e107_plugins/poll/admin_config.php
<?php
/*
* e107 website system
*
* Copyright (C) 2008-2013 e107 Inc (e107.org)
* Released under the terms and conditions of the
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
*
*/
require_once(__DIR__.'/../../class2.php');
if (!is_object($tp)) $tp = new e_parse;
if (!getperms("P") || !e107::isInstalled('poll'))
{
e107::redirect('admin');
exit;
}
$e_sub_cat = 'poll';
e107::includeLan(e_PLUGIN.'poll/languages/'.e_LANGUAGE.'_admin_poll.php');
require_once(e_ADMIN."auth.php");
require_once(e_PLUGIN."poll/poll_class.php");
require_once(e_HANDLER."userclass_class.php");
require_once(e_HANDLER."form_handler.php"); // FIXME using 'form' instead of 'e_form'
/*if(isset($_POST))
{
$_POST = strip_if_magic($_POST);
}*/
$rs = new form;
$poll = new poll;
$frm = e107::getForm();
$mes = e107::getMessage();
if (isset($_POST['reset']))
{
unset($poll_id, $_POST['poll_title'], $_POST['poll_option'], $_POST['activate'], $_POST['multipleChoice'], $_POST['showResults'], $_POST['startday'], $_POST['startmonth'], $_POST['startyear'], $_POST['endday'], $_POST['endmonth'], $_POST['endyear']);
define("RESET", TRUE);
}
if (varset($_POST['delete']))
{
$poll->delete_poll(key($_POST['delete'])); // TODO check security?
$mes->addSuccess(LAN_DELETED);
unset($poll_id, $_POST['poll_title'], $_POST['poll_option'], $_POST['activate']);
$_GET['mode']='list';
}
if (isset($_POST['submit']))
{
if($_POST['poll_title'])
{
define("POLLID", (int) $_POST['poll_id']);
$poll->submit_poll();
$mes->addSuccess(LAN_CREATED);
unset($_POST['poll_title'], $_POST['poll_option'], $_POST['activate'], $_POST['poll_comment']);
}
else
{
$mes->addError(LAN_REQUIRED_BLANK);
}
$_GET['mode']='list';
}
if (isset($_POST['preview']))
{
// Can't have everyone voting if tracking method is user ID
if (($_POST['pollUserclass'] == e_UC_PUBLIC) && ($_POST['storageMethod'] == 2)) $_POST['pollUserclass'] = e_UC_MEMBER;
$poll->render_poll($_POST, "preview");
}
if (varset($_POST['edit']) || varset($_GET['mode'])=='create' && !varset($_POST['submit']))
{
$_GET['mode']='create';
if($_POST['edit'])
{
edit_poll();
define("POLLACTION",'edit');
}
$poll_total = $sql->select("polls");
$text = $poll -> renderPollForm();
if (varset($_GET['mode'])=='create')
{
$ns->tablerender(LAN_PLUGIN_POLL_NAME.SEP.LAN_CREATE, $mes->render() . $text);
}
if (varset($_GET['mode'])=='edit')
{
$ns->tablerender(LAN_PLUGIN_POLL_NAME.SEP.LAN_EDIT, $mes->render() . $text);
}
}
if(!varset($_POST['edit']) && ($_GET['mode']=="list" || !$_GET['mode']))
{
poll_list();
}
require_once(e_ADMIN."footer.php");
function edit_poll()
{
$sql = e107::getDb();
$id = key($_POST['edit']);
if ($sql->select("polls", "*", "poll_id=".$id))
{
$_GET['mode'] = 'create';
$row = $sql->fetch();
extract($row); // FIXME
$tmpArray = explode(chr(1), $poll_options);
foreach($tmpArray as $option)
{
$_POST['poll_option'][] = $option;
}
$_POST['poll_id'] = $id;
$_POST['activate'] = $poll_active;
$_POST['option_count'] = count($_POST['poll_option']);
$_POST['poll_title'] = $poll_title;
$_POST['poll_comment'] = $poll_comment;
if ($poll_start_datestamp)
{
$tmp = getdate($poll_start_datestamp);
$_POST['startmonth'] = $tmp['mon'];
$_POST['startday'] = $tmp['mday'];
$_POST['startyear'] = $tmp['year'];
}
if ($poll_end_datestamp)
{
$tmp = getdate($poll_end_datestamp);
$_POST['endmonth'] = $tmp['mon'];
$_POST['endday'] = $tmp['mday'];
$_POST['endyear'] = $tmp['year'];
}
$_POST['multipleChoice'] = $poll_allow_multiple;
$_POST['showResults'] = $poll_result_type;
// Can't have everyone voting if tracking method is user ID
$_POST['pollUserclass'] = (($poll_vote_userclass == e_UC_PUBLIC) && $poll_storage_method == 2) ? e_UC_MEMBER : $poll_vote_userclass;
$_POST['storageMethod'] = $poll_storage_method;
}
}
function poll_list()
{
$sql = e107::getDb();
$ns = e107::getRender();
$tp = e107::getParser();
$frm = e107::getForm();
$mes = e107::getMessage();
// global $user_pref;
if(isset($_POST['etrigger_ecolumns'])) //TODO User
{
// $user_pref['admin_poll_columns'] = $_POST['e-columns'];
e107::getConfig('user')->setPref('admin_poll_columns',$_POST['e-columns'])->save(true,true,false);
}
$fieldpref = (varset($user_pref['admin_poll_columns'])) ? $user_pref['admin_poll_columns'] : array("poll_id","poll_title","poll_options","poll_vote_userclass"); ;
//TODO Add more column options.
$fields = array(
'poll_id' => array('title'=> LAN_ID, 'width'=>'5%', 'forced'=> TRUE),
'poll_title' => array('title'=> POLLAN_3, 'width'=>'auto'),
'poll_options' => array('title'=> POLLAN_4, 'type' => 'text', 'width' => 'auto', 'thclass' => 'left' ), // No real vetting
// 'poll_start_datestamp' => array('title'=> LAN_AUTHOR, 'type' => 'text', 'width' => 'auto', 'thclass' => 'left first'), // Display name
// 'poll_end_datestamp' => array('title'=> LAN_DATE, 'type' => 'text', 'width' => 'auto'), // User name
'poll_vote_userclass' => array('title'=> LAN_USERCLASS, 'type' => 'text', 'width' => 'auto'), // Photo
'options' => array('title'=> LAN_OPTIONS, 'forced'=>TRUE, 'width' => '10%', 'thclass' => 'center last')
);
$text = "
<form action='".e_SELF."' method='post' id='del_poll'>";
if ($poll_total = $sql->select("polls", "*"))
{
$text .= "<table class='table adminlist'>";
$text .= $frm->colGroup($fields,$fieldpref).
$frm->thead($fields,$fieldpref);
$text .= "<tbody>";
while ($row = $sql->fetch())
{
extract($row); // FIXME
$pollopts = explode(chr(1),$poll_options);
$pollopts = array_filter($pollopts);
$text .= "
<tr>
<td>$poll_id</td>";
$text .= (in_array("poll_title",$fieldpref)) ? "<td class='left'>".$tp->toHTML($poll_title, TRUE,"no_hook, emotes_off, defs")."</td>" : "";
$text .= (in_array("poll_options",$fieldpref)) ? "<td class='left'><ul><li>".implode("</li><li>",$pollopts)."</li></ul></td>" : "";
$text .= (in_array("poll_comment",$fieldpref)) ? "<td>".($poll_comment ? LAN_YES : LAN_NO)."</td>" : "";
$text .= (in_array("poll_vote_userclass",$fieldpref)) ? "<td>".(r_userclass_name($poll_vote_userclass))."</td>" : "";
$text .= "
<td class='center' style='white-space:nowrap'>
<button class='btn btn-default btn-secondary btn-large' type='submit' name='edit[{$poll_id}]' value='edit' alt='".LAN_EDIT."' title='".LAN_EDIT."' >".ADMIN_EDIT_ICON."</button>
<button class='btn btn-default btn-secondary btn-large action delete' type='submit' name='delete[$poll_id]' value='del' onclick=\"return jsconfirm(".$tp->toAttribute($tp->toJSON(LAN_CONFIRMDEL." [".$poll_id."]")).") \" title='".LAN_DELETE."' >".ADMIN_DELETE_ICON."</button>
</td>
</tr>";
}
$text .= "</tbody></table>";
}
else
{
$mes->addInfo(LAN_NO_RECORDS_FOUND);
}
$text .= "</form>";
$ns->tablerender(LAN_PLUGIN_POLL_NAME.SEP.LAN_MANAGE, $mes->render(). $text);
}
function admin_config_adminmenu()
{
$action = varset($_GET['mode']) ? $_GET['mode'] : "list";
$var['list']['text'] = LAN_MANAGE;
$var['list']['link'] = e_SELF;
$var['list']['perm'] = "P";
$var['create']['text'] = LAN_CREATE ;
$var['create']['link'] = e_SELF."?mode=create";
$var['create']['perm'] = "P";
/* $var['import']['text'] = GSLAN_23;
$var['import']['link'] = e_SELF."?import";
$var['import']['perm'] = "0";*/
//$icon = e107::getParser()->toIcon(e_PLUGIN.'poll/images/polls_32.png');
$caption = "<span>".LAN_PLUGIN_POLL_NAME."</span>";
show_admin_menu($caption, $action, $var);
}