1
0
mirror of https://github.com/e107inc/e107.git synced 2025-01-17 20:58:30 +01:00
php-e107/e107_plugins/poll/poll_class.php

610 lines
20 KiB
PHP
Raw Normal View History

2006-12-02 04:36:16 +00:00
<?php
/*
+ ----------------------------------------------------------------------------+
| e107 website system
|
| <EFBFBD>Steve Dunstan 2001-2002
| http://e107.org
| jalist@e107.org
|
| Released under the terms and conditions of the
| GNU General Public License (http://gnu.org).
|
| $Source: /cvs_backup/e107_0.8/e107_plugins/poll/poll_class.php,v $
| $Revision: 1.8 $
| $Date: 2008-06-03 21:31:31 $
| $Author: e107steved $
2006-12-02 04:36:16 +00:00
+----------------------------------------------------------------------------+
*/
if (!defined('e107_INIT')) { exit; }
@include_once(e_PLUGIN."poll/languages/".e_LANGUAGE.".php");
@include_once(e_PLUGIN."poll/languages/English.php");
define("POLLCLASS", TRUE);
define("POLL_MODE_COOKIE", 0);
define("POLL_MODE_IP", 1);
define("POLL_MODE_USERID", 2);
class poll
{
var $pollRow;
var $pollmode;
function delete_poll($existing)
{
global $sql;
if ($sql -> db_Delete("polls", " poll_id='".intval($existing)."' "))
{
if(function_exists("admin_purge_related"))
{
admin_purge_related("poll", $existing);
}
return "Poll deleted.";
}
}
function submit_poll($mode=1)
{
/*
$mode = 1 :: poll is main poll
$mode = 2 :: poll is forum poll
*/
global $tp, $sql;
extract($_POST);
$poll_title = $tp->toDB($poll_title);
$active_start = (!$_POST['startmonth'] || !$_POST['startday'] || !$_POST['startyear'] ? 0 : mktime (0, 0, 0, $_POST['startmonth'], $_POST['startday'], $_POST['startyear']));
$active_end = (!$_POST['endmonth'] || !$_POST['endday'] || !$_POST['endyear'] ? 0 : mktime (0, 0, 0, $_POST['endmonth'], $_POST['endday'], $_POST['endyear']));
$poll_options = "";
foreach($poll_option as $key => $value)
{
$poll_options .= $tp->toDB($poll_option[$key]).chr(1);
}
if(POLLACTION == "edit")
{
$sql -> db_Update("polls", "poll_title='$poll_title', poll_options='$poll_options', poll_type=$mode, poll_comment='".$tp -> toDB($poll_comment)."', poll_allow_multiple=".intval($multipleChoice).", poll_result_type=".intval($showResults).", poll_vote_userclass=".intval($pollUserclass).", poll_storage_method=".intval($storageMethod)." WHERE poll_id=".intval(POLLID));
/* update poll results - bugtracker #1124 .... */
$sql -> db_Select("polls", "poll_votes", "poll_id='".intval(POLLID)."' ");
$foo = $sql -> db_Fetch();
$voteA = explode(chr(1), $foo['poll_votes']);
$opt = count($poll_option) - count($voteA);
if($opt)
{
for($a=0; $a<=$opt; $a++)
{
$foo['poll_votes'] .= "0".chr(1);
}
$sql -> db_Update("polls", "poll_votes='".$foo['poll_votes']."' WHERE poll_id='".intval(POLLID)."' ");
}
$message = POLLAN_45;
} else {
$votes = "";
for($a=1; $a<=count($_POST['poll_option']); $a++)
{
$votes .= "0".chr(1);
}
if($mode == 1)
{
/* deactivate other polls */
if($sql -> db_Select("polls", "*", "poll_type=1 AND poll_vote_userclass!=255"))
{
$deacArray = $sql -> db_getList();
foreach($deacArray as $deacpoll)
{
$sql -> db_Update("polls", "poll_end_datestamp='".time()."', poll_vote_userclass='255' WHERE poll_id=".$deacpoll['poll_id']);
}
}
$sql -> db_Insert("polls", "'0', ".time().", ".intval($active_start).", ".intval($active_end).", ".ADMINID.", '$poll_title', '$poll_options', '$votes', '', '1', '".$tp -> toDB($poll_comment)."', '".intval($multipleChoice)."', '".intval($showResults)."', '".intval($pollUserclass)."', '".intval($storageMethod)."'");
}
else
{
$sql -> db_Insert("polls", "'0', ".intval($_POST['iid']).", '0', '0', ".USERID.", '$poll_title', '$poll_options', '$votes', '', '2', '0', '".intval($multipleChoice)."', '0', '0', '".intval($storageMethod)."'");
}
}
return $message;
}
function get_poll($query)
{
global $sql, $e107;
if ($sql->db_Select_gen($query))
{
$pollArray = $sql -> db_Fetch();
if (!check_class($pollArray['poll_vote_userclass']))
{
$POLLMODE = "disallowed";
}
else
{
switch($pollArray['poll_storage_method'])
{
case POLL_MODE_COOKIE:
$userid = "";
$cookiename = "poll_".$pollArray['poll_id'];
if(isset($_COOKIE[$cookiename]))
{
$POLLMODE = "voted";
}
else
{
$POLLMODE = "notvoted";
}
break;
case POLL_MODE_IP:
$userid = $e107->getip();
$voted_ids = explode("^", substr($pollArray['poll_ip'], 0, -1));
if (in_array($userid, $voted_ids))
{
$POLLMODE = "voted";
}
else
{
$POLLMODE = "notvoted";
}
break;
case POLL_MODE_USERID:
if(!USER)
{
$POLLMODE = "disallowed";
}
else
{
$userid = USERID;
$voted_ids = explode("^", substr($pollArray['poll_ip'], 0, -1));
if (in_array($userid, $voted_ids))
{
$POLLMODE = "voted";
}
else
{
$POLLMODE = "notvoted";
}
}
break;
}
}
}
if(isset($_POST['pollvote']) && $POLLMODE == "notvoted" && ($POLLMODE != "disallowed"))
{
if ($_POST['votea'])
{
// $sql -> db_Select("polls", "*", "poll_vote_userclass!=255 AND poll_type=1 ORDER BY poll_datestamp DESC LIMIT 0,1");
$row = $pollArray;
extract($row);
$votes = explode(chr(1), $poll_votes);
if(is_array($_POST['votea']))
{
/* multiple choice vote */
foreach($_POST['votea'] as $vote)
{
$vote = intval($vote);
$votes[($vote-1)] ++;
}
}
else
{
$votes[($_POST['votea']-1)] ++;
}
$optionArray = explode(chr(1), $pollArray['poll_options']);
$optionArray = array_slice($optionArray, 0, -1);
foreach($optionArray as $k=>$v)
{
if(!$votes[$k])
{
$votes[$k] = 0;
}
}
$votep = implode(chr(1), $votes);
$pollArray['poll_votes'] = $votep;
$sql->db_Update("polls", "poll_votes = '$votep', poll_ip='".$poll_ip.$userid."^' WHERE poll_id=".$poll_id);
echo "
<script type='text/javascript'>
<!--
setcook({$poll_id});
//-->
</script>
";
$POLLMODE = "voted";
}
}
$this->pollRow = $pollArray;
$this->pollmode = $POLLMODE;
}
function render_poll($pollArray = "", $type = "menu", $POLLMODE = "", $returnMethod=FALSE)
{
global $POLLSTYLE, $sql, $tp, $ns;
switch ($POLLMODE)
2006-12-02 04:36:16 +00:00
{
case "query" : // Show poll, register any vote
2006-12-02 04:36:16 +00:00
$this->get_poll($pollArray);
$pollArray = $this->pollRow;
$POLLMODE = $this->pollmode;
break;
case 'results' :
if ($sql->db_Select_gen($pollArray))
{
$pollArray = $sql -> db_Fetch();
}
break;
2006-12-02 04:36:16 +00:00
}
$barl = (file_exists(THEME."images/barl.png") ? THEME_ABS."images/barl.png" : e_PLUGIN."poll/images/barl.png");
$barr = (file_exists(THEME."images/barr.png") ? THEME_ABS."images/barr.png" : e_PLUGIN."poll/images/barr.png");
$bar = (file_exists(THEME."images/bar.png") ? THEME_ABS."images/bar.png" : e_PLUGIN."poll/images/bar.png");
2006-12-02 04:36:16 +00:00
if($type == "preview")
{
/* load lan file */
@include_once(e_PLUGIN."poll/languages/".e_LANGUAGE.".php");
@include_once(e_PLUGIN."poll/languages/English.php");
$optionArray = $pollArray['poll_option'];
$voteArray = array();
$voteArray = array_pad($voteArray, count($optionArray), 0);
$pollArray['poll_allow_multiple'] = $pollArray['multipleChoice'];
}
else if($type == "forum")
{
@include_once(e_PLUGIN."poll/languages/".e_LANGUAGE.".php");
@include_once(e_PLUGIN."poll/languages/English.php");
if(isset($_POST['fpreview']))
{
$pollArray['poll_allow_multiple'] = $pollArray['multipleChoice'];
$optionArray = $pollArray['poll_option'];
}
else
{
$optionArray = explode(chr(1), $pollArray['poll_options']);
$optionArray = array_slice($optionArray, 0, -1);
}
$voteArray = explode(chr(1), $pollArray['poll_votes']);
// $voteArray = array_slice($voteArray, 0, -1);
}
else
{ // Get existing results
2006-12-02 04:36:16 +00:00
$optionArray = explode(chr(1), $pollArray['poll_options']);
$optionArray = array_slice($optionArray, 0, -1);
$voteArray = explode(chr(1), $pollArray['poll_votes']);
// $voteArray = array_slice($voteArray, 0, -1);
}
$voteTotal = array_sum($voteArray);
$percentage = array();
if(count($voteArray))
{
2007-08-08 19:34:52 +00:00
foreach($voteArray as $votes)
{
if ($voteTotal > 0)
{
$percentage[] = round(($votes/$voteTotal) * 100, 2);
}
else
{
$percentage[] = 0;
2006-12-02 04:36:16 +00:00
}
2007-08-08 19:34:52 +00:00
}
2006-12-02 04:36:16 +00:00
}
/* get template */
if (file_exists(THEME."poll_template.php"))
{
require(THEME."poll_template.php");
}
else if(!isset($POLL_NOTVOTED_START))
{
require(e_PLUGIN."poll/templates/poll_template.php");
}
$preview = FALSE;
if ($type == "preview")
{
$POLLMODE = "notvoted";
}
elseif($type == "forum")
{
2006-12-02 04:36:16 +00:00
$preview = TRUE;
}
$comment_total = $sql->db_Select("comments", "*", "comment_item_id='".intval($pollArray['poll_id'])."' AND comment_type=4");
$QUESTION = $tp -> toHTML($pollArray['poll_title'], TRUE,"emotes_off, defs");
2006-12-02 04:36:16 +00:00
$VOTE_TOTAL = POLLAN_31.": ".$voteTotal;
$COMMENTS = ($pollArray['poll_comment'] ? " <a href='".e_BASE."comment.php?comment.poll.".$pollArray['poll_id']."'>".POLLAN_27.": ".$comment_total."</a>" : "");
$OLDPOLLS = ($type == "menu" ? "<a href='".e_PLUGIN."poll/oldpolls.php'>".POLLAN_28."</a>" : "");
$AUTHOR = POLLAN_35." ".($type == "preview" || $type == "forum" ? USERNAME : "<a href='".e_BASE."user.php?id.".$pollArray['poll_admin_id']."'>".$pollArray['user_name']."</a>");
switch ($POLLMODE)
{
case "notvoted":
$text = "<form method='post' action='".e_SELF.(e_QUERY ? "?".e_QUERY : "")."'>\n".preg_replace("/\{(.*?)\}/e", '$\1', ($type == "forum" ? $POLL_FORUM_NOTVOTED_START : $POLL_NOTVOTED_START));
$count = 1;
$alt = 0; // alternate style.
foreach($optionArray as $option)
{
2006-12-02 04:36:16 +00:00
// $MODE = ($mode) ? $mode : ""; /* debug */
$OPTIONBUTTON = ($pollArray['poll_allow_multiple'] ? "<input type='checkbox' name='votea[]' value='$count' />" : "<input type='radio' name='votea' value='$count' />");
$OPTION = $tp->toHTML($option, TRUE);
if(isset($POLL_NOTVOTED_LOOP_ALT) && $POLL_NOTVOTED_LOOP_ALT && $type != "forum")
{ // alternating style
2006-12-02 04:36:16 +00:00
$text .= preg_replace("/\{(.*?)\}/e", '$\1', ($alt == 0 ? $POLL_NOTVOTED_LOOP : $POLL_NOTVOTED_LOOP_ALT));
$alt = ($alt ==0) ? 1 : 0;
}
else
{
2006-12-02 04:36:16 +00:00
$text .= preg_replace("/\{(.*?)\}/e", '$\1', ($type == "forum" ? $POLL_FORUM_NOTVOTED_LOOP : $POLL_NOTVOTED_LOOP));
}
$count ++;
}
$SUBMITBUTTON = "<input class='button' type='submit' name='pollvote' value='".POLLAN_30."' />";
if(('preview' == $type || $preview == TRUE) && strpos(e_SELF, "viewtopic") === FALSE)
{
$SUBMITBUTTON = "[".POLLAN_30."]";
}
$text .= "\n".preg_replace("/\{(.*?)\}/e", '$\1', ($type == "forum" ? $POLL_FORUM_NOTVOTED_END : $POLL_NOTVOTED_END))."\n</form>";
break;
case "voted":
case 'results' :
2006-12-02 04:36:16 +00:00
if($pollArray['poll_result_type'] && !strstr(e_SELF, "comment.php"))
{
$text = "<div style='text-align: center;'><br /><br />".POLLAN_39."<br /><br /><a href='".e_BASE."comment.php?comment.poll.".$pollArray['poll_id']."'>".POLLAN_40."</a></div><br /><br />";
}
else
{
$text = preg_replace("/\{(.*?)\}/e", '$\1', ($type == "forum" ? $POLL_FORUM_VOTED_START : $POLL_VOTED_START));
$count = 0;
foreach($optionArray as $option)
{
$OPTION = $tp->toHTML($option, TRUE);
$BAR = ($percentage[$count] ? "<div style='width: 100%'><div style='background-image: url($barl); width: 5px; height: 14px; float: left;'></div><div style='background-image: url($bar); width: ".(floor($percentage[$count]) != 100 ? floor($percentage[$count]) : 90)."%; height: 14px; float: left;'></div><div style='background-image: url($barr); width: 5px; height: 14px; float: left;'></div></div>" : "");
$PERCENTAGE = $percentage[$count]."%";
$VOTES = POLLAN_31.": ".$voteArray[$count];
$text .= preg_replace("/\{(.*?)\}/e", '$\1', ($type == "forum" ? $POLL_FORUM_VOTED_LOOP : $POLL_VOTED_LOOP));
$count ++;
}
}
$text .= preg_replace("/\{(.*?)\}/e", '$\1', ($type == "forum" ? $POLL_FORUM_VOTED_END : $POLL_VOTED_END));
break;
case "disallowed":
$text = preg_replace("/\{(.*?)\}/e", '$\1', $POLL_DISALLOWED_START);
foreach($optionArray as $option)
{
$MODE = $mode; /* debug */
$OPTION = $tp->toHTML($option, TRUE);
$text .= preg_replace("/\{(.*?)\}/e", '$\1', $POLL_DISALLOWED_LOOP);
$count ++;
}
if($pollArray['poll_vote_userclass'] == 253)
{
$DISALLOWMESSAGE = POLLAN_41;
}
elseif($pollArray['poll_vote_userclass'] == 254)
2006-12-02 04:36:16 +00:00
{
$DISALLOWMESSAGE = POLLAN_42;
}
else
{
$DISALLOWMESSAGE = POLLAN_43;
}
$text .= preg_replace("/\{(.*?)\}/e", '$\1', $POLL_DISALLOWED_END);
break;
}
if(!defined("POLLRENDERED")) define("POLLRENDERED", TRUE);
$caption = (file_exists(THEME."images/poll_menu.png") ? "<img src='".THEME_ABS."images/poll_menu.png' alt='' /> ".POLLAN_MENU_CAPTION : POLLAN_MENU_CAPTION);
2006-12-02 04:36:16 +00:00
if($type == "preview")
{
$caption = POLLAN_23;
$text = "<div style='text-align:center; margin-left: auto; margin-right: auto;'>\n<table style='width:350px' class='fborder'>\n<tr>\n<td>\n$text\n</td></tr></table></div>";
}
else if($type == "forum")
{
$caption = LAN_4;
}
if($returnMethod)
{
return $text;
}
else
{
$ns->tablerender($caption, $text, 'poll');
}
}
function renderPollForm($mode="admin")
{
/*
$mode = "admin" :: called from admin_config.php
$mode = "forum" :: called from forum_post.php
*/
global $tp;
if($mode == "forum")
{
$text = "<tr>
<td colspan='2' class='nforumcaption2'>".LAN_4."</td>
</tr>
<tr>
<td colspan='2' class='forumheader3'>
<span class='smalltext'>".LAN_386."</span>
</td>
</tr>
<tr><td style='width:20%' class='forumheader3'><div class='normaltext'>".LAN_5."</div></td><td style='width:80%'class='forumheader3'><input class='tbox' type='text' name='poll_title' size='70' value='".$tp->post_toForm($_POST['poll_title'])."' maxlength='200' /></td></tr>";
$option_count = (count($_POST['poll_option']) ? count($_POST['poll_option']) : 1);
$text .= "<tr>
<td style='width:20%' class='forumheader3'>".LAN_391."</td>
<td style='width:80%' class='forumheader3'>
<div id='pollsection'>";
for($count = 1; $count <= $option_count; $count++)
{
if($count != 1 && $_POST['poll_option'][($count-1)] =="")
{
break;
}
$opt = ($count==1) ? "id='pollopt'" : "";
$text .="<span $opt><input class='tbox' type='text' name='poll_option[]' size='40' value=\"".$_POST['poll_option'][($count-1)]."\" maxlength='200' />";
$text .= "</span><br />";
}
$text .="</div><input class='button' type='button' name='addoption' value='".LAN_6."' onclick=\"duplicateHTML('pollopt','pollsection')\" /><br />
</td></tr>
<tr>
<td style='width:20%' class='forumheader3'>".POLL_506."</td>
<td style='width:80%' class='forumheader3'>
<input type='radio' name='multipleChoice' value='1'".($_POST['multipleChoice'] ? " checked='checked'" : "")." /> ".POLL_507."&nbsp;&nbsp;
<input type='radio' name='multipleChoice' value='0'".(!$_POST['multipleChoice'] ? " checked='checked'" : "")." /> ".POLL_508."
</td>
</tr>
<tr>
<td style='width:30%' class='forumheader3'>".POLLAN_16."</td>
<td class='forumheader3'>
<input type='radio' name='storageMethod' value='0'".(!$_POST['storageMethod'] ? " checked='checked'" : "")." /> ".POLLAN_17."<br />
<input type='radio' name='storageMethod' value='1'".($_POST['storageMethod'] == 1 ? " checked='checked'" : "")." /> ".POLLAN_18."<br />
<input type='radio' name='storageMethod' value='2'".($_POST['storageMethod'] ==2 ? " checked='checked'" : "")." /> ".POLLAN_19."
</tr>
";
return $text;
}
$formgo = e_SELF.(e_QUERY && !defined("RESET") && strpos(e_QUERY, 'delete') === FALSE ? "?".e_QUERY : "");
$text = "<div style='text-align:center'>
<form method='post' action='$formgo'>
<table style='".ADMIN_WIDTH."' class='fborder'>
<tr>
<td style='width:30%' class='forumheader3'><div class='normaltext'>".POLLAN_3.":</div></td>
<td style='width:70%'class='forumheader3'>
<input class='tbox' type='text' name='poll_title' size='70' value='".$tp -> post_toForm($_POST['poll_title'])."' maxlength='200' />";
$option_count = (count($_POST['poll_option']) ? count($_POST['poll_option']) : 1);
$text .= "<tr>
<td style='width:30%;vertical-align:top' class='forumheader3'>".LAN_OPTIONS." :</td>
<td style='width:70%' class='forumheader3'>
<div id='pollsection'>";
for($count = 1; $count <= $option_count; $count++)
{
if($count != 1 && $_POST['poll_option'][($count-1)] =="")
{
break;
}
$opt = ($count==1) ? "id='pollopt'" : "";
$text .="<span $opt><input class='tbox' type='text' name='poll_option[]' size='40' value=\"".$tp -> post_toForm($_POST['poll_option'][($count-1)])."\" maxlength='200' />";
$text .= "</span><br />";
}
$text .="</div><input class='button' type='button' name='addoption' value='".POLLAN_8."' onclick=\"duplicateHTML('pollopt','pollsection')\" /><br />
</td></tr>
<tr>
<td style='width:30%' class='forumheader3'>".POLLAN_9."</td>
<td style='width:70%' class='forumheader3'>
<input type='radio' name='multipleChoice' value='1'".($_POST['multipleChoice'] ? " checked='checked'" : "")." /> ".POLLAN_10."&nbsp;&nbsp;
<input type='radio' name='multipleChoice' value='0'".(!$_POST['multipleChoice'] ? " checked='checked'" : "")." /> ".POLLAN_11."
</td>
</tr>
<tr>
<td style='width:30%' class='forumheader3'>".POLLAN_12."</td>
<td style='width:70%' class='forumheader3'>
<input type='radio' name='showResults' value='0'".(!$_POST['showResults'] ? " checked='checked'" : "")." /> ".POLLAN_13."<br />
<input type='radio' name='showResults' value='1'".($_POST['showResults'] ? " checked='checked'" : "")." /> ".POLLAN_14."
</td>
</tr>
<tr>
<td style='width:30%' class='forumheader3'>".POLLAN_15."</td>
<td class='forumheader3'>".r_userclass("pollUserclass", $_POST['pollUserclass'], 'off', "public,member,admin,classes,matchclass")."</td>
2006-12-02 04:36:16 +00:00
</tr>
<tr>
<td style='width:30%' class='forumheader3'>".POLLAN_16."</td>
<td class='forumheader3'>
<input type='radio' name='storageMethod' value='0'".(!$_POST['storageMethod'] ? " checked='checked'" : "")." /> ".POLLAN_17."<br />
<input type='radio' name='storageMethod' value='1'".($_POST['storageMethod'] ==1 ? " checked='checked'" : "")." /> ".POLLAN_18."<br />
2006-12-02 04:36:16 +00:00
<input type='radio' name='storageMethod' value='2'".($_POST['storageMethod'] ==2 ? " checked='checked'" : "")." /> ".POLLAN_19."
</tr>
<tr>
<td class='forumheader3'>".POLLAN_20.": </td><td class='forumheader3'>
<input type='radio' name='poll_comment' value='1'".($_POST['poll_comment'] ? " checked='checked'" : "")." /> ".POLLAN_10."
<input type='radio' name='poll_comment' value='0'".(!$_POST['poll_comment'] ? " checked='checked'" : "")." /> ".POLLAN_11."
</td>
</tr>
<tr style='vertical-align:top'>
<td colspan='2' style='text-align:center' class='forumheader'>";
if (isset($_POST['preview'])) {
$text .= "<input class='button' type='submit' name='preview' value='".POLLAN_21."' /> ";
if (POLLACTION == "edit") {
$text .= "<input class='button' type='submit' name='submit' value='".POLLAN_22."' /> ";
} else {
$text .= "<input class='button' type='submit' name='submit' value='".POLLAN_23."' /> ";
}
} else {
$text .= "<input class='button' type='submit' name='preview' value='".POLLAN_24."' /> ";
}
if (POLLID) {
$text .= "<input class='button' type='submit' name='reset' value='".POLLAN_25."' /> ";
}
$text .= "</td></tr></table>
</form>
</div>";
return $text;
}
}
echo '<script type="text/javascript">
<!--
function setcook(pollid){
var name = "poll_"+pollid;
var date = new Date();
var value = pollid;
date.setTime(date.getTime()+(365*24*60*60*1000));
var expires = "; expires="+date.toGMTString();
document.cookie = name+"="+value+expires+"; path=/";
}
//-->
</script>
';
?>