yyy-group/net/module/poll/poll.lib.php
2023-06-20 10:48:26 +09:00

310 lines
7.4 KiB
PHP

<?
/*********************************** 투표관리 *************************************/
//투표 등록
function insertPoll(){
$tbl = $GLOBALS["_conf_tbl"]["poll_info"];
$tbl_contents = $GLOBALS["_conf_tbl"]["poll_contents"];
$use_login = mysql_real_escape_string($_POST[use_login])=="Y"?"Y":"N";
$is_show = mysql_real_escape_string($_POST[is_show])=="Y"?"Y":"N";
//투표정보에 입력
$sql = "insert into ".$tbl." SET
subject= '".mysql_real_escape_string($_POST[subject])."',
use_login= '".$use_login."',
is_show= '".$is_show."',
sdate = '".mysql_real_escape_string($_POST[sdate])."',
edate = '".mysql_real_escape_string($_POST[edate])."',
wdate = now()
";
$rs = mysql_query($sql,$GLOBALS[dblink]);
$insert_idx = mysql_insert_id($GLOBALS[dblink]);
$total = mysql_affected_rows($GLOBALS[dblink]);
if($total > 0){
//투표항목에 입력
for($i=0;$i<count($_POST[answer]);$i++){
if(trim(mysql_real_escape_string($_POST[answer][$i]))!=""){
$sql = "insert into ".$tbl_contents." SET
p_idx= '".$insert_idx."',
answer= '".mysql_real_escape_string($_POST[answer][$i])."'
";
mysql_query($sql,$GLOBALS[dblink]);
}
}
return true;
}else{
return false;
}
}
function getPollList($scale, $offset=0){
// 테이블 지정
$tbl = $GLOBALS["_conf_tbl"]["poll_info"];
$sql = "SELECT * FROM $tbl WHERE 1=1 ";
$sql .= " order by idx desc ";
$rs = mysql_query($sql, $GLOBALS[dblink]);
$total_rs = mysql_num_rows($rs);
//echo $sql;
if($total_rs > 0){
$list['total'] = $total_rs;
// 페이지 네비게이션 오프셋 지정.
if(!$offset){
$offset=0;
}else{
$offset=$offset;
}
// offset 이 전체 게시물수보다 작을때 offset 을 전체게시물 - 페이지당 보여줄 글 수로 offset 설정
if($total_rs<=$offset){
$offset = $total_rs - $scale;
}
//scale 0 으로 지정시에는 전체 가져옴
if($scale > 0){
$sql .= " limit $offset,$scale ";
}
$rs = mysql_query($sql,$GLOBALS[dblink]);
// offset 을 이용한 limit 가 적용된 갯수
$total = mysql_num_rows($rs);
$list['list']['total'] = $total;
// 페이지 네비게이션 오프셋 지정.
for($i=0; $i < $total; $i++){
$list['list'][$i] = mysql_fetch_assoc($rs);
}
}else{
$list['total'] = 0;
}
return $list;
}
//테이블에서 목록 가져오기
function getPollAnswerList($idx, $orderby){
// 테이블 지정
$tbl = $GLOBALS["_conf_tbl"]["poll_contents"];
if($orderby){
$orderby = $orderby;
}else{
$orderby = "idx asc";
}
$sql = "SELECT * ";
$sql .= "FROM $tbl WHERE p_idx='$idx' order by $orderby ";
//echo $sql;
$rs = mysql_query($sql, $GLOBALS[dblink]);
$total_rs = mysql_num_rows($rs);
if($total_rs > 0){
$list['total'] = $total_rs;
for($i=0; $i < $total_rs; $i++){
$list['list'][$i] = mysql_fetch_assoc($rs);
}
}else{
$list['total'] = 0;
}
return $list;
}
//투표합계가져오기
function getPollAnswerTotal($idx){
// 테이블 지정
$tbl = $GLOBALS["_conf_tbl"]["poll_contents"];
$sql = "SELECT sum(vote) ";
$sql .= "FROM $tbl WHERE p_idx='$idx' ";
//echo $sql;
$rs = mysql_query($sql, $GLOBALS[dblink]);
$row = mysql_fetch_row($rs);
return $row[0];
}
//투표 수정
function editPoll($idx){
$tbl = $GLOBALS["_conf_tbl"]["poll_info"];
$tbl_contents = $GLOBALS["_conf_tbl"]["poll_contents"];
$use_login = mysql_real_escape_string($_POST[use_login])=="Y"?"Y":"N";
$is_show = mysql_real_escape_string($_POST[is_show])=="Y"?"Y":"N";
//투표정보에 입력
$sql = "update ".$tbl." SET
subject= '".mysql_real_escape_string($_POST[subject])."',
use_login= '".$use_login."',
is_show= '".$is_show."',
sdate = '".mysql_real_escape_string($_POST[sdate])."',
edate = '".mysql_real_escape_string($_POST[edate])."'
WHERE idx='$idx'
";
$rs = mysql_query($sql,$GLOBALS[dblink]);
if($rs){
//투표항목에서 삭제
for($i=0;$i<count($_POST[del_answer]);$i++){
$sql = "DELETE FROM ".$tbl_contents."
WHERE idx='".$_POST[del_answer][$i]."'
";
mysql_query($sql,$GLOBALS[dblink]);
}
//투표항목에서 업데이트
foreach ($_POST[answer_list] as $key => $val){
$sql = "UPDATE ".$tbl_contents." SET
answer = '$val'
WHERE idx='$key'
";
mysql_query($sql,$GLOBALS[dblink]);
}
//투표항목에 입력
for($i=0;$i<count($_POST[answer]);$i++){
if(trim(mysql_real_escape_string($_POST[answer][$i]))!=""){
$sql = "insert into ".$tbl_contents." SET
p_idx= '".$idx."',
answer= '".mysql_real_escape_string($_POST[answer][$i])."'
";
mysql_query($sql,$GLOBALS[dblink]);
}
}
return true;
}else{
return false;
}
}
//투표 삭제
function deletePoll($idx){
$tbl = $GLOBALS["_conf_tbl"]["poll_info"];
$tbl_contents = $GLOBALS["_conf_tbl"]["poll_contents"];
$tbl_log = $GLOBALS["_conf_tbl"]["poll_log"];
$sql = "DELETE FROM ".$tbl_contents." WHERE p_idx = '$idx' ";
$rsf = mysql_query($sql,$GLOBALS[dblink]);
if($rsf){
$sql = "DELETE FROM ".$tbl." WHERE idx = '$idx' ";
$rsf = mysql_query($sql,$GLOBALS[dblink]);
$sql = "DELETE FROM ".$tbl_log." WHERE p_idx = '$idx' ";
$rsf = mysql_query($sql,$GLOBALS[dblink]);
return true;
}else{
return false;
}
}
function getMainPoll(){
// 테이블 지정
$tbl = $GLOBALS["_conf_tbl"]["poll_info"];
$sql = "SELECT * FROM $tbl WHERE is_show='Y' AND sdate <= now() AND concat(edate,' 23:59:59') >= now() order by idx desc ";
$rs = mysql_query($sql,$GLOBALS[dblink]);
$total = mysql_num_rows($rs);
$list['list']['total'] = $total;
for($i=0; $i < $total; $i++){
$list['list'][$i] = mysql_fetch_assoc($rs);
$list['answer'][$i] = getPollAnswerList($list['list'][$i][idx],"");
}
return $list;
}
//투표 참여
function insertVote($p_idx, $pc_idx){
$tbl = $GLOBALS["_conf_tbl"]["poll_info"];
$tbl_contents = $GLOBALS["_conf_tbl"]["poll_contents"];
$tbl_log = $GLOBALS["_conf_tbl"]["poll_log"];
$arrInfo = getArticleInfo($tbl, $p_idx);
//로그인여부 체크
if($arrInfo["list"][0][use_login]=="Y" && !$_SESSION[$GLOBALS["_SITE"]["DOMAIN"]]["MEMBER"]["ID"]){
jsMsg("로그인후 이용가능 합니다.");
jsHistory("-1") ;
exit;
}
//표시체크
if($arrInfo["list"][0][is_show]!="Y"){
jsMsg("참여가능한 투표이 아닙니다.");
jsHistory("-1") ;
exit;
}
//날짜체크
if($arrInfo["list"][0][sdate] > date("Y-m-d",mktime())){
jsMsg("아직 시작되지 않은 투표입니다.");
jsHistory("-1") ;
exit;
}
if($arrInfo["list"][0][edate] < date("Y-m-d",mktime())){
jsMsg("이미 종료된 투표입니다.");
jsHistory("-1") ;
exit;
}
//로그인을 해야하는 투표의 경우 이미 참여했는지 체크
if($arrInfo["list"][0][use_login]=="Y"){
$sql = "select * from $tbl_log WHERE p_idx='$p_idx' AND user_id='".$_SESSION[$GLOBALS["_SITE"]["DOMAIN"]]["MEMBER"]["ID"]."' ";
$rs = mysql_query($sql,$GLOBALS[dblink]);
$total = mysql_num_rows($rs);
if($total > 0){
jsMsg("이미 참여하신 투표입니다.");
jsHistory("-1") ;
exit;
}
}
//투표항목에 업데이트
$sql = "UPDATE ".$tbl_contents." SET
vote = vote +1 WHERE idx = '$pc_idx'
";
$rs = mysql_query($sql,$GLOBALS[dblink]);
if($rs){
//투표로그에 입력
$sql = "insert into ".$tbl_log." SET
p_idx= '".$p_idx."',
pc_idx= '".$pc_idx."',
user_id= '".$_SESSION[$GLOBALS["_SITE"]["DOMAIN"]]["MEMBER"]["ID"]."',
ip = '".$_SERVER[REMOTE_ADDR]."',
wdate = now()
";
$rs = mysql_query($sql,$GLOBALS[dblink]);
$total = mysql_affected_rows($GLOBALS[dblink]);
}
if($total > 0){
return true;
}else{
return false;
}
}
?>