mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-01-14 00:39:57 +09:00
simulz님의 rank count 위젯 추가
git-svn-id: http://xe-core.googlecode.com/svn/sandbox@3076 201d5d3c-b55e-5fd7-737f-ddc643e51545
This commit is contained in:
parent
b5eac321ee
commit
9a8a1d50bf
18 changed files with 670 additions and 0 deletions
73
widgets/rank_count/conf/info.xml
Normal file
73
widgets/rank_count/conf/info.xml
Normal file
|
|
@ -0,0 +1,73 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<widget version="0.5">
|
||||
<title xml:lang="ko">글, 댓글 랭킹 출력</title>
|
||||
<author email_address="simulz@simulz.com" link="http://www.simulz.com" date="2007. 10. 07">
|
||||
<name xml:lang="ko">Simulz</name>
|
||||
<description xml:lang="ko">글, 댓글 작성 순위를 출력합니다.</description>
|
||||
</author>
|
||||
<extra_vars>
|
||||
<var id="title">
|
||||
<name xml:lang="ko">제목</name>
|
||||
<type>text</type>
|
||||
<description xml:lang="ko">위젯의 제목으로 출력됩니다.</description>
|
||||
</var>
|
||||
<var id="list_count">
|
||||
<name xml:lang="ko">목록수</name>
|
||||
<type>text</type>
|
||||
<description xml:lang="ko">출력될 목록의 수를 정하실 수 있습니다. (기본 5개)</description>
|
||||
</var>
|
||||
<var id="rankby">
|
||||
<name xml:lang="ko">순위 대상</name>
|
||||
<type>select</type>
|
||||
<description xml:lang="ko">대상을 선택하세요.</description>
|
||||
<options>
|
||||
<name xml:lang="ko">글 작성</name>
|
||||
<value>document</value>
|
||||
</options>
|
||||
<options>
|
||||
<name xml:lang="ko">댓글 작성</name>
|
||||
<value>comment</value>
|
||||
</options>
|
||||
<options>
|
||||
<name xml:lang="ko">파일 첨부</name>
|
||||
<value>attach</value>
|
||||
</options>
|
||||
<options>
|
||||
<name xml:lang="ko">추천 수</name>
|
||||
<value>vote</value>
|
||||
</options>
|
||||
<options>
|
||||
<name xml:lang="ko">조회 수</name>
|
||||
<value>read</value>
|
||||
</options>
|
||||
</var>
|
||||
<var id="without_admin">
|
||||
<name xml:lang="ko">관리자</name>
|
||||
<type>select</type>
|
||||
<description xml:lang="ko">순위에 관리자를 포함합니다.</description>
|
||||
<options>
|
||||
<name xml:lang="ko">포함</name>
|
||||
<value>false</value>
|
||||
</options>
|
||||
<options>
|
||||
<name xml:lang="ko">미포함</name>
|
||||
<value>true</value>
|
||||
</options>
|
||||
</var>
|
||||
<var id="with_group">
|
||||
<name xml:lang="ko">그룹 포함</name>
|
||||
<type>text</type>
|
||||
<description xml:lang="ko">출력할 회원 그룹명을 입력하세요. 예)준회원,정회원</description>
|
||||
</var>
|
||||
<var id="without_group">
|
||||
<name xml:lang="ko">그룹 제외</name>
|
||||
<type>text</type>
|
||||
<description xml:lang="ko">제외할 회원 그룹명을 입력하세요. 예)관리그룹</description>
|
||||
</var>
|
||||
<var id="regdate">
|
||||
<name xml:lang="ko">기간(일)</name>
|
||||
<type>text</type>
|
||||
<description xml:lang="ko">설정 기간 내의 순위를 출력합니다.</description>
|
||||
</var>
|
||||
</extra_vars>
|
||||
</widget>
|
||||
25
widgets/rank_count/queries/getRankCommentCount.xml
Normal file
25
widgets/rank_count/queries/getRankCommentCount.xml
Normal file
|
|
@ -0,0 +1,25 @@
|
|||
<query id="getRankCommentCount" action="select">
|
||||
<tables>
|
||||
<table name="comments" alias="comments" />
|
||||
<table name="member" alias="member" />
|
||||
</tables>
|
||||
<columns>
|
||||
<column name="member.*" />
|
||||
<column name="count(*)" alias="count" />
|
||||
</columns>
|
||||
<conditions>
|
||||
<condition operation="excess" column="comments.member_srl" default="0" />
|
||||
<condition operation="equal" column="comments.member_srl" var="member.member_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.is_admin" var="is_admin" pipe="and" />
|
||||
<group pipe="and">
|
||||
<condition operation="more" column="comments.regdate" var="regdate" pipe="or" />
|
||||
</group>
|
||||
</conditions>
|
||||
<groups>
|
||||
<group column="comments.member_srl" />
|
||||
</groups>
|
||||
<navigation>
|
||||
<index var="sort_index" default="count" order="desc" />
|
||||
<list_count var="list_count" default="20" />
|
||||
</navigation>
|
||||
</query>
|
||||
|
|
@ -0,0 +1,29 @@
|
|||
<query id="getRankCommentCount" action="select">
|
||||
<tables>
|
||||
<table name="comments" alias="comments" />
|
||||
<table name="member" alias="member" />
|
||||
<table name="member_group_member" alias="member_group"/>
|
||||
</tables>
|
||||
<columns>
|
||||
<column name="member.*" />
|
||||
<column name="count(*)" alias="count" />
|
||||
</columns>
|
||||
<conditions>
|
||||
<condition operation="in" column="member_group.group_srl" var="selected_group_srl" />
|
||||
<condition operation="notequal" column="member_group.group_srl" var="selected_group_without_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.member_srl" var="member_group.member_srl" pipe="and" notnull="notnull" />
|
||||
<condition operation="excess" column="comments.member_srl" default="0" pipe="and" />
|
||||
<condition operation="equal" column="comments.member_srl" var="member.member_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.is_admin" var="is_admin" pipe="and" />
|
||||
<group pipe="and">
|
||||
<condition operation="more" column="comments.regdate" var="regdate" pipe="or" />
|
||||
</group>
|
||||
</conditions>
|
||||
<groups>
|
||||
<group column="comments.member_srl" />
|
||||
</groups>
|
||||
<navigation>
|
||||
<index var="sort_index" default="count" order="desc" />
|
||||
<list_count var="list_count" default="20" />
|
||||
</navigation>
|
||||
</query>
|
||||
25
widgets/rank_count/queries/getRankDocumentCount.xml
Normal file
25
widgets/rank_count/queries/getRankDocumentCount.xml
Normal file
|
|
@ -0,0 +1,25 @@
|
|||
<query id="getRankDocumentCount" action="select">
|
||||
<tables>
|
||||
<table name="documents" alias="documents" />
|
||||
<table name="member" alias="member" />
|
||||
</tables>
|
||||
<columns>
|
||||
<column name="member.*" />
|
||||
<column name="count(*)" alias="count" />
|
||||
</columns>
|
||||
<conditions>
|
||||
<condition operation="excess" column="documents.member_srl" default="0" />
|
||||
<condition operation="equal" column="documents.member_srl" var="member.member_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.is_admin" var="is_admin" pipe="and" />
|
||||
<group pipe="and">
|
||||
<condition operation="more" column="documents.regdate" var="regdate" pipe="or" />
|
||||
</group>
|
||||
</conditions>
|
||||
<groups>
|
||||
<group column="documents.member_srl" />
|
||||
</groups>
|
||||
<navigation>
|
||||
<index var="sort_index" default="count" order="desc" />
|
||||
<list_count var="list_count" default="20" />
|
||||
</navigation>
|
||||
</query>
|
||||
|
|
@ -0,0 +1,29 @@
|
|||
<query id="getRankDocumentCount" action="select">
|
||||
<tables>
|
||||
<table name="documents" alias="documents" />
|
||||
<table name="member" alias="member" />
|
||||
<table name="member_group_member" alias="member_group"/>
|
||||
</tables>
|
||||
<columns>
|
||||
<column name="member.*" />
|
||||
<column name="count(*)" alias="count" />
|
||||
</columns>
|
||||
<conditions>
|
||||
<condition operation="in" column="member_group.group_srl" var="selected_group_srl" />
|
||||
<condition operation="notequal" column="member_group.group_srl" var="selected_group_without_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.member_srl" var="member_group.member_srl" pipe="and" notnull="notnull" />
|
||||
<condition operation="excess" column="documents.member_srl" default="0" pipe="and" />
|
||||
<condition operation="equal" column="documents.member_srl" var="member.member_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.is_admin" var="is_admin" pipe="and" />
|
||||
<group pipe="and">
|
||||
<condition operation="more" column="documents.regdate" var="regdate" pipe="or" />
|
||||
</group>
|
||||
</conditions>
|
||||
<groups>
|
||||
<group column="documents.member_srl" />
|
||||
</groups>
|
||||
<navigation>
|
||||
<index var="sort_index" default="count" order="desc" />
|
||||
<list_count var="list_count" default="20" />
|
||||
</navigation>
|
||||
</query>
|
||||
26
widgets/rank_count/queries/getRankReadedCount.xml
Normal file
26
widgets/rank_count/queries/getRankReadedCount.xml
Normal file
|
|
@ -0,0 +1,26 @@
|
|||
<query id="getRankReadedCount" action="select">
|
||||
<tables>
|
||||
<table name="documents" alias="documents" />
|
||||
<table name="member" alias="member" />
|
||||
</tables>
|
||||
<columns>
|
||||
<column name="member.*" />
|
||||
<column name="sum(readed_count)" alias="count" />
|
||||
</columns>
|
||||
<conditions>
|
||||
<condition operation="excess" column="documents.member_srl" default="0" />
|
||||
<condition operation="excess" column="documents.readed_count" default="0" pipe="and" />
|
||||
<condition operation="equal" column="documents.member_srl" var="member.member_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.is_admin" var="is_admin" pipe="and" />
|
||||
<group pipe="and">
|
||||
<condition operation="more" column="documents.regdate" var="regdate" pipe="or" />
|
||||
</group>
|
||||
</conditions>
|
||||
<groups>
|
||||
<group column="documents.member_srl" />
|
||||
</groups>
|
||||
<navigation>
|
||||
<index var="sort_index" default="count" order="desc" />
|
||||
<list_count var="list_count" default="20" />
|
||||
</navigation>
|
||||
</query>
|
||||
30
widgets/rank_count/queries/getRankReadedCountWithinGroup.xml
Normal file
30
widgets/rank_count/queries/getRankReadedCountWithinGroup.xml
Normal file
|
|
@ -0,0 +1,30 @@
|
|||
<query id="getRankReadedCountWithinGroup" action="select">
|
||||
<tables>
|
||||
<table name="documents" alias="documents" />
|
||||
<table name="member" alias="member" />
|
||||
<table name="member_group_member" alias="member_group"/>
|
||||
</tables>
|
||||
<columns>
|
||||
<column name="member.*" />
|
||||
<column name="sum(readed_count)" alias="count" />
|
||||
</columns>
|
||||
<conditions>
|
||||
<condition operation="in" column="member_group.group_srl" var="selected_group_srl" />
|
||||
<condition operation="notequal" column="member_group.group_srl" var="selected_group_without_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.member_srl" var="member_group.member_srl" pipe="and" notnull="notnull" />
|
||||
<condition operation="excess" column="documents.member_srl" default="0" pipe="and" />
|
||||
<condition operation="excess" column="documents.readed_count" default="0" pipe="and" />
|
||||
<condition operation="equal" column="documents.member_srl" var="member.member_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.is_admin" var="is_admin" pipe="and" />
|
||||
<group pipe="and">
|
||||
<condition operation="more" column="documents.regdate" var="regdate" pipe="or" />
|
||||
</group>
|
||||
</conditions>
|
||||
<groups>
|
||||
<group column="documents.member_srl" />
|
||||
</groups>
|
||||
<navigation>
|
||||
<index var="sort_index" default="count" order="desc" />
|
||||
<list_count var="list_count" default="20" />
|
||||
</navigation>
|
||||
</query>
|
||||
26
widgets/rank_count/queries/getRankUploadedCount.xml
Normal file
26
widgets/rank_count/queries/getRankUploadedCount.xml
Normal file
|
|
@ -0,0 +1,26 @@
|
|||
<query id="getRankUploadedCount" action="select">
|
||||
<tables>
|
||||
<table name="documents" alias="documents" />
|
||||
<table name="member" alias="member" />
|
||||
</tables>
|
||||
<columns>
|
||||
<column name="member.*" />
|
||||
<column name="sum(uploaded_count)" alias="count" />
|
||||
</columns>
|
||||
<conditions>
|
||||
<condition operation="excess" column="documents.member_srl" default="0" />
|
||||
<condition operation="excess" column="documents.uploaded_count" default="0" pipe="and" />
|
||||
<condition operation="equal" column="documents.member_srl" var="member.member_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.is_admin" var="is_admin" pipe="and" />
|
||||
<group pipe="and">
|
||||
<condition operation="more" column="documents.regdate" var="regdate" pipe="or" />
|
||||
</group>
|
||||
</conditions>
|
||||
<groups>
|
||||
<group column="documents.member_srl" />
|
||||
</groups>
|
||||
<navigation>
|
||||
<index var="sort_index" default="count" order="desc" />
|
||||
<list_count var="list_count" default="20" />
|
||||
</navigation>
|
||||
</query>
|
||||
|
|
@ -0,0 +1,30 @@
|
|||
<query id="getRankUploadedCountWithinGroup" action="select">
|
||||
<tables>
|
||||
<table name="documents" alias="documents" />
|
||||
<table name="member" alias="member" />
|
||||
<table name="member_group_member" alias="member_group"/>
|
||||
</tables>
|
||||
<columns>
|
||||
<column name="member.*" />
|
||||
<column name="sum(uploaded_count)" alias="count" />
|
||||
</columns>
|
||||
<conditions>
|
||||
<condition operation="in" column="member_group.group_srl" var="selected_group_srl" />
|
||||
<condition operation="notequal" column="member_group.group_srl" var="selected_group_without_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.member_srl" var="member_group.member_srl" pipe="and" notnull="notnull" />
|
||||
<condition operation="excess" column="documents.member_srl" default="0" pipe="and" />
|
||||
<condition operation="excess" column="documents.uploaded_count" default="0" pipe="and" />
|
||||
<condition operation="equal" column="documents.member_srl" var="member.member_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.is_admin" var="is_admin" pipe="and" />
|
||||
<group pipe="and">
|
||||
<condition operation="more" column="documents.regdate" var="regdate" pipe="or" />
|
||||
</group>
|
||||
</conditions>
|
||||
<groups>
|
||||
<group column="documents.member_srl" />
|
||||
</groups>
|
||||
<navigation>
|
||||
<index var="sort_index" default="count" order="desc" />
|
||||
<list_count var="list_count" default="20" />
|
||||
</navigation>
|
||||
</query>
|
||||
26
widgets/rank_count/queries/getRankVotedCount.xml
Normal file
26
widgets/rank_count/queries/getRankVotedCount.xml
Normal file
|
|
@ -0,0 +1,26 @@
|
|||
<query id="getRankVotedCount" action="select">
|
||||
<tables>
|
||||
<table name="documents" alias="documents" />
|
||||
<table name="member" alias="member" />
|
||||
</tables>
|
||||
<columns>
|
||||
<column name="member.*" />
|
||||
<column name="sum(voted_count)" alias="count" />
|
||||
</columns>
|
||||
<conditions>
|
||||
<condition operation="excess" column="documents.member_srl" default="0" />
|
||||
<condition operation="excess" column="documents.voted_count" default="0" pipe="and" />
|
||||
<condition operation="equal" column="documents.member_srl" var="member.member_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.is_admin" var="is_admin" pipe="and" />
|
||||
<group pipe="and">
|
||||
<condition operation="more" column="documents.regdate" var="regdate" pipe="or" />
|
||||
</group>
|
||||
</conditions>
|
||||
<groups>
|
||||
<group column="documents.member_srl" />
|
||||
</groups>
|
||||
<navigation>
|
||||
<index var="sort_index" default="count" order="desc" />
|
||||
<list_count var="list_count" default="20" />
|
||||
</navigation>
|
||||
</query>
|
||||
30
widgets/rank_count/queries/getRankVotedCountWithinGroup.xml
Normal file
30
widgets/rank_count/queries/getRankVotedCountWithinGroup.xml
Normal file
|
|
@ -0,0 +1,30 @@
|
|||
<query id="getRankVotedCountWithinGroup" action="select">
|
||||
<tables>
|
||||
<table name="documents" alias="documents" />
|
||||
<table name="member" alias="member" />
|
||||
<table name="member_group_member" alias="member_group"/>
|
||||
</tables>
|
||||
<columns>
|
||||
<column name="member.*" />
|
||||
<column name="sum(voted_count)" alias="count" />
|
||||
</columns>
|
||||
<conditions>
|
||||
<condition operation="in" column="member_group.group_srl" var="selected_group_srl" />
|
||||
<condition operation="notequal" column="member_group.group_srl" var="selected_group_without_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.member_srl" var="member_group.member_srl" pipe="and" notnull="notnull" />
|
||||
<condition operation="excess" column="documents.member_srl" default="0" pipe="and" />
|
||||
<condition operation="excess" column="documents.voted_count" default="0" pipe="and" />
|
||||
<condition operation="equal" column="documents.member_srl" var="member.member_srl" pipe="and" />
|
||||
<condition operation="equal" column="member.is_admin" var="is_admin" pipe="and" />
|
||||
<group pipe="and">
|
||||
<condition operation="more" column="documents.regdate" var="regdate" pipe="or" />
|
||||
</group>
|
||||
</conditions>
|
||||
<groups>
|
||||
<group column="documents.member_srl" />
|
||||
</groups>
|
||||
<navigation>
|
||||
<index var="sort_index" default="count" order="desc" />
|
||||
<list_count var="list_count" default="20" />
|
||||
</navigation>
|
||||
</query>
|
||||
225
widgets/rank_count/rank_count.class.php
Normal file
225
widgets/rank_count/rank_count.class.php
Normal file
|
|
@ -0,0 +1,225 @@
|
|||
<?php
|
||||
/**
|
||||
* @class rank_count
|
||||
* @author Simulz.com (simulz@simulz.com)
|
||||
* @brief 글, 댓글, 첨부 랭킹
|
||||
* @version 0.1
|
||||
**/
|
||||
|
||||
class rank_count extends WidgetHandler {
|
||||
|
||||
/**
|
||||
* @brief 위젯의 실행 부분
|
||||
*
|
||||
* ./widgets/위젯/conf/info.xml 에 선언한 extra_vars를 args로 받는다
|
||||
* 결과를 만든후 print가 아니라 return 해주어야 한다
|
||||
**/
|
||||
function proc($args) {
|
||||
// 위젯 자체적으로 설정한 변수들을 체크
|
||||
$title = $args->title;
|
||||
$rankby = $args->rankby;
|
||||
$period = (int)$args->regdate;
|
||||
$list_count = (int)$args->list_count;
|
||||
if(!$list_count) $list_count = 5;
|
||||
$mid_list = explode(",",$args->mid_list);
|
||||
$subject_cut_size = $args->subject_cut_size;
|
||||
if(!$subject_cut_size) $subject_cut_size = 0;
|
||||
|
||||
//그룹 정보를 구해옴 (그룹 포함)
|
||||
$tmp_groups = explode(",",$args->with_group);
|
||||
$count = count($tmp_groups);
|
||||
for($i = 0; $i < $count; $i++) {
|
||||
$group_name = trim($tmp_groups[$i]);
|
||||
if(!$group_name) continue;
|
||||
$target_group[$i] = $group_name;
|
||||
}
|
||||
|
||||
//그룹 정보를 구해옴 (그룹 제외)
|
||||
$tmp_groups = explode(",",$args->without_group);
|
||||
$count = count($tmp_groups);
|
||||
for($i = 0; $i < $count; $i++) {
|
||||
$group_name = trim($tmp_groups[$i]);
|
||||
if(!$group_name) continue;
|
||||
$target_group_without[$i] = $group_name;
|
||||
}
|
||||
|
||||
if($period) {
|
||||
$before_month_month_day = $this->convertDatetoDay( date("n") == 1 ? date("Y") - 1 : date("Y"), date("n") == 1 ? 12 : date("n") - 1);
|
||||
|
||||
$m = date("n");
|
||||
$y = date("Y");
|
||||
|
||||
if(date("j") < $period) {
|
||||
$day = $before_month_month_day + date("j") - $period + 1;
|
||||
$m = $m - 1;
|
||||
if($m < 1) {
|
||||
$m = 12;
|
||||
$y = $y - 1;
|
||||
}
|
||||
} else {
|
||||
$day = date("j") - $period + 1;
|
||||
}
|
||||
|
||||
$widget_info->date_from = $y."-".sprintf("%02d", $m)."-".sprintf("%02d", $day);
|
||||
$widget_info->period = $period;
|
||||
$obj->regdate = $y.sprintf("%02d", $m).sprintf("%02d", $day).date("His");
|
||||
}
|
||||
|
||||
$oMemberModel = &getModel('member');
|
||||
$this->oPointModel = &getModel('point');
|
||||
|
||||
$obj->list_count = $list_count;
|
||||
$obj->is_admin = $args->without_admin == "true" ? "N" : "";
|
||||
|
||||
if(count($target_group) || count($target_group_without)) {
|
||||
// 그룹 목록을 구해옴
|
||||
$group_list = $oMemberModel->getGroups();
|
||||
|
||||
if(count($target_group)) {
|
||||
foreach($group_list as $group_srl => $val) {
|
||||
if(!in_array($val->title, $target_group)) continue;
|
||||
$target_group_srl_list[] = $group_srl;
|
||||
}
|
||||
} else {
|
||||
foreach($group_list as $group_srl => $val) {
|
||||
if(!in_array($val->title, $target_group_without)) continue;
|
||||
$target_group_without_srl_list[] = $group_srl;
|
||||
}
|
||||
}
|
||||
|
||||
// 해당 그룹의 멤버를 구해옴
|
||||
if(count($target_group_srl_list) || count($target_group_without_srl_list)) {
|
||||
if(count($target_group_srl_list)) $obj->selected_group_srl = implode(',',$target_group_srl_list);
|
||||
else $obj->selected_group_without_srl = implode(',',$target_group_without_srl_list);
|
||||
|
||||
if($rankby == "document") $output = executeQuery('widgets.rank_count.getRankDocumentCountWithinGroup', $obj);
|
||||
elseif($rankby == "comment") $output = executeQuery('widgets.rank_count.getRankCommentCountWithinGroup', $obj);
|
||||
elseif($rankby == "attach") $output = executeQuery('widgets.rank_count.getRankUploadedCountWithinGroup', $obj);
|
||||
elseif($rankby == "vote") $output = executeQuery('widgets.rank_count.getRankVotedCountWithinGroup', $obj);
|
||||
elseif($rankby == "read") $output = executeQuery('widgets.rank_count.getRankReadedCountWithinGroup', $obj);
|
||||
}
|
||||
}
|
||||
else {
|
||||
//전체 목록을 구해옴
|
||||
if($rankby == "document") $output = executeQuery('widgets.rank_count.getRankDocumentCount', $obj);
|
||||
elseif($rankby == "comment") $output = executeQuery('widgets.rank_count.getRankCommentCount', $obj);
|
||||
elseif($rankby == "attach") $output = executeQuery('widgets.rank_count.getRankUploadedCount', $obj);
|
||||
elseif($rankby == "vote") $output = executeQuery('widgets.rank_count.getRankVotedCount', $obj);
|
||||
elseif($rankby == "read") $output = executeQuery('widgets.rank_count.getRankReadedCount', $obj);
|
||||
}
|
||||
|
||||
// 오류가 생기면 그냥 무시
|
||||
//if(!$output->toBool()) return;
|
||||
|
||||
// 결과가 있으면 각 문서 객체화를 시킴
|
||||
if(count($output->data)) {
|
||||
foreach($output->data as $key => $val) {
|
||||
$val->point = $this->oPointModel->getPoint($val->member_srl);
|
||||
$val->perlev = $this->point_info($val->member_srl);
|
||||
|
||||
$image_name = $oMemberModel->getImageName($val->member_srl);
|
||||
$image_mark = $oMemberModel->getImageMark($val->member_srl);
|
||||
if($image_name->width) {
|
||||
if($image_mark->height && $image_mark->height > $image_name->height) $top_margin = ($image_mark->height - $image_name->height)/2;
|
||||
else $top_margin = 0;
|
||||
$val->nick_name = sprintf('<img src="%s" border="0" alt="%s" title="%s" width="%s" height="%s" align="absmiddle" style="margin-top:%dpx;" />', Context::getRequestUri().$image_name->file, $image_name->file, $image_name->file, $image_name->width, $image_name->height, $top_margin);
|
||||
}
|
||||
if($image_mark->width) {
|
||||
$val->nick_name = sprintf('<img src="%s" border="0" alt="%s" title="%s" width="%s" height="%s" align="absmiddle" />', Context::getRequestUri().$image_mark->file, $image_mark->file, $image_mark->file, $image_mark->width, $image_mark->height).$val->nick_name;
|
||||
}
|
||||
|
||||
$rank_list[$key] = $val;
|
||||
}
|
||||
} else {
|
||||
$rank_list = array();
|
||||
}
|
||||
|
||||
// 템플릿 파일에서 사용할 변수들을 세팅
|
||||
if(count($mid_list)==1) $widget_info->module_name = $mid_list[0];
|
||||
|
||||
$widget_info->title = $title;
|
||||
$widget_info->list_count = $list_count;
|
||||
$widget_info->data = $rank_list;
|
||||
$widget_info->rankby = $rankby;
|
||||
|
||||
Context::set('widget_info', $widget_info);
|
||||
|
||||
// 템플릿의 스킨 경로를 지정 (skin, colorset에 따른 값을 설정)
|
||||
$tpl_path = sprintf('%sskins/%s', $this->widget_path, $args->skin);
|
||||
Context::set('colorset', $args->colorset);
|
||||
|
||||
// 템플릿 파일을 지정
|
||||
$tpl_file = 'list';
|
||||
|
||||
// 템플릿 컴파일
|
||||
$oTemplate = &TemplateHandler::getInstance();
|
||||
$output = $oTemplate->compile($tpl_path, $tpl_file);
|
||||
return $output;
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief 포인트 정보 표시
|
||||
**/
|
||||
function point_info($member_srl) {
|
||||
$oModuleModel = &getModel('module');
|
||||
$this->config = $oModuleModel->getModuleConfig('point');
|
||||
|
||||
$point = $this->oPointModel->getPoint($member_srl);
|
||||
$level = $this->oPointModel->getLevel($point, $this->config->level_step);
|
||||
|
||||
$src = sprintf("modules/point/icons/%s/%d.gif", $this->config->level_icon, $level);
|
||||
$info = getimagesize($src);
|
||||
$this->icon_width = $info[0];
|
||||
$this->icon_height = $info[1];
|
||||
|
||||
if($level < $this->config->max_level) {
|
||||
$next_point = $this->config->level_step[$level+1];
|
||||
if($next_point > 0) {
|
||||
$per = (int)($point / $next_point*100);
|
||||
}
|
||||
}
|
||||
|
||||
$code = sprintf('title="%s:%s%s %s, %s:%s/%s" style="background:url(%s) no-repeat left;padding-left:%dpx; height:%dpx"', Context::getLang('point'), $point, $this->config->point_name, $per?"(".$per."%)":"", Context::getLang('level'), $level, $this->config->max_level, Context::getRequestUri().$src, $this->icon_width+2, $this->icon_height);
|
||||
return $code;
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief 날짜 수 계산
|
||||
**/
|
||||
function convertDatetoDay($year, $month) {
|
||||
$numOfLeapYear = 0; // 윤년의 수
|
||||
|
||||
// 전년도까지의 윤년의 수를 구한다.
|
||||
for($i = 0; $i < $year; $i++) {
|
||||
if($this->isLeapYear($i)) $numOfLeapYear++;
|
||||
}
|
||||
|
||||
// 전년도까지의 일 수를 구한다.
|
||||
$toLastYearDaySum = ($year-1) * 365 + $numOfLeapYear;
|
||||
|
||||
// 올해의 현재 월까지의 일수 계산
|
||||
$thisYearDaySum = 0;
|
||||
// 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12
|
||||
$endOfMonth = array(1 => 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
|
||||
|
||||
for($i = 1; $i < $month; $i++) {
|
||||
$thisYearDaySum += $endOfMonth[$i];
|
||||
}
|
||||
|
||||
// 윤년이고, 2월이 포함되어 있으면 1일을 증가시킨다.
|
||||
if ($month > 2 && $this->isLeapYear($year)) $thisYearDaySum++;
|
||||
|
||||
if($this->isLeapYear($year)) $endOfMonth[2] = 29;
|
||||
|
||||
return $endOfMonth[$month];
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief 윤년 검사
|
||||
**/
|
||||
function isLeapYear($year) {
|
||||
if ($year % 4 == 0 && $year % 100 != 0 || $year % 400 == 0) return true;
|
||||
else return false;
|
||||
}
|
||||
}
|
||||
?>
|
||||
22
widgets/rank_count/skins/sz_xe/css/default.css
Normal file
22
widgets/rank_count/skins/sz_xe/css/default.css
Normal file
|
|
@ -0,0 +1,22 @@
|
|||
.szrank_count { width:100%; position:relative; }
|
||||
.szrank_count h2 { display:block; height:21px; padding:9px 0 0 9px; color:#000000; font-size:1em;}
|
||||
.szrank_count h5{ display:block; height:21px; padding:9px 0 0 9px; margin-top:-15px; color:#000000; font-size:1em;}
|
||||
|
||||
.szrank_count .left { cursor:pointer; height:20px; background:url(../images/default/bullet.gif) no-repeat left; padding-left:15px; overflow:hidden; }
|
||||
|
||||
.szrank_count .center { text-align:right; padding-left:5px; }
|
||||
|
||||
.szrank_count .sz_Box_000{border:solid 0;padding:0;}
|
||||
.szrank_count .sz_Box_001{width:100%;border:solid 1px;border-color:#E7E7E7;padding:5px 5px 2px 5px;background-color:#F4F4F4;color:#696969;}
|
||||
.szrank_count .sz_Box_002{width:100%;border:solid 1px;border-color:#DDEAA8;padding:5px 5px 2px 5px;background-color:#FBFDF1;color:#99B81A;}
|
||||
.szrank_count .sz_Box_003{width:100%;border:solid 1px;border-color:#F9D5D5;padding:5px 5px 2px 5px;background-color:#FEF6F6;color:#D98383;}
|
||||
.szrank_count .sz_Box_004{width:100%;border:solid 1px;border-color:#EFDAF4;padding:5px 5px 2px 5px;background-color:#FCF7FD;color:#AF69C0;}
|
||||
.szrank_count .sz_Box_005{width:100%;border:solid 1px;border-color:#DCDFF6;padding:5px 5px 2px 5px;background-color:#F6F7FE;color:#7381EA;}
|
||||
.szrank_count .sz_Box_006{width:100%;border:solid 1px;border-color:#DAEAEE;padding:5px 5px 2px 5px;background-color:#F0F6F8;color:#619DAC;}
|
||||
.szrank_count .sz_Box_007{width:100%;border:solid 1px;border-color:#D5EDDD;padding:5px 5px 2px 5px;background-color:#EFF9F2;color:#6FB587;}
|
||||
.szrank_count .sz_Box_008{width:100%;border:solid 1px;border-color:#FFEC15;padding:5px 5px 2px 5px;background-color:#FFFCDF;color:#FF9900;}
|
||||
.szrank_count .sz_Box_009{width:100%;border:solid 1px;border-color:#9DD7E8;padding:5px 5px 2px 5px;background-color:#F8FDFF;color:#0A8DBD;}
|
||||
|
||||
.szrank_count a {color: #000000; text-decoration:none;}
|
||||
.szrank_count a:hover {color: #000000;}
|
||||
.szrank_count a:visit {color: #000000;}
|
||||
BIN
widgets/rank_count/skins/sz_xe/images/default/bullet.gif
Normal file
BIN
widgets/rank_count/skins/sz_xe/images/default/bullet.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 282 B |
BIN
widgets/rank_count/skins/sz_xe/images/default/bulletD0.gif
Normal file
BIN
widgets/rank_count/skins/sz_xe/images/default/bulletD0.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 44 B |
BIN
widgets/rank_count/skins/sz_xe/images/default/lineNotice.gif
Normal file
BIN
widgets/rank_count/skins/sz_xe/images/default/lineNotice.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 139 B |
32
widgets/rank_count/skins/sz_xe/list.html
Normal file
32
widgets/rank_count/skins/sz_xe/list.html
Normal file
|
|
@ -0,0 +1,32 @@
|
|||
<!-- 설정된 컬러셋의 종류에 따라서 css파일을 import 합니다 -->
|
||||
|
||||
<!--%import("css/default.css")-->
|
||||
|
||||
<div class="szrank_count">
|
||||
<div class="sz_{$colorset}">
|
||||
<!--@if($widget_info->title)-->
|
||||
<h2>{$widget_info->title} Top {$widget_info->list_count}</h2>
|
||||
<!--@end-->
|
||||
<h5><!--@if($widget_info->period)-->(기간: {$widget_info->period}일, {$widget_info->date_from}~)<!--@end--></h5>
|
||||
|
||||
<table>
|
||||
{@ $no = 1}
|
||||
<!--@foreach($widget_info->data as $val)-->
|
||||
<tr class="member_{$val->member_srl}">
|
||||
<td class="left">{$no}위. <span class="nick_name" {$val->perlev}>{$val->nick_name}</span></td>
|
||||
<td class="center">{$val->count}회</td>
|
||||
<td class="right">
|
||||
<!--@if($logged_info->is_admin == "Y")-->
|
||||
<!--@if($widget_info->rankby == "document")-->
|
||||
<a href="{getUrl('module','admin','act','dispDocumentAdminList','search_target','member_srl','search_keyword',$val->member_srl)}" target="_blank">[작성글]</a>
|
||||
<!--@elseif($widget_info->rankby == "comment")-->
|
||||
<a href="{getUrl('module','admin','act','dispCommentAdminList','search_target','user_id','search_keyword',$val->user_id)}" target="_blank">[작성댓글]</a>
|
||||
<!--@end-->
|
||||
<!--@end-->
|
||||
</td>
|
||||
</tr>
|
||||
{@ $no++}
|
||||
<!--@end-->
|
||||
</table>
|
||||
</div>
|
||||
</div>
|
||||
42
widgets/rank_count/skins/sz_xe/skin.xml
Normal file
42
widgets/rank_count/skins/sz_xe/skin.xml
Normal file
|
|
@ -0,0 +1,42 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<skin>
|
||||
<title xml:lang="ko">Simulz 랭킹 스킨</title>
|
||||
<maker email_address="k10206@naver.com" link="http://www.simulz.com" date="2007. 8. 29">
|
||||
<name xml:lang="ko">Simulz</name>
|
||||
<description xml:lang="ko">
|
||||
Simulz 랭킹 스킨입니다.
|
||||
</description>
|
||||
</maker>
|
||||
<colorset>
|
||||
<color name="Box_000">
|
||||
<title xml:lang="ko">기본</title>
|
||||
</color>
|
||||
<color name="Box_001">
|
||||
<title xml:lang="ko">회색</title>
|
||||
</color>
|
||||
<color name="Box_002">
|
||||
<title xml:lang="ko">연두</title>
|
||||
</color>
|
||||
<color name="Box_003">
|
||||
<title xml:lang="ko">분홍</title>
|
||||
</color>
|
||||
<color name="Box_004">
|
||||
<title xml:lang="ko">보라</title>
|
||||
</color>
|
||||
<color name="Box_005">
|
||||
<title xml:lang="ko">밝은 파랑</title>
|
||||
</color>
|
||||
<color name="Box_006">
|
||||
<title xml:lang="ko">청록</title>
|
||||
</color>
|
||||
<color name="Box_007">
|
||||
<title xml:lang="ko">초록</title>
|
||||
</color>
|
||||
<color name="Box_008">
|
||||
<title xml:lang="ko">노랑</title>
|
||||
</color>
|
||||
<color name="Box_009">
|
||||
<title xml:lang="ko">파랑</title>
|
||||
</color>
|
||||
</colorset>
|
||||
</skin>
|
||||
Loading…
Add table
Add a link
Reference in a new issue