mirror of
https://github.com/e107inc/e107.git
synced 2025-02-07 07:47:59 +01:00
2903 lines
83 KiB
PHP
2903 lines
83 KiB
PHP
<?php
|
|
/*
|
|
* e107 website system
|
|
*
|
|
* Copyright (C) 2008-2014 e107 Inc (e107.org)
|
|
* Released under the terms and conditions of the
|
|
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
|
*
|
|
*/
|
|
|
|
$eplug_admin = true;
|
|
require_once('../../class2.php');
|
|
if (!getperms('P'))
|
|
{
|
|
e107::redirect('admin');
|
|
exit;
|
|
}
|
|
|
|
|
|
e107::lan('forum', 'admin',true);
|
|
e107::lan('forum','front', true);
|
|
//e107::includeLan(e_PLUGIN.'forum/languages/'.e_LANGUAGE.'/English_admin.php');
|
|
//e107::lan('forum','', 'front');
|
|
|
|
|
|
e107::css('inline',"
|
|
|
|
img.level-1 { margin:0 5px 0 25px; }
|
|
img.level-2 { margin:0 5px 0 50px; }
|
|
|
|
");
|
|
|
|
$legacy = false;
|
|
|
|
if(E107_DEBUG_LEVEL > 0 && $legacy == true)
|
|
{
|
|
define('OLD_FORUMADMIN', true);
|
|
//e107::getMessage()->addwarning("Experimental code now active. Using this page in debug mode active could break your forum configuration.");
|
|
}
|
|
|
|
// Generated e107 Plugin Admin Area
|
|
|
|
if(!deftrue('OLD_FORUMADMIN'))
|
|
{
|
|
|
|
class forum_admin extends e_admin_dispatcher
|
|
{
|
|
|
|
protected $modes = array(
|
|
|
|
'main' => array(
|
|
'controller' => 'forum_ui',
|
|
'path' => null,
|
|
'ui' => 'forum_form_ui',
|
|
'uipath' => null
|
|
),
|
|
'mods' => array(
|
|
'controller' => 'forum_ui',
|
|
'path' => null,
|
|
'ui' => 'forum_form_ui',
|
|
'uipath' => null
|
|
),
|
|
'report' => array(
|
|
'controller' => 'reported_ui',
|
|
'path' => null,
|
|
'ui' => 'reported_form_ui',
|
|
'uipath' => null
|
|
),
|
|
'post' => array(
|
|
'controller' => 'post_ui',
|
|
'path' => null,
|
|
'ui' => 'post_form_ui',
|
|
'uipath' => null
|
|
),
|
|
|
|
);
|
|
|
|
|
|
protected $adminMenu = array(
|
|
|
|
'main/list' => array('caption'=> LAN_MANAGE, 'perm' => 'P'),
|
|
'main/create' => array('caption'=> LAN_CREATE, 'perm' => 'P'),
|
|
'main/opt1' => array('divider'=>true),
|
|
|
|
|
|
'main/rules' => array('caption'=> WMGLAN_5, 'perm' => 'P'),
|
|
'mods/list' => array('caption'=> LAN_FORUM_2003, 'perm'=>'P'),
|
|
'main/prefs' => array('caption'=> LAN_PREFS, 'perm' => 'P'),
|
|
'main/opt2' => array('divider'=>true),
|
|
'report/list' => array('caption'=> FORLAN_116, 'perm'=>'P'),
|
|
'post/list' => array('caption'=>LAN_PLUGIN_FORUM_LATESTPOSTS, 'perm'=>'P'),
|
|
'main/prune' => array('caption'=> LAN_PRUNE, 'perm' => 'P'),
|
|
'main/tools' => array('caption'=>FORLAN_153, 'perm'=>'p')
|
|
|
|
);
|
|
|
|
protected $adminMenuAliases = array(
|
|
'main/edit' => 'main/list'
|
|
);
|
|
|
|
protected $menuTitle = LAN_PLUGIN_FORUM_NAME;
|
|
|
|
|
|
function init()
|
|
{
|
|
if(E107_DEBUG_LEVEL > 0)
|
|
{
|
|
$this->adminMenu['opt3'] = array('divider'=>true);
|
|
$this->adminMenu['main/update'] = array('caption'=>"Redo v1.x Forum Upgrade", 'perm'=>0, 'uri'=>'{e_PLUGIN}forum/forum_update.php');
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
class forum_ui extends e_admin_ui
|
|
{
|
|
|
|
protected $pluginTitle = LAN_PLUGIN_FORUM_NAME;
|
|
protected $pluginName = 'forum';
|
|
// protected $eventName = 'forum-forum'; // remove comment to enable event triggers in admin.
|
|
protected $table = 'forum';
|
|
protected $pid = 'forum_id';
|
|
protected $perPage = 30;
|
|
protected $batchDelete = true;
|
|
// protected $batchCopy = true;
|
|
protected $sortField = 'forum_order';
|
|
protected $sortParent = 'forum_parent';
|
|
protected $orderStep = 50;
|
|
|
|
/*
|
|
// protected $tabs = array('Tabl 1','Tab 2'); // Use 'tab'=>0 OR 'tab'=>1 in the $fields below to enable.
|
|
// protected $listQry = "SELECT *, xAND forum_order > 45 THEN forum_order ELSE forum_order + forum_parent END AS Sort FROM `#forum` "; // Example Custom Query. LEFT JOINS allowed. Should be without any Order or Limit.
|
|
// protected $listQry = "SELECT *, CASE WHEN forum_parent = 0 OR forum_order =0 THEN forum_id + (forum_order/1000) ELSE forum_parent + (forum_order/1000) END AS Sort FROM `#forum` "; // Example Custom Query. LEFT JOINS allowed. Should be without any Order or Limit.
|
|
// protected $listOrder = ' COALESCE(NULLIF(forum_parent,0), forum_order), forum_parent > 0, forum_order '; //FIXME works with parent/child but doesn't respect parent order.
|
|
// protected $listQry = "SELECT * , forum_parent + forum_order AS Sort FROM `#forum` ";
|
|
*/
|
|
|
|
protected $listQry = "SELECT a. *, CASE WHEN a.forum_parent = 0 THEN a.forum_order ELSE b.forum_order + (( a.forum_order)/1000) END AS Sort FROM `#forum` AS a LEFT JOIN `#forum` AS b ON a.forum_parent = b.forum_id ";
|
|
protected $listOrder = 'Sort,forum_order ';
|
|
// protected $listOrder = 'forum_order';
|
|
// protected $listOrder = ' COALESCE(NULLIF(forum_parent,0), forum_id), forum_parent > 0, forum_order ';
|
|
|
|
protected $fields = array (
|
|
'checkboxes' => array ( 'title' => '', 'type' => null, 'data' => null, 'width' => '5%', 'thclass' => 'center', 'forced' => '1', 'class' => 'center', 'toggle' => 'e-multiselect', ),
|
|
'forum_id' => array ( 'title' => LAN_ID, 'data' => 'int', 'width' => '5%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'forum_name' => array ( 'title' => LAN_TITLE, 'type' => 'method', 'inline'=>true, 'data' => 'str', 'width' => '40%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'forum_sef' => array ( 'title' => LAN_SEFURL, 'type' => 'text', 'inline'=>true, 'noedit'=>false, 'data' => 'str', 'width' => 'auto', 'help' => 'Leave blank to auto-generate it from the title above.', 'readParms' => '', 'writeParms' => 'size=xxlarge', 'class' => 'left', 'thclass' => 'left', ),
|
|
'forum_description' => array ( 'title' => LAN_DESCRIPTION, 'type' => 'textarea', 'data' => 'str', 'width' => '30%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'forum_parent' => array ( 'title' => FORLAN_75, 'type' => 'dropdown', 'data' => 'int', 'width' => '10%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'forum_sub' => array ( 'title' => LAN_FORUM_1002, 'type' => 'dropdown', 'data' => 'int', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'forum_moderators' => array ( 'title' => LAN_FORUM_2003, 'type' => 'userclass', 'inline'=>true, 'data' => 'int', 'width' => 'auto', 'help' => '', 'readParms' => 'classlist=admin,main,classes', 'writeParms' => "classlist=admin,main,mods,classes", 'class' => 'left', 'thclass' => 'left', ),
|
|
'forum_threads' => array ( 'title' => LAN_FORUM_1003, 'type' => 'number', 'data' => 'int', 'noedit'=>true, 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'forum_replies' => array ( 'title' => LAN_FORUM_0003, 'type' => 'number', 'data' => 'int', 'noedit'=>true, 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'forum_lastpost_user' => array ( 'title' => LAN_AUTHOR, 'type' => 'hidden', 'noedit'=>true, 'data' => 'int', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'forum_lastpost_user_anon' => array ( 'title' => FORLAN_204, 'type' => 'hidden','noedit'=>true, 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'forum_lastpost_info' => array ( 'title' => LAN_PLUGIN_FORUM_LATESTPOSTS, 'type' => 'hidden', 'noedit'=>true, 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'forum_class' => array ( 'title' => LAN_VISIBILITY, 'type' => 'userclass', 'data' => 'int', 'width' => 'auto', 'batch' => true, 'filter' => true, 'inline' => true, 'help' => '', 'readParms' => array('classlist'=>'public,guest,nobody,member,admin,main,new,mods,classes'), 'writeParms' => array('classlist'=>'public,guest,nobody,member,admin,main,new,mods,classes'), 'class' => 'left', 'thclass' => 'left', ),
|
|
'forum_order' => array ( 'title' => LAN_ORDER, 'type' => 'text', 'data' => 'int', 'inline'=>true, 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'forum_postclass' => array ( 'title' => FORLAN_205, 'type' => 'userclass', 'inline'=>true,'filter'=>true, 'batch'=>true, 'data' => 'int', 'width' => 'auto', 'help' => '', 'readParms' => array('classlist'=>'public,guest,nobody,member,admin,main,new,mods,classes'), 'writeParms' => array('classlist'=>'public,guest,nobody,member,admin,main,new,mods,classes'), 'class' => 'center', 'thclass' => 'center', ),
|
|
'forum_threadclass' => array ( 'title' => FORLAN_206, 'type' => 'userclass', 'inline'=>true, 'filter'=>true, 'batch'=>true, 'data' => 'int', 'width' => 'auto', 'help' => '', 'readParms' => array('classlist'=>'public,guest,nobody,member,admin,main,new,mods,classes'), 'writeParms' => array('classlist'=>'public,guest,nobody,member,admin,main,new,mods,classes'), 'class' => 'center', 'thclass' => 'center', ),
|
|
'forum_datestamp' => array ( 'title' => LAN_DATESTAMP, 'type' => 'datestamp', 'data' => 'int', 'noedit'=>true, 'width' => 'auto', 'filter' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'right', 'thclass' => 'center', ),
|
|
// 'Sort' => array ( 'title' => 'Sort', 'type' => 'text', 'data' => 'str', 'noedit'=>true, 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'forum_options' => array ( 'title' => LAN_OPTIONS, 'type' => 'hidden', 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'options' => array ( 'title' => LAN_OPTIONS, 'type' => null, 'data' => null, 'width' => '10%', 'thclass' => 'center last', 'class' => 'center last', 'forced' => '1', 'sort'=>1 ),
|
|
);
|
|
|
|
protected $fieldpref = array('forum_name', 'forum_parent', 'Sort', 'forum_description', 'forum_class', 'forum_postclass', 'forum_threadclass', 'forum_order');
|
|
|
|
protected $preftabs = array();
|
|
|
|
|
|
protected $prefs = array(
|
|
'enclose' => array('title'=> FORLAN_44, 'type'=>'boolean', 'data' => 'int','help'=>FORLAN_45),
|
|
'title' => array('title'=> FORLAN_65, 'type'=>'text', 'data' => 'str','help'=>''),
|
|
'notify' => array('title'=> FORLAN_47, 'type'=>'boolean', 'data' => 'int','help'=>FORLAN_48),
|
|
'notify_on' => array('title'=> FORLAN_177, 'type'=>'boolean', 'data' => 'int','help'=>FORLAN_178),
|
|
'poll' => array('title'=> FORLAN_49, 'type'=>'userclass', 'data' => 'int','help'=>FORLAN_50),
|
|
'attach' => array('title'=> FORLAN_70, 'type'=>'boolean', 'data' => 'str','help'=>FORLAN_71),
|
|
'maxwidth' => array('title'=> FORLAN_134, 'type'=>'number', 'data' => 'str','help'=>FORLAN_135),
|
|
'linkimg' => array('title'=> FORLAN_136, 'type'=>'boolean', 'data' => 'int','help'=>FORLAN_137),
|
|
'track' => array('title'=> FORLAN_200, 'type'=>'boolean', 'data' => 'int','help'=>FORLAN_201),
|
|
'trackemail' => array('title'=> FORLAN_202, 'type'=>'boolean', 'data' => 'int','help'=>FORLAN_203),
|
|
'redirect' => array('title'=> FORLAN_112, 'type'=>'boolean', 'data' => 'int','help'=>FORLAN_113),
|
|
'reported_post_email' => array('title'=> FORLAN_116, 'type'=>'boolean', 'data' => 'int','help'=>FORLAN_122),
|
|
'tooltip' => array('title'=> FORLAN_126, 'type'=>'boolean', 'data' => 'int','help'=>FORLAN_127),
|
|
'ranks' => array('title'=> FORLAN_63, 'type'=>'boolean', 'data' => 'int','help'=>''),
|
|
|
|
'tiplength' => array('title'=> FORLAN_128, 'type'=>'number', 'data' => 'int','help'=>FORLAN_129),
|
|
'eprefix' => array('title'=> FORLAN_53, 'type'=>'text', 'data' => 'string','help'=>FORLAN_54),
|
|
'popular' => array('title'=> FORLAN_55, 'type'=>'number', 'data' => 'int','help'=>FORLAN_56),
|
|
'postspage' => array('title'=> FORLAN_57, 'type'=>'number', 'data' => 'int','help'=>FORLAN_58),
|
|
'threadspage' => array('title'=> FORLAN_186, 'type'=>'number', 'data' => 'int','help'=>FORLAN_187),
|
|
|
|
|
|
|
|
|
|
);
|
|
|
|
public $forumParents = array();
|
|
public $forumObj = null;
|
|
|
|
|
|
// Correct bad ordering based on parent/child relationship.
|
|
private function checkOrder()
|
|
{
|
|
$sql = e107::getDb();
|
|
$sql2 = e107::getDb('sql2');
|
|
$count = $sql->select('forum', 'forum_id', 'forum_order = 0');
|
|
|
|
if($count > 1)
|
|
{
|
|
$sql->gen("SELECT forum_id,forum_name,forum_parent,forum_order FROM `#forum` ORDER BY COALESCE(NULLIF(forum_parent,0), forum_id), forum_parent > 0, forum_order ");
|
|
|
|
$c = 0;
|
|
while($row = $sql->fetch())
|
|
{
|
|
//print_a($row);
|
|
|
|
if($row['forum_parent'] == 0)
|
|
{
|
|
$c = $c + 100;
|
|
}
|
|
else
|
|
{
|
|
$c = $c+1;
|
|
}
|
|
|
|
$sql2->update('forum', 'forum_order = '.$c.' WHERE forum_id = '.$row['forum_id'].' LIMIT 1');
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
public function init()
|
|
{
|
|
|
|
$this->checkOrder();
|
|
|
|
|
|
if(e107::isInstalled('poll') == false)
|
|
{
|
|
$this->prefs['poll']['writeParms']['post'] = " <span class='label label-important label-danger'>".FORLAN_215."</span>";
|
|
}
|
|
|
|
|
|
if($this->getMode() == 'mods')
|
|
{
|
|
$this->fieldpref = array('forum_name', 'forum_moderators');
|
|
$this->fields['forum_moderators']['width'] = '50%';
|
|
$this->fields['options']['nolist'] = true;
|
|
$this->fields['options']['forced'] = false;
|
|
$this->fields['forum_class']['batch'] = false;
|
|
$this->fields['forum_postclass']['batch'] = false;
|
|
$this->fields['forum_threadclass']['batch'] = false;
|
|
$this->fields['forum_moderators']['batch'] = true;
|
|
|
|
}
|
|
|
|
require_once(e_PLUGIN.'forum/forum_class.php');
|
|
$this->forumObj = new e107forum;
|
|
|
|
if(E107_DEBUG_LEVEL > 0) // check fpr legacy prefs in debug mode. Should normally be done during upgrade.
|
|
{
|
|
$this->forumObj->upgradeLegacyPrefs();
|
|
}
|
|
|
|
|
|
if (!empty($_POST['do_prune']) && !empty($_POST['prune_days']) && !empty($_POST['pruneForum']))
|
|
{
|
|
$msg = $this->forumObj->forumPrune($_POST['prune_type'], $_POST['prune_days'], $_POST['pruneForum']);
|
|
e107::getMessage()->addSuccess($msg);
|
|
}
|
|
|
|
if(!empty($_POST['frsubmit']))
|
|
{
|
|
$this->saveRules();
|
|
}
|
|
|
|
|
|
|
|
|
|
if($this->getAction() == 'edit')
|
|
{
|
|
$this->fields['forum_order']['noedit'] = true;
|
|
}
|
|
|
|
|
|
$data = e107::getDb()->retrieve('forum', 'forum_id,forum_name,forum_parent', 'forum_id != 0',true);
|
|
$this->forumParents[0] = FORLAN_216;
|
|
$forumSubParents = array();
|
|
|
|
foreach($data as $val)
|
|
{
|
|
$id = $val['forum_id'];
|
|
|
|
if($val['forum_parent'] == 0)
|
|
{
|
|
$this->forumParents[$id] = $val['forum_name'];
|
|
}
|
|
else
|
|
{
|
|
$forumSubParents[$id] = $val['forum_name'];
|
|
}
|
|
|
|
}
|
|
|
|
$this->fields['forum_parent']['writeParms'] = $this->forumParents;
|
|
$this->fields['forum_sub']['writeParms']['optArray'] = $forumSubParents;
|
|
$this->fields['forum_sub']['writeParms']['default'] = 'blank';
|
|
|
|
}
|
|
|
|
|
|
// ------- Customize Create --------
|
|
|
|
public function afterSort($result, $selected)
|
|
{
|
|
|
|
return;
|
|
|
|
$sql = e107::getDb();
|
|
|
|
$data2 = $sql->retrieve('forum','forum_id,forum_name,forum_parent,forum_order','forum_parent = 0',true);
|
|
foreach($data2 as $val)
|
|
{
|
|
$id = $val['forum_id'];
|
|
$parent[$id] = $val['forum_order'];
|
|
|
|
}
|
|
|
|
$previous = 0;
|
|
|
|
$data = $sql->retrieve('forum','*','forum_parent != 0 ORDER BY forum_order',true);
|
|
foreach($data as $row)
|
|
{
|
|
$p = $row['forum_parent'];
|
|
|
|
if($p != $previous)
|
|
{
|
|
$c = $parent[$p];
|
|
}
|
|
|
|
$c++;
|
|
$previous = $p;
|
|
|
|
// echo "<br />".$row['forum_name']." with parent: ".$p." old: ".$row['forum_order']." new: ".$c;
|
|
$sql->update('forum','forum_order = '.$c.' WHERE forum_id = '.intval($row['forum_id']).' LIMIT 1');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function beforeCreate($new_data)
|
|
{
|
|
$sql = e107::getDb();
|
|
$parentOrder = $sql->retrieve('forum','forum_order','forum_id='.$new_data['forum_parent']." LIMIT 1");
|
|
|
|
$new_data['forum_order'] = $parentOrder + 50;
|
|
|
|
if(empty($new_data['forum_sef']))
|
|
{
|
|
$new_data['forum_sef'] = eHelper::title2sef($new_data['forum_name']);
|
|
}
|
|
|
|
return $new_data;
|
|
}
|
|
|
|
public function afterCreate($new_data, $old_data, $id)
|
|
{
|
|
// do something
|
|
e107::getCache()->clear_sys('forum_perms');
|
|
}
|
|
|
|
public function onCreateError($new_data, $old_data)
|
|
{
|
|
// do something
|
|
}
|
|
|
|
|
|
// ------- Customize Update --------
|
|
|
|
public function beforeUpdate($new_data, $old_data, $id)
|
|
{
|
|
if(empty($new_data['forum_sef']) && !empty($new_data['forum_name']))
|
|
{
|
|
$new_data['forum_sef'] = eHelper::title2sef($new_data['forum_name']);
|
|
}
|
|
|
|
return $new_data;
|
|
}
|
|
|
|
public function afterUpdate($new_data, $old_data, $id)
|
|
{
|
|
// do something
|
|
e107::getCache()->clear_sys('forum_perms',true);
|
|
}
|
|
|
|
|
|
public function afterDelete($del_data,$id)
|
|
{
|
|
e107::getCache()->clear_sys('forum_perms');
|
|
}
|
|
|
|
public function onUpdateError($new_data, $old_data, $id)
|
|
{
|
|
// do something
|
|
}
|
|
|
|
|
|
// optional - a custom page.
|
|
public function prunePage()
|
|
{
|
|
$ns = e107::getRender();
|
|
$sql = e107::getDB();
|
|
$frm = e107::getForm();
|
|
|
|
// $sql->select("forum", "forum_id, forum_name", "forum_parent!=0 ORDER BY forum_order ASC");
|
|
$qry = "
|
|
SELECT f.forum_id, f.forum_name, sp.forum_name AS sub_parent, fp.forum_name AS forum_parent
|
|
FROM #forum AS f
|
|
LEFT JOIN #forum AS sp ON sp.forum_id = f.forum_sub
|
|
LEFT JOIN #forum AS fp ON fp.forum_id = f.forum_parent
|
|
WHERE f.forum_parent != 0
|
|
ORDER BY f.forum_parent ASC, f.forum_sub, f.forum_order ASC
|
|
";
|
|
|
|
$forums = $sql->retrieve($qry, true);
|
|
// $forums = $sql->db_getList();
|
|
|
|
e107::getMessage()->addWarning(FORLAN_60);
|
|
|
|
$text = "
|
|
<form method='post' action='".e_SELF."?mode=main&action=prune'>\n
|
|
<table class='table adminlist'>
|
|
<colgroup>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
|
|
</colgroup>
|
|
|
|
<tr>
|
|
<td>".FORLAN_87."</td>
|
|
<td>".$frm->number('prune_days',0,3,array('min'=>1))."</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".LAN_TYPE."</td>
|
|
<td>
|
|
".$frm->radio('prune_type','delete',false, array('label'=>FORLAN_89)).
|
|
$frm->radio('prune_type','make_inactive',true, array('label'=>FORLAN_90))."
|
|
<div class='field-help'>".FORLAN_2."</div>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_138."</td>
|
|
<td>";
|
|
|
|
foreach($forums as $forum)
|
|
{
|
|
$for_name = $forum['forum_parent']." ≫ ";
|
|
$for_name .= ($forum['sub_parent'] ? $forum['sub_parent']." ≫ " : "");
|
|
$for_name .= $forum['forum_name'];
|
|
$text .= $frm->checkbox('pruneForum[]',$forum['forum_id'], false, $for_name); // "<input type='checkbox' name='pruneForum[]' value='".$forum['forum_id']."' /> ".$for_name."<br />";
|
|
}
|
|
|
|
|
|
$text .= "
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('do_prune', LAN_PRUNE, 'submit')."
|
|
</div>
|
|
</form>";
|
|
|
|
return $text;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
function saveRules()
|
|
{
|
|
$tp = e107::getParser();
|
|
$sql = e107::getDb();
|
|
|
|
|
|
$guestrules = $tp->toDB($_POST['guestrules']);
|
|
$memberrules = $tp->toDB($_POST['memberrules']);
|
|
$adminrules = $tp->toDB($_POST['adminrules']);
|
|
|
|
if(!$sql->update("generic", "gen_chardata ='$guestrules', gen_intdata='".$_POST['guest_active']."' WHERE gen_type='forum_rules_guest' "))
|
|
{
|
|
$sql->insert("generic", "0, 'forum_rules_guest', '".time()."', 0, '', '".$_POST['guest_active']."', '$guestrules' ");
|
|
}
|
|
if(!$sql->update("generic", "gen_chardata ='$memberrules', gen_intdata='".$_POST['member_active']."' WHERE gen_type='forum_rules_member' "))
|
|
{
|
|
$sql->insert("generic", "0, 'forum_rules_member', '".time()."', 0, '', '".$_POST['member_active']."', '$memberrules' ");
|
|
}
|
|
if(!$sql->update("generic", "gen_chardata ='$adminrules', gen_intdata='".$_POST['admin_active']."' WHERE gen_type='forum_rules_admin' "))
|
|
{
|
|
$sql->insert("generic", "0, 'forum_rules_admin', '".time()."', 0, '', '".$_POST['admin_active']."', '$adminrules' ");
|
|
}
|
|
|
|
|
|
e107::getMessage()->addSuccess(LAN_SAVED);
|
|
return null;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
function rulesPage()
|
|
{
|
|
|
|
$pref = e107::getPref();
|
|
$ns = e107::getRender();
|
|
$sql = e107::getDB();
|
|
$tp = e107::getParser();
|
|
$frm = e107::getForm();
|
|
|
|
/*
|
|
$sql->select("wmessage");
|
|
list($null) = $sql->fetch();
|
|
list($null) = $sql->fetch();
|
|
list($null) = $sql->fetch();
|
|
list($id, $guestrules, $wm_active4) = $sql->fetch();
|
|
list($id, $memberrules, $wm_active5) = $sql->fetch();
|
|
list($id, $adminrules, $wm_active6) = $sql->fetch();
|
|
*/
|
|
|
|
|
|
if($sql->select('generic','*',"gen_type='forum_rules_guest'"))
|
|
{
|
|
$guest_rules = $sql->fetch();
|
|
}
|
|
if($sql->select('generic','*',"gen_type='forum_rules_member'"))
|
|
{
|
|
$member_rules = $sql->fetch();
|
|
}
|
|
if($sql->select('generic','*',"gen_type='forum_rules_admin'"))
|
|
{
|
|
$admin_rules = $sql->fetch();
|
|
}
|
|
|
|
$guesttext = $tp->toForm(vartrue($guest_rules['gen_chardata']));
|
|
$membertext = $tp->toForm(vartrue($member_rules['gen_chardata']));
|
|
$admintext = $tp->toForm(vartrue($admin_rules['gen_chardata']));
|
|
|
|
$text = "
|
|
<form method='post' action='".e_SELF."?mode=main&action=rules' id='wmform'>
|
|
<table class='table adminform'>
|
|
<colgroup span='2'>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tr>
|
|
<td>".WMGLAN_1.": <br />
|
|
".WMGLAN_6.":";
|
|
if (vartrue($guest_rules['gen_intdata']))
|
|
{
|
|
$text .= "<input type='checkbox' name='guest_active' value='1' checked='checked' />";
|
|
}
|
|
else
|
|
{
|
|
$text .= "<input type='checkbox' name='guest_active' value='1' />";
|
|
}
|
|
$text .= "</td>
|
|
|
|
<td>
|
|
".$frm->bbarea('guestrules', $guesttext)."
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".WMGLAN_2.": <br />
|
|
".WMGLAN_6.":";
|
|
if (vartrue($member_rules['gen_intdata']))
|
|
{
|
|
$text .= "<input type='checkbox' name='member_active' value='1' checked='checked' />";
|
|
}
|
|
else
|
|
{
|
|
$text .= "<input type='checkbox' name='member_active' value='1' />";
|
|
}
|
|
$text .= "</td>
|
|
|
|
<td>
|
|
".$frm->bbarea('memberrules', $membertext)."
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".WMGLAN_3.": <br />
|
|
".WMGLAN_6.": ";
|
|
|
|
if (vartrue($admin_rules['gen_intdata']))
|
|
{
|
|
$text .= "<input type='checkbox' name='admin_active' value='1' checked='checked' />";
|
|
}
|
|
else
|
|
{
|
|
$text .= "<input type='checkbox' name='admin_active' value='1' />";
|
|
}
|
|
|
|
$text .= "</td>
|
|
<td>
|
|
".$frm->bbarea('adminrules', $admintext)."
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('frsubmit', LAN_UPDATE, 'submit')."
|
|
</div>
|
|
</form>";
|
|
|
|
return $text;
|
|
|
|
$ns->tablerender(WMGLAN_5, $text);
|
|
|
|
|
|
/*
|
|
echo "
|
|
<script type=\"text/javascript\">
|
|
function addtext1(sc){
|
|
document.getElementById('wmform').guestrules.value += sc;
|
|
}
|
|
function addtext2(sc){
|
|
document.getElementById('wmform').memberrules.value += sc;
|
|
}
|
|
function addtext3(sc){
|
|
document.getElementById('wmform').adminrules.value += sc;
|
|
}
|
|
function help1(help){
|
|
document.getElementById('wmform').helpguest.value = help;
|
|
}
|
|
function help2(help){
|
|
document.getElementById('wmform').helpmember.value = help;
|
|
}
|
|
function help3(help){
|
|
document.getElementById('wmform').helpadmin.value = help;
|
|
}
|
|
</script>
|
|
";*/
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function modsPage()
|
|
{
|
|
|
|
|
|
$ns = e107::getRender();
|
|
$sql = e107::getDB();
|
|
//$e107 = e107::getInstance();
|
|
|
|
$forumList = $this->forumObj->forum_getforums('all');
|
|
$parentList = $this->forumObj->forum_getparents('list');
|
|
$subList = $this->forumObj->forumGetSubs('bysub');
|
|
|
|
$frm = e107::getForm();
|
|
$tp = e107::getParser();
|
|
|
|
$txt = "<form method='post' action='".e_SELF."?".e_QUERY."'>
|
|
<table class='table adminlist'>
|
|
<colgroup span='2'>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>";
|
|
|
|
foreach($parentList as $p)
|
|
{
|
|
$txt .= "
|
|
<tr>
|
|
<td colspan='2' ><strong>".$tp->toHTML($p['forum_name'])."</strong></td>
|
|
</tr>
|
|
";
|
|
|
|
foreach($forumList[$p['forum_id']] as $f)
|
|
{
|
|
$txt .= "
|
|
<tr>
|
|
<td>{$f['forum_name']}</td>
|
|
<td>".e107::getUserClass()->uc_dropdown("mods[{$f['forum_id']}]", $f['forum_moderators'], 'admin,classes')."</td>
|
|
</tr>
|
|
";
|
|
foreach($subList[$f['forum_id']] as $s)
|
|
{
|
|
$txt .= "
|
|
<tr>
|
|
<td> {$s['forum_name']}</td>
|
|
<td>".e107::getUserClass()->uc_dropdown("mods[{$s['forum_id']}]", $s['forum_moderators'], 'admin,classes')."</td>
|
|
</tr>
|
|
";
|
|
}
|
|
}
|
|
}
|
|
$txt .= "
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('setMods', LAN_UPDATE, 'update')."
|
|
</div>
|
|
</form>";
|
|
|
|
return $txt;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
function toolsPageProcess()
|
|
{
|
|
|
|
$mes = e107::getMessage();
|
|
|
|
$fList = array();
|
|
|
|
if(isset($_POST['tools']))
|
|
{
|
|
$msg = '';
|
|
if(isset($_POST['forum_all']))
|
|
{
|
|
$fList[]='all';
|
|
}
|
|
else
|
|
{
|
|
foreach(array_keys($_POST['forumlist']) as $k)
|
|
{
|
|
$fList[] = $k;
|
|
}
|
|
}
|
|
foreach($fList as $fid)
|
|
{
|
|
if(isset($_POST['counts']))
|
|
{
|
|
$this->forumObj->forumUpdateCounts($fid, $_POST['counts_threads']);
|
|
$msg .= FORLAN_167.": $fid <br />";
|
|
}
|
|
if(isset($_POST['lastpost']))
|
|
{
|
|
$with_threads = (!empty($_POST['lastpost_nothread'])) ? FALSE : TRUE;
|
|
$this->forumObj->forumUpdateLastpost('forum', $fid, $with_threads);
|
|
$msg .= FORLAN_168.": $fid <br />";
|
|
}
|
|
}
|
|
if(isset($_POST['userpostcounts']))
|
|
{
|
|
$ue = e107::getUserExt();
|
|
|
|
$list = $this->forumObj->getUserCounts();
|
|
foreach($list as $uid => $cnt)
|
|
{
|
|
$ue->user_extended_setvalue($uid, 'user_plugin_forum_posts', $cnt, 'int');
|
|
}
|
|
$msg .= FORLAN_169.' <br />';
|
|
}
|
|
|
|
$mes->addSuccess($msg);
|
|
// $ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
//TODO Add SEF-url generation for forum and threads where missing.
|
|
function toolsPage()
|
|
{
|
|
$sql = e107::getDb();
|
|
$ns = e107::getRender();
|
|
$tp = e107::getParser();
|
|
$frm = e107::getForm();
|
|
|
|
$this->toolsPageProcess();
|
|
|
|
$txt = "
|
|
<form method='post' action='".e_SELF."?".e_QUERY."'>
|
|
<table class='table adminlist'>
|
|
<colgroup span='3'>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
<col class='col-control' style='width:50%' />
|
|
</colgroup>
|
|
<tr>
|
|
<td>".FORLAN_156."</td>
|
|
|
|
<td colspan='2'>
|
|
";
|
|
if($sql->select("forum", "*", "1 ORDER BY forum_order"))
|
|
{
|
|
$fList = $sql->db_getList();
|
|
foreach($fList as $f)
|
|
{
|
|
$key = 'forumlist['.$f['forum_id'].']';
|
|
$txt .= $frm->checkbox($key, 1, false, $tp->toHTML($f['forum_name']));
|
|
// $txt .= "<input type='checkbox' name='forumlist[{$f['forum_id']}]' value='1' /> ".$tp->toHTML($f['forum_name'])."<br />";
|
|
}
|
|
$txt .= "<hr />";
|
|
$txt .= $frm->checkbox('forum_all', 1, false, LAN_PLUGIN_FORUM_ALLFORUMS);
|
|
// $txt .= "<input type='checkbox' name='forum_all' value='1' /> <strong>".LAN_PLUGIN_FORUM_ALLFORUMS."</strong>";
|
|
}
|
|
|
|
|
|
//TODO LAN - see below
|
|
$txt .= "
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_158."</td>
|
|
|
|
<td>".$frm->checkbox('lastpost', 1, false, LAN_ACTIVE).
|
|
"</td><td>".
|
|
$frm->select('lastpost_nothread', array(0=>FORLAN_207, 1=>FORLAN_208))."
|
|
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_161."</td>
|
|
|
|
<td>".$frm->checkbox('counts', 1, false, LAN_ACTIVE).
|
|
"</td><td>".
|
|
$frm->checkbox('counts_threads', 1, false, FORLAN_182)."
|
|
<span class='text-warning'>".FORLAN_183."</span>
|
|
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_163."</td>
|
|
|
|
<td colspan='2'>".$frm->checkbox('userpostcounts',1, false, LAN_ACTIVE)."</td>
|
|
</tr>
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('tools', LAN_GO, 'submit')."
|
|
</div>
|
|
</form>
|
|
";
|
|
|
|
return $txt;
|
|
// $ns->tablerender(FORLAN_166, $txt);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
class forum_form_ui extends e_admin_form_ui
|
|
{
|
|
|
|
function forum_name($curVal,$mode,$parm)
|
|
{
|
|
|
|
$frm = e107::getForm();
|
|
|
|
if($mode == 'read')
|
|
{
|
|
return $curVal;
|
|
|
|
$parent = $this->getController()->getListModel()->get('forum_parent');
|
|
$id = $this->getController()->getListModel()->get('forum_id');
|
|
$sub = $this->getController()->getListModel()->get('forum_sub');
|
|
|
|
|
|
|
|
$level = 1;
|
|
|
|
if(!empty($sub))
|
|
{
|
|
$level = 3;
|
|
}
|
|
|
|
$linkQ = e_SELF."?searchquery=&filter_options=page_chapter__".$id."&mode=page&action=list";
|
|
$level_image = $parent ? '<img src="'.e_IMAGE_ABS.'generic/branchbottom.gif" class="icon" alt="" style="margin-left: '.($level * 20).'px" /> ' : '';
|
|
|
|
|
|
|
|
return ($parent) ? $level_image.$curVal : $curVal;
|
|
}
|
|
|
|
if($mode == 'write')
|
|
{
|
|
return $frm->text('forum_name',$curVal,255,'size=xxlarge');
|
|
}
|
|
|
|
if($mode == 'filter')
|
|
{
|
|
return;
|
|
}
|
|
if($mode == 'batch')
|
|
{
|
|
return;
|
|
}
|
|
|
|
if($mode == 'inline')
|
|
{
|
|
$ret = array('inlineType'=>'text');
|
|
|
|
$parent = $this->getController()->getListModel()->get('forum_parent');
|
|
$sub = $this->getController()->getListModel()->get('forum_sub');
|
|
|
|
if(!empty($parent))
|
|
{
|
|
|
|
$level = 1;
|
|
|
|
if(!empty($sub))
|
|
{
|
|
$level = 2;
|
|
}
|
|
|
|
$ret['inlineParms'] = array('pre'=>'<img src="'.e_IMAGE_ABS.'generic/branchbottom.gif" class="level-'.$level.' icon" alt="" />');
|
|
}
|
|
|
|
|
|
return $ret;
|
|
}
|
|
}
|
|
|
|
|
|
// Custom Method/Function
|
|
function forum_parent($curVal,$mode)
|
|
{
|
|
$frm = e107::getForm();
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
return $curVal;
|
|
break;
|
|
|
|
case 'write': // Edit Page
|
|
return $frm->text('forum_parent',$curVal);
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
// return $array;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
// Custom Method/Function
|
|
function forum_sub($curVal,$mode)
|
|
{
|
|
$frm = e107::getForm();
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
return $curVal;
|
|
break;
|
|
|
|
case 'write': // Edit Page
|
|
return $frm->text('forum_sub',$curVal);
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
// return $array;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Custom Method/Function
|
|
function forum_lastpost_info($curVal,$mode)
|
|
{
|
|
$frm = e107::getForm();
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
return $curVal;
|
|
break;
|
|
|
|
case 'write': // Edit Page
|
|
return $frm->text('forum_lastpost_info',$curVal);
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
// return $array;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
// Custom Method/Function
|
|
function forum_options($curVal,$mode)
|
|
{
|
|
$frm = e107::getForm();
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
return $curVal;
|
|
break;
|
|
|
|
case 'write': // Edit Page
|
|
return $frm->text('forum_options',$curVal);
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
// return $array;
|
|
break;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class reported_ui extends e_admin_ui
|
|
{
|
|
|
|
protected $pluginTitle = LAN_PLUGIN_FORUM_NAME;
|
|
protected $pluginName = 'forum';
|
|
protected $table = 'generic';
|
|
protected $pid = 'gen_id';
|
|
protected $perPage = 10;
|
|
protected $listQry = "SELECT g.*,u.user_name FROM `#generic` AS g LEFT JOIN `#user` AS u ON g.gen_user_id = u.user_id WHERE g.gen_type='reported_post' OR g.gen_type='Reported Forum Post' ORDER BY g.gen_datestamp DESC";
|
|
|
|
protected $fields = array (
|
|
'checkboxes' => array ( 'title' => '', 'type' => null, 'data' => null, 'width' => '5%', 'thclass' => 'center', 'forced' => '1', 'class' => 'center', 'toggle' => 'e-multiselect', ),
|
|
'gen_id' => array ( 'title' => LAN_ID, 'nolist'=>true, 'data' => 'int', 'width' => '5%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
// 'gen_type' => array ( 'title' => LAN_BAN, 'type' => 'method', 'data' => 'str', 'width' => 'auto', 'batch' => true, 'filter' => true, 'inline' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'gen_datestamp' => array ( 'title' => LAN_DATESTAMP, 'type' => 'datestamp', 'data' => 'int', 'width' => '10%', 'filter' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'gen_ip' => array ( 'title' => FORLAN_209, 'type' => 'text', 'data' => 'str', 'width' => '20%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'gen_chardata' => array ( 'title' => FORLAN_210, 'type' => 'method', 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'gen_user_id' => array ( 'title' => FORLAN_211, 'type' => 'user', 'batch'=>true, 'data' => 'int', 'width' => '5%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left nowrap', ),
|
|
'gen_intdata' => array ( 'title' => FORLAN_209, 'type' => 'number', 'nolist'=>true, 'batch'=>false, 'data' => 'int', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'center', 'thclass' => 'center', ),
|
|
'options' => array ( 'title' => LAN_OPTIONS, 'type' => 'method', 'data' => null, 'width' => '10%', 'thclass' => 'center last', 'class' => 'center last', 'forced' => '1', 'readParms'=>'edit=0' ),
|
|
);
|
|
|
|
protected $fieldpref = array('gen_datestamp', 'gen_ip', 'gen_user_id', 'gen_chardata');
|
|
|
|
|
|
// optional
|
|
public function init()
|
|
{
|
|
|
|
}
|
|
|
|
public function afterDelete($data)
|
|
{
|
|
// $sql2->db_Delete('banlist', "banlist_ip='{$banIP}'");
|
|
}
|
|
|
|
public function renderHelp()
|
|
{
|
|
return array('caption'=>LAN_HELP, 'text'=>FORLAN_189);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class reported_form_ui extends e_admin_form_ui
|
|
{
|
|
|
|
|
|
// Custom Method/Function
|
|
function gen_intdata($curVal,$mode)
|
|
{
|
|
$frm = e107::getForm();
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
|
|
return "<a class='e-modal btn btn-primary' data-modal-caption='Topic#: ".$curVal."' href='".e_SELF."?mode=post&action=list&id=". $curVal."' rel='external'>#". $curVal."</a>";
|
|
return $curVal;
|
|
break;
|
|
|
|
case 'write': // Edit Page
|
|
return $frm->text('gen_type',$curVal);
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
return array(1=>LAN_BAN);
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
// Custom Method/Function
|
|
function gen_chardata($curVal,$mode)
|
|
{
|
|
$frm = e107::getForm();
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
return str_replace(":::","<br />",$curVal);
|
|
break;
|
|
|
|
case 'write': // Edit Page
|
|
return $frm->text('gen_chardata',$curVal);
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
// return $array;
|
|
break;
|
|
}
|
|
}
|
|
|
|
function options($att, $value, $id, $attributes)
|
|
{
|
|
|
|
if($attributes['mode'] == 'read')
|
|
{
|
|
|
|
$topic = $this->getController()->getListModel()->get('gen_chardata');
|
|
$topidId = $this->getController()->getListModel()->get('gen_intdata');
|
|
$text = "<div class='btn-group'>";
|
|
$text .= "<a class='e-modal btn btn-default' data-modal-caption='Topic: ".$topic."' href='".e_SELF."?mode=post&action=list&id=". $topidId."' rel='external'>".ADMIN_VIEW_ICON."</a>";
|
|
|
|
$text .= $this->renderValue('options',$value,array('readParms'=>'edit=0'));
|
|
$text .= "</div>";
|
|
return $text;
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
class post_ui extends e_admin_ui
|
|
{
|
|
|
|
protected $pluginTitle = LAN_PLUGIN_FORUM_NAME;
|
|
protected $pluginName = 'forum';
|
|
protected $table = 'forum_post';
|
|
protected $pid = 'post_id';
|
|
protected $perPage = 10;
|
|
// protected $listQry = "SELECT g.*,u.user_name FROM `#generic` AS g LEFT JOIN `#user` AS u ON g.gen_user_id = u.user_id WHERE g.gen_type='reported_post' OR g.gen_type='Reported Forum Post' ORDER BY g.gen_datestamp DESC";
|
|
|
|
protected $listOrder = 'post_datestamp';
|
|
|
|
protected $fields = array (
|
|
'checkboxes' => array ( 'title' => '', 'type' => null, 'data' => null, 'width' => '5%', 'thclass' => 'center', 'forced' => '1', 'class' => 'center', 'toggle' => 'e-multiselect', ),
|
|
'post_id' => array ( 'title' => LAN_ID, 'nolist'=>true, 'data' => 'int', 'width' => '5%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
// 'gen_type' => array ( 'title' => LAN_BAN, 'type' => 'method', 'data' => 'str', 'width' => 'auto', 'batch' => true, 'filter' => true, 'inline' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'post_datestamp' => array ( 'title' => LAN_DATESTAMP, 'type' => 'datestamp', 'data' => 'int', 'width' => '10%', 'filter' => true, 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'post_entry' => array ( 'title' => FORLAN_213, 'type' => 'bbarea', 'data' => 'str', 'width' => '20%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
// 'gen_chardata' => array ( 'title' => "Issue", 'type' => 'method', 'data' => 'str', 'width' => 'auto', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'post_user' => array ( 'title' => LAN_USER, 'type' => 'user', 'batch'=>false, 'data' => 'int', 'width' => '5%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left nowrap', ),
|
|
'post_attachments' => array ( 'title' => FORLAN_212, 'type' => 'method', 'batch'=>false, 'data' => 'int', 'width' => '10%', 'help' => '', 'readParms' => '', 'writeParms' => '', 'class' => 'left', 'thclass' => 'left', ),
|
|
'options' => array ( 'title' => LAN_OPTIONS, 'type' => null, 'data' => null, 'width' => '2%', 'thclass' => 'right last', 'class' => 'right last', 'forced' => '1', 'readParms'=>'edit=0' ),
|
|
);
|
|
|
|
protected $fieldpref = array('post_datestamp', 'post_entry', 'post_user', 'post_attachments');
|
|
|
|
|
|
// optional
|
|
public function init()
|
|
{
|
|
|
|
$id = intval($_GET['id']);
|
|
|
|
if(!empty($id))
|
|
{
|
|
define('e_IFRAME', true);
|
|
$this->listQry = "SELECT p.*,u.user_name FROM `#forum_post` AS p LEFT JOIN `#user` AS u ON p.post_user = u.user_id WHERE p.post_thread = ".intval($id);
|
|
}
|
|
else
|
|
{
|
|
$this->listOrder = 'post_datestamp DESC';
|
|
$this->listQry = "SELECT p.*,u.user_name FROM `#forum_post` AS p LEFT JOIN `#user` AS u ON p.post_user = u.user_id ";
|
|
}
|
|
}
|
|
|
|
public function afterDelete($data)
|
|
{
|
|
// $sql2->db_Delete('banlist', "banlist_ip='{$banIP}'");
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class post_form_ui extends e_admin_form_ui
|
|
{
|
|
|
|
function post_attachments($curVal,$mode)
|
|
{
|
|
|
|
|
|
switch($mode)
|
|
{
|
|
case 'read': // List Page
|
|
$data = e107::unserialize($curVal);
|
|
$tp = e107::getParser();
|
|
$fl = e107::getFile();
|
|
|
|
|
|
$text = '';
|
|
|
|
if(!empty($data['img']))
|
|
{
|
|
$text .= "<ul class='list-unstyled'>";
|
|
foreach($data['img'] as $v)
|
|
{
|
|
$text .= "<li><span class='label label-primary'>".$tp->toGlyph('fa-file-image-o').$v['name']."</span> <small>".$fl->file_size_encode($v['size'])."</small></li>";
|
|
}
|
|
|
|
$text .= "</ul>";
|
|
}
|
|
|
|
if(!empty($data['file']))
|
|
{
|
|
$text .= "<ul class='list-unstyled'>";
|
|
foreach($data['file'] as $v)
|
|
{
|
|
$text .= "<li><span class='label label-primary'>".$tp->toGlyph('fa-file-text-o').$v['name']."</span> <small>".$fl->file_size_encode($v['size'])."</small></li>";
|
|
}
|
|
|
|
$text .= "</ul>";
|
|
}
|
|
|
|
return $text;
|
|
break;
|
|
|
|
case 'write': // Edit Page
|
|
$data = e107::unserialize($curVal);
|
|
return print_a($data,true);
|
|
break;
|
|
|
|
case 'filter':
|
|
case 'batch':
|
|
// return $array;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
new forum_admin();
|
|
|
|
require_once(e_ADMIN."auth.php");
|
|
e107::getAdminUI()->runPage();
|
|
|
|
require_once(e_ADMIN."footer.php");
|
|
exit;
|
|
|
|
|
|
}
|
|
|
|
|
|
/*
|
|
$e_sub_cat = 'forum';
|
|
|
|
require_once(e_ADMIN.'auth.php');
|
|
require_once(e_HANDLER.'userclass_class.php');
|
|
require_once(e_HANDLER.'form_handler.php');
|
|
require_once(e_PLUGIN.'forum/forum_class.php');
|
|
|
|
$for = new e107forum;
|
|
$forum = new forumAdmin;
|
|
|
|
$mes = e107::getMessage();
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
|
|
$fPref = e107::getPlugConfig('forum', '', false);
|
|
|
|
print_a($fPref);
|
|
|
|
define('IMAGE_new', "<img src='".img_path('new.png')."' alt='' />");
|
|
define('IMAGE_sub', "<img src='".e_PLUGIN."forum/images/forums_16.png' alt='".FORLAN_145."' title='".FORLAN_145."' />");
|
|
define('IMAGE_nosub', "<img src='".e_PLUGIN."forum/images/sub_forums_16.png' alt='".FORLAN_145."' title='".FORLAN_145."' />");
|
|
|
|
$deltest = array_flip($_POST);
|
|
|
|
if (e_QUERY)
|
|
{
|
|
$tmp = explode('.', e_QUERY);
|
|
$action = $tmp[0];
|
|
$sub_action = $tmp[1];
|
|
$id = $tmp[2];
|
|
unset($tmp);
|
|
}
|
|
|
|
if(isset($_POST['delete']))
|
|
{
|
|
$tmp = array_pop(array_flip($_POST['delete']));
|
|
list($delete, $del_id) = explode('_', $tmp);
|
|
}
|
|
|
|
if(isset($_POST['setMods']))
|
|
{
|
|
foreach($_POST['mods'] as $fid => $modid)
|
|
{
|
|
if($sql->update('forum',"forum_moderators = '{$modid}' WHERE forum_id = {$fid}"))
|
|
{
|
|
$mes->addSuccess(LAN_UPDATED);
|
|
}
|
|
else
|
|
{
|
|
$mes->addError(LAN_UPDATED_FAILED);
|
|
}
|
|
|
|
}
|
|
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
|
|
if(isset($_POST['tools']))
|
|
{
|
|
$msg = '';
|
|
if(isset($_POST['forum_all']))
|
|
{
|
|
$fList[]='all';
|
|
}
|
|
else
|
|
{
|
|
foreach(array_keys($_POST['forumlist']) as $k)
|
|
{
|
|
$fList[] = $k;
|
|
}
|
|
}
|
|
foreach($fList as $fid)
|
|
{
|
|
if(isset($_POST['counts']))
|
|
{
|
|
$for->forumUpdateCounts($fid, $_POST['counts_threads']);
|
|
$msg .= FORLAN_167.": $fid <br />";
|
|
}
|
|
if(isset($_POST['lastpost']))
|
|
{
|
|
$with_threads = (isset($_POST['lastpost_nothread'])) ? FALSE : TRUE;
|
|
$for->forumUpdateLastpost('forum', $fid, $with_threads);
|
|
$msg .= FORLAN_168.": $fid <br />";
|
|
}
|
|
}
|
|
if(isset($_POST['userpostcounts']))
|
|
{
|
|
require_once(e_HANDLER.'user_extended_class.php');
|
|
$ue = new e107_user_extended;
|
|
|
|
$list = $for->getUserCounts();
|
|
foreach($list as $uid => $cnt)
|
|
{
|
|
$ue->user_extended_setvalue($uid, 'user_plugin_forum_posts', $cnt, 'int');
|
|
}
|
|
$msg .= FORLAN_169.' <br />';
|
|
}
|
|
$mes->addSuccess($msg);
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
|
|
|
|
if(isset($_POST['create_sub']))
|
|
{
|
|
$fid = (int)($sub_action);
|
|
$tmp = array();
|
|
$tmp['forum_name'] = $tp->toDB($_POST['subname_new']);
|
|
$tmp['forum_description'] = $tp->toDB($_POST['subdesc_new']);
|
|
$tmp['forum_order'] = (int)$_POST['suborder_new'];
|
|
|
|
if($tmp['forum_name'] != '' && $sql->select('forum', '*', "forum_id = {$fid}"))
|
|
{
|
|
$row = $sql->fetch();
|
|
$tmp['forum_parent'] = $row['forum_parent'];
|
|
$tmp['forum_moderators'] = $row['forum_moderators'];
|
|
$tmp['forum_class'] = $row['forum_class'];
|
|
$tmp['forum_postclass'] = $row['forum_postclass'];
|
|
$tmp['forum_sub'] = $fid;
|
|
if($sql->insert('forum', $tmp))
|
|
{
|
|
$mes->addSuccess(LAN_CREATED);
|
|
}
|
|
else
|
|
{
|
|
$mes->addError(LAN_CREATED_FAILED);
|
|
}
|
|
}
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
|
|
if(isset($_POST['update_subs']))
|
|
{
|
|
$msg = "";
|
|
foreach(array_keys($_POST['subname']) as $id)
|
|
{
|
|
if($_POST['subname'][$id] == "")
|
|
{
|
|
if ($sql->delete("forum", "forum_id='$id' "))
|
|
{
|
|
$msg .= LAN_FORUM_1002." ". LAN_ID.":"." ".$id." ".LAN_DELETED."<br />";
|
|
$cnt = $sql->delete("forum_thread", "thread_forum_id = {$id}");
|
|
$msg .= $cnt." ".FORLAN_152." ".LAN_DELETED."<br />";
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$_name = $tp->toDB($_POST['subname'][$id]);
|
|
$_desc = $tp->toDB($_POST['subdesc'][$id]);
|
|
$_order = (int)$_POST['suborder'][$id];
|
|
if($sql->update('forum', "forum_name='{$_name}', forum_description='{$_desc}', forum_order='{$_order}' WHERE forum_id = {$id}"))
|
|
{
|
|
$msg .= LAN_FORUM_1002 ." ". LAN_ID.":"." ".$id." ".LAN_UPDATED."<br />";
|
|
}
|
|
}
|
|
}
|
|
if($msg)
|
|
{
|
|
$mes->addSuccess($msg);
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
}
|
|
|
|
if(isset($_POST['submit_parent']))
|
|
{
|
|
unset($insert);
|
|
$insert = array(
|
|
'forum_name' => $tp->toDB($_POST['forum_name']),
|
|
'forum_datestamp' => time(),
|
|
'forum_class' => (int)$_POST['forum_class'],
|
|
'forum_postclass' => (int)$_POST['forum_postclass'],
|
|
'forum_threadclass' => (int)$_POST['forum_threadclass'],
|
|
);
|
|
|
|
if($sql->insert('forum', $insert))
|
|
{
|
|
$mes->addSuccess(LAN_CREATED);
|
|
}
|
|
else
|
|
{
|
|
$mes->addError(LAN_CREATED_FAILED);
|
|
}
|
|
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
|
|
|
|
if(isset($_POST['update_parent']))
|
|
{
|
|
unset($update);
|
|
$update = array(
|
|
'forum_name' => $tp->toDb($_POST['forum_name']),
|
|
'forum_datestamp' => time(),
|
|
'forum_class' => (int)$_POST['forum_class'],
|
|
'forum_postclass' => (int)$_POST['forum_postclass'],
|
|
'forum_threadclass' => (int)$_POST['forum_threadclass'],
|
|
'WHERE' => 'forum_id = '.(int)$id
|
|
);
|
|
|
|
if($sql->update('forum', $update))
|
|
{
|
|
$mes->addSuccess(LAN_UPDATED);
|
|
}
|
|
else
|
|
{
|
|
$mes->addError(LAN_UPDATED_FAILED);
|
|
}
|
|
|
|
$action = 'main';
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
|
|
|
|
if(isset($_POST['submit_forum']))
|
|
{
|
|
$tmp = array();
|
|
$tmp['forum_moderators'] = (int)$_POST['forum_moderators'];
|
|
$tmp['forum_name'] = $tp->toDB($_POST['forum_name']);
|
|
$tmp['forum_description'] = $tp->toDB($_POST['forum_description']);
|
|
$tmp['forum_datestamp'] = time();
|
|
$tmp['forum_class'] = (int)$_POST['forum_class'];
|
|
$tmp['forum_postclass'] = (int)$_POST['forum_postclass'];
|
|
$tmp['forum_threadclass'] = (int)$_POST['forum_threadclass'];
|
|
$tmp['forum_parent'] = (int)$_POST['forum_parent'];
|
|
|
|
if($sql->insert('forum', $tmp))
|
|
{
|
|
$mes->addSuccess(LAN_CREATED);
|
|
}
|
|
else
|
|
{
|
|
$mes->addError(LAN_CREATED_FAILED);
|
|
}
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
|
|
|
|
if(isset($_POST['update_forum']))
|
|
{
|
|
unset($_POST['update_forum']);
|
|
$tmp['data'] = $_POST;
|
|
$tmp['WHERE'] = 'forum_id = '.(int)$id;
|
|
|
|
$tmp2['forum_moderators'] = $tmp['forum_moderators'];
|
|
$tmp2['forum_class'] = $tmp['forum_class'];
|
|
$tmp2['forum_postclass'] = $tmp['forum_postclass'];
|
|
$tmp2['forum_threadclass'] = $tmp['forum_threadclass'];
|
|
$tmp2['WHERE'] = 'forum_sub = '.(int)$id;
|
|
|
|
$sql->update('forum', $tmp);
|
|
$sql->update('forum', $tmp2);
|
|
|
|
$mes->addSuccess(LAN_UPDATED);
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
$action = 'main';
|
|
}
|
|
|
|
|
|
|
|
if (isset($_POST['update_order']))
|
|
{
|
|
while (list($key, $id) = each($_POST['forum_order']))
|
|
{
|
|
$tmp = explode('.', $id);
|
|
$sql->update('forum', "forum_order=".$tmp[1]." WHERE forum_id=".$tmp[0]);
|
|
}
|
|
$mes->addSuccess(LAN_UPDATED);
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
|
|
|
|
if (isset($_POST['updateoptions']))
|
|
{
|
|
$fPref->set('notify', $_POST['email_notify']);
|
|
$fPref->set('notify_on', $_POST['email_notify_on']);
|
|
$fPref->set('poll', $_POST['forum_poll']);
|
|
$fPref->set('popular', $_POST['forum_popular']);
|
|
$fPref->set('track', $_POST['forum_track']);
|
|
$fPref->set('eprefix', $_POST['forum_eprefix']);
|
|
$fPref->set('enclose', $_POST['forum_enclose']);
|
|
$fPref->set('title', $_POST['forum_title']);
|
|
$fPref->set('postspage', $_POST['forum_postspage']);
|
|
$fPref->set('threadspage', $_POST['forum_threadspage']);
|
|
$fPref->set('html_post', $_POST['html_post']);
|
|
$fPref->set('attach', $_POST['forum_attach']);
|
|
$fPref->set('redirect', $_POST['forum_redirect']);
|
|
$fPref->set('reported_post_email', $_POST['reported_post_email']);
|
|
$fPref->set('tooltip', $_POST['forum_tooltip']);
|
|
$fPref->set('tiplength', $_POST['forum_tiplength']);
|
|
$fPref->set('hilightsticky', $_POST['forum_hilightsticky']);
|
|
$fPref->set('maxwidth', $_POST['forum_maxwidth']);
|
|
$fPref->set('linkimg', $_POST['forum_linkimg']);
|
|
$fPref->save(true, true);
|
|
|
|
$mes->addSuccess();
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
|
|
|
|
if (isset($_POST['do_prune']))
|
|
{
|
|
$msg = $for->forumPrune($_POST['prune_type'], $_POST['prune_days'], $_POST['pruneForum']);
|
|
$mes->addSuccess($msg);
|
|
$action = 'main';
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
|
|
}
|
|
|
|
|
|
if (isset($_POST['frsubmit']))
|
|
{
|
|
$guestrules = $tp->toDB($_POST['guestrules']);
|
|
$memberrules = $tp->toDB($_POST['memberrules']);
|
|
$adminrules = $tp->toDB($_POST['adminrules']);
|
|
if(!$sql->update("generic", "gen_chardata ='$guestrules', gen_intdata='".$_POST['guest_active']."' WHERE gen_type='forum_rules_guest' "))
|
|
{
|
|
$sql->insert("generic", "0, 'forum_rules_guest', '".time()."', 0, '', '".$_POST['guest_active']."', '$guestrules' ");
|
|
}
|
|
if(!$sql->update("generic", "gen_chardata ='$memberrules', gen_intdata='".$_POST['member_active']."' WHERE gen_type='forum_rules_member' "))
|
|
{
|
|
$sql->insert("generic", "0, 'forum_rules_member', '".time()."', 0, '', '".$_POST['member_active']."', '$memberrules' ");
|
|
}
|
|
if(!$sql->update("generic", "gen_chardata ='$adminrules', gen_intdata='".$_POST['admin_active']."' WHERE gen_type='forum_rules_admin' "))
|
|
{
|
|
$sql->insert("generic", "0, 'forum_rules_admin', '".time()."', 0, '', '".$_POST['admin_active']."', '$adminrules' ");
|
|
}
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
if (vartrue($delete) == 'main') {
|
|
if ($sql->delete('forum', "forum_id='$del_id' "))
|
|
{
|
|
$mes->addSuccess(LAN_DELETED);
|
|
}
|
|
else
|
|
{
|
|
$mes->addError(LAN_DELETED_FAILED);
|
|
}
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
|
|
if (vartrue($action) == 'create')
|
|
{
|
|
if ($sql->select('forum', '*', "forum_parent='0' "))
|
|
{
|
|
$forum->create_forums($sub_action, $id);
|
|
}
|
|
else
|
|
{
|
|
header('location:'.e_ADMIN.'forum.php');
|
|
exit;
|
|
}
|
|
}
|
|
|
|
if ($delete == 'cat')
|
|
{
|
|
if ($sql->delete('forum', "forum_id='$del_id' "))
|
|
{
|
|
$sql->delete('forum', "forum_parent='$del_id' ");
|
|
$mes->addSuccess(LAN_DELETED);
|
|
$action = 'main';
|
|
}
|
|
else
|
|
{
|
|
$mes->addError(LAN_DELETED_FAILED);
|
|
}
|
|
|
|
$ns->tablerender($caption, $mes->render().$text);
|
|
}
|
|
|
|
|
|
|
|
switch($action)
|
|
{
|
|
case 'delete':
|
|
$forum->delete_item(intval($sub_action));
|
|
break;
|
|
|
|
case 'cat':
|
|
$forum->create_parents($sub_action, $id);
|
|
break;
|
|
|
|
case 'order':
|
|
$forum->show_existing_forums($sub_action, $id, true);
|
|
break;
|
|
|
|
case 'opt':
|
|
$forum->show_prefs();
|
|
break;
|
|
|
|
case 'mods':
|
|
$forum->show_mods();
|
|
break;
|
|
|
|
case 'tools':
|
|
$forum->show_tools();
|
|
break;
|
|
|
|
case 'prune':
|
|
$forum->show_prune();
|
|
break;
|
|
|
|
case 'rules':
|
|
$forum->show_rules();
|
|
break;
|
|
|
|
case 'subs':
|
|
$forum->show_subs($sub_action);
|
|
break;
|
|
|
|
case 'sr':
|
|
$forum->show_reported($sub_action);
|
|
break;
|
|
}
|
|
|
|
|
|
if ($delete == 'reported')
|
|
{
|
|
$sql->delete("generic", "gen_id='$del_id' ");
|
|
$mes->addSuccess(LAN_DELETED);
|
|
}
|
|
|
|
|
|
if (!e_QUERY || $action == 'main')
|
|
{
|
|
$forum->show_existing_forums(vartrue($sub_action), vartrue($id));
|
|
}
|
|
|
|
require_once(e_ADMIN.'footer.php');
|
|
// function headerjs()
|
|
// {
|
|
// $e107 = e107::getInstance();
|
|
// $tp = e107::getParser();
|
|
|
|
// // These functions need to be removed and replaced with the generic jsconfirm() function.
|
|
// $headerjs = "<script type=\"text/javascript\">
|
|
// function confirm_(mode, forum_id, forum_name) {
|
|
// if (mode == 'sr') {
|
|
// return confirm(\"".$tp->toJS(FORLAN_117)."\");
|
|
// } else if(mode == 'parent') {
|
|
// return confirm(\"".$tp->toJS(FORLAN_81)." [ID: \" + forum_name + \"]\");
|
|
// } else {
|
|
// return confirm(\"".$tp->toJS(FORLAN_82)." [ID: \" + forum_name + \"]\");
|
|
// }
|
|
// }
|
|
// </script>";
|
|
// return $headerjs;
|
|
// }
|
|
|
|
function forum_admin_adminmenu()
|
|
{
|
|
global $forum;
|
|
global $action;
|
|
$forum->show_options($action);
|
|
}
|
|
|
|
|
|
|
|
|
|
class forumAdmin
|
|
{
|
|
|
|
function show_options($action)
|
|
{
|
|
|
|
$sql = e107::getDb();
|
|
if ($action == '') { $action = 'main'; }
|
|
|
|
// ##### Display options ---------------------------------------------------------------------------------------------------------
|
|
$var['main']['text'] = FORLAN_76;
|
|
$var['main']['link'] = e_SELF;
|
|
$var['cat']['text'] = FORLAN_83;
|
|
$var['cat']['link'] = e_SELF.'?cat';
|
|
if ($sql->select('forum', 'forum_id', "forum_parent='0' LIMIT 1"))
|
|
{
|
|
$var['create']['text'] = FORLAN_77;
|
|
$var['create']['link'] = e_SELF.'?create';
|
|
}
|
|
$var['order']['text'] = FORLAN_78;
|
|
$var['order']['link'] = e_SELF.'?order';
|
|
$var['opt']['text'] = LAN_PREFS;
|
|
$var['opt']['link'] = e_SELF.'?opt';
|
|
$var['prune']['text'] = LAN_PRUNE;
|
|
$var['prune']['link'] = e_SELF.'?prune';
|
|
$var['rules']['text'] = LAN_FORUM_0016;
|
|
$var['rules']['link'] = e_SELF.'?rules';
|
|
$var['sr']['text'] = FORLAN_116;
|
|
$var['sr']['link'] = e_SELF.'?sr';
|
|
$var['mods']['text'] = LAN_FORUM_2003;
|
|
$var['mods']['link'] = e_SELF.'?mods';
|
|
$var['tools']['text'] = FORLAN_153;
|
|
$var['tools']['link'] = e_SELF.'?tools';
|
|
|
|
show_admin_menu(FORLAN_7, $action, $var);
|
|
}
|
|
|
|
// Initial delete function. Determines which delete routine should be applied.
|
|
function delete_item($id)
|
|
{
|
|
// If a delete routine is cancelled, redirect back to forum listing
|
|
if($_POST['cancel'])
|
|
{
|
|
$this->show_existing_forums(vartrue($sub_action), vartrue($id));
|
|
return;
|
|
}
|
|
|
|
$sql = e107::getDb();
|
|
$id = (int)$id;
|
|
|
|
$confirm = isset($_POST['confirm']) ? true : false;
|
|
|
|
if($confirm)
|
|
{
|
|
e107::getRender()->tablerender('Forums', e107::getMessage()->render().$txt);
|
|
}
|
|
else
|
|
{
|
|
$this->delete_show_confirm($txt);
|
|
}
|
|
|
|
if($row = $sql->retrieve('forum', 'forum_parent, forum_sub', "forum_id = {$id}"))
|
|
{
|
|
$txt = "";
|
|
|
|
// is parent
|
|
if($row['forum_parent'] == 0)
|
|
{
|
|
$txt .= $this->delete_parent($id, $confirm);
|
|
}
|
|
// is subforum
|
|
elseif($row['forum_sub'] > 0)
|
|
{
|
|
$txt .= $this->delete_sub($id, $confirm);
|
|
}
|
|
// is forum
|
|
else
|
|
{
|
|
$txt .= $this->delete_forum($id, $confirm);
|
|
}
|
|
}
|
|
// forum_id not found, should not happen.
|
|
else
|
|
{
|
|
$this->show_existing_forums(vartrue($sub_action), vartrue($id));
|
|
return;
|
|
}
|
|
}
|
|
|
|
function delete_parent($id, $confirm = false)
|
|
{
|
|
$sql = e107::getDb();
|
|
$mes = e107::getMessage();
|
|
$ns = e107::getRender();
|
|
|
|
// check if parent contains forums and delete them if needed
|
|
if($sql->select('forum', 'forum_id', 'forum_parent = '.$id))
|
|
{
|
|
$fList = $sql->rows();
|
|
foreach($fList as $f)
|
|
{
|
|
$this->delete_forum($f['forum_id'], $confirm);
|
|
}
|
|
}
|
|
|
|
if($confirm)
|
|
{
|
|
if($sql->delete('forum', "forum_id = {$id}"))
|
|
{
|
|
$mes->addSuccess(LAN_DELETED);
|
|
}
|
|
else
|
|
{
|
|
$mes->addError(LAN_DELETED_FAILED);
|
|
}
|
|
}
|
|
}
|
|
|
|
// function deleteForum($forumId)
|
|
// {
|
|
// $sql = e107::getDb();
|
|
// $forumId = (int)$forumId;
|
|
|
|
// // Check for any sub forums
|
|
// if($sql->select('forum', 'forum_id', "forum_sub = {$forumId}"))
|
|
// {
|
|
// $list = $sql->rows();
|
|
// foreach($list as $f)
|
|
// {
|
|
// $ret .= $this->deleteForum($f['forum_id']);
|
|
// }
|
|
// }
|
|
// require_once(e_PLUGIN.'forum/forum_class.php');
|
|
// $f = new e107Forum;
|
|
// if($sql->delete('forum_thread', 'thread_id','thread_forum_id='.$forumId))
|
|
// {
|
|
// $list = $sql->rows();
|
|
// foreach($list as $t)
|
|
// {
|
|
// $f->threadDelete($t['thread_id'], false);
|
|
// }
|
|
// }
|
|
// return $sql->delete('forum', 'forum_id = '.$forumId);
|
|
// }
|
|
|
|
// delete forum
|
|
function delete_forum($id, $confirm = false)
|
|
{
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
$ns = e107::getRender();
|
|
$mes = e107::getMessage();
|
|
|
|
// check if forum contains subforums
|
|
if($sql->select('forum', 'forum_id', 'forum_sub = '.$id))
|
|
{
|
|
$fList = $sql->rows();
|
|
foreach($fList as $f)
|
|
{
|
|
$this->delete_sub($f['forum_id'], $confirm);
|
|
}
|
|
}
|
|
if($confirm)
|
|
{
|
|
if($this->deleteForum($id))
|
|
{
|
|
$mes->addSuccess(LAN_DELETED);
|
|
}
|
|
else
|
|
{
|
|
$mes->addError(LAN_DELETED_FAILED);
|
|
}
|
|
}
|
|
|
|
$sql->select('forum', 'forum_name, forum_threads, forum_replies', 'forum_id = '.$id);
|
|
$row = $sql->fetch();
|
|
|
|
$mes->addInfo("Forum {$id} [".$tp->toHTML($row['forum_name'])."] has {$row['forum_threads']} threads and {$row['forum_replies']} replies.");
|
|
}
|
|
|
|
function delete_sub($id, $confirm = FALSE)
|
|
{
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
$mes = e107::getMessage();
|
|
$ns = e107::getRender();
|
|
|
|
if($confirm)
|
|
{
|
|
if($this->deleteForum($id))
|
|
{
|
|
$mes->addSuccess(LAN_DELETED);
|
|
}
|
|
else
|
|
{
|
|
$mes->addError(LAN_DELETED);
|
|
}
|
|
}
|
|
|
|
$sql->select('forum', '*', 'forum_id = '.$id);
|
|
$row = $sql->fetch();
|
|
$mes->addInfo("Sub-forum {$id} [".$tp->toHTML($row['forum_name'])."] has {$row['forum_threads']} threads, {$row['forum_replies']} replies.");
|
|
}
|
|
|
|
function delete_show_confirm($message)
|
|
{
|
|
$mes = e107::getMessage();
|
|
|
|
$mes->addInfo($message);
|
|
|
|
$text = "
|
|
<form method='post' action='".e_SELF.'?'.e_QUERY."'>
|
|
<div align='center'>
|
|
".e107::getForm()->admin_button('confirm', LAN_UI_DELETE_LABEL, 'delete')."
|
|
".e107::getForm()->admin_button('cancel', LAN_CANCEL, 'cancel')."
|
|
</div>
|
|
</form>
|
|
";
|
|
e107::getRender()->tablerender('Forum'.SEP.'Delete forum(s)', $mes->render().$text);
|
|
}
|
|
|
|
function show_subs($id)
|
|
{
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
$ns = e107::getRender();
|
|
$frm = e107::getForm();
|
|
$txt = "
|
|
<form method='post' action='".e_SELF.'?'.e_QUERY."'>
|
|
<table class='table adminlist'>
|
|
<tr>
|
|
<td>".LAN_ID."</td>
|
|
<td>".LAN_NAME."</td>
|
|
<td>".LAN_DESCRIPTION."</td>
|
|
<td>".LAN_ORDER."</td>
|
|
<td>".LAN_DELETE."</td>
|
|
</tr>
|
|
";
|
|
if($sql->select('forum', 'forum_id, forum_name, forum_description, forum_order', "forum_sub = {$id} ORDER by forum_order ASC"))
|
|
{
|
|
$subList = $sql->db_getList();
|
|
foreach($subList as $sub)
|
|
{
|
|
$txt .= "
|
|
<tr>
|
|
<td style='vertical-align:top'>{$sub['forum_id']}</td>
|
|
<td style='vertical-align:top'><input class='tbox' type='text' name='subname[{$sub['forum_id']}]' value='{$sub['forum_name']}' size='30' maxlength='255' /></td>
|
|
<td style='vertical-align:top'><textarea cols='60' rows='2' class='tbox' name='subdesc[{$sub['forum_id']}]'>{$sub['forum_description']}</textarea></td>
|
|
<td style='vertical-align:top'><input class='tbox' type='text' name='suborder[{$sub['forum_id']}]' value='{$sub['forum_order']}' size='3' maxlength='4' /></td>
|
|
<td style='vertical-align:top; text-align:center'>
|
|
<a href='".e_SELF."?delete.{$sub['forum_id']}'>".ADMIN_DELETE_ICON."</a>
|
|
</td>
|
|
</tr>
|
|
";
|
|
}
|
|
$txt .= "
|
|
<tr>
|
|
<td colspan='5' style='text-align:center'>".$frm->admin_button('update_subs', LAN_UPDATE, 'update')."</td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan='5' style='text-align:center'> </td>
|
|
</tr>
|
|
";
|
|
|
|
}
|
|
else
|
|
{
|
|
$txt .= "<tr><td colspan='5' style='text-align:center'>".FORLAN_146."</td>";
|
|
}
|
|
|
|
$txt .= "
|
|
<tr>
|
|
<td>".LAN_ID."</td>
|
|
<td>".LAN_NAME."</td>
|
|
<td>".LAN_DESCRIPTION."</td>
|
|
<td>".LAN_ORDER."</td>
|
|
<td> </td>
|
|
</tr>
|
|
<tr>
|
|
<td style='vertical-align:top'> </td>
|
|
<td><input class='tbox' type='text' name='subname_new' value='' size='30' maxlength='255' /></td>
|
|
<td><textarea cols='60' rows='2' class='tbox' name='subdesc_new'></textarea></td>
|
|
<td><input class='tbox' type='text' name='suborder_new' value='' size='3' maxlength='4' /></td>
|
|
<td> </td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan='5' style='text-align:center'>".$frm->admin_button('create_sub', LAN_CREATE, 'submit')."</td>
|
|
</tr>
|
|
</table>
|
|
</form>";
|
|
|
|
$ns->tablerender(LAN_FORUM_0069, $txt);
|
|
}
|
|
|
|
function show_existing_forums($sub_action, $id, $mode = false)
|
|
{
|
|
global $for; // $e107
|
|
$frm = e107::getForm();
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
$mes = e107::getMessage();
|
|
$ns = e107::getRender();
|
|
|
|
$subList = $for->forumGetSubs();
|
|
|
|
if (!$mode)
|
|
{
|
|
$text = "<div style='padding : 1px; margin-left: auto; margin-right: auto; text-align: center;'>";
|
|
}
|
|
else
|
|
{
|
|
$text = "<form method='post' action='".e_SELF."?".e_QUERY."'>";
|
|
}
|
|
|
|
if (!$parent_amount = $sql->select('forum', '*', "forum_parent='0' ORDER BY forum_order ASC"))
|
|
{
|
|
//$text .= "<tr><td style='text-align:center' colspan='3'>".FORLAN_29."</td></tr>";
|
|
$mes->addInfo(FORLAN_29);
|
|
}
|
|
else
|
|
{
|
|
$text .= "
|
|
<table class='table adminlist'>
|
|
<tr>
|
|
<th colspan='2'>".LAN_FORUM_1001."</th>
|
|
<th>".LAN_OPTIONS."</th>
|
|
</tr>";
|
|
while ($row = $sql->fetch())
|
|
{
|
|
$parentList[] = $row;
|
|
}
|
|
foreach($parentList as $parent)
|
|
{
|
|
$text .= "
|
|
<tr>
|
|
<td colspan='2'>".$parent['forum_name']."
|
|
<br /><b>".FORLAN_140.":</b> ".e107::getUserClass()->uc_get_classname($parent['forum_class'])." <b>".LAN_FORUM_2015.":</b> ".e107::getUserClass()->uc_get_classname($parent['forum_postclass'])."
|
|
</td>";
|
|
|
|
$text .= "<td style='text-align:center'>";
|
|
|
|
if ($mode)
|
|
{
|
|
$text .= "<select name='forum_order[]' class='tbox'>\n";
|
|
for($a = 1; $a <= $parent_amount; $a++)
|
|
{
|
|
$text .= ($parent['forum_order'] == $a ? "<option value='{$parent['forum_id']}.{$a}' selected='selected'>$a</option>\n" : "<option value='{$parent['forum_id']}.{$a}'>$a</option>\n");
|
|
}
|
|
$text .= "</select>";
|
|
}
|
|
else
|
|
{
|
|
$text .= "
|
|
<div style='text-align:left; padding-left: 30px'>
|
|
<a class='btn btn-default ' href='".e_SELF."?cat.edit.{$parent['forum_id']}'>".ADMIN_EDIT_ICON."</a>
|
|
<a class='btn btn-default ' href='".e_SELF."?delete.{$parent['forum_id']}'>".ADMIN_DELETE_ICON."</a>
|
|
</div>
|
|
";
|
|
}
|
|
$text .= "</td></tr>";
|
|
|
|
$forumCount = $sql->select('forum', '*', "forum_parent='".$parent['forum_id']."' AND forum_sub = 0 ORDER BY forum_order ASC");
|
|
if (!$forumCount)
|
|
{
|
|
$text .= "<td colspan='4' style='text-align:center'>".FORLAN_29."</td>";
|
|
}
|
|
else
|
|
{
|
|
$forumList = array();
|
|
while ($row = $sql->fetch())
|
|
{
|
|
$forumList[] = $row;
|
|
}
|
|
foreach($forumList as $forum)
|
|
{
|
|
$text .= "
|
|
<tr>
|
|
<td style='width:5%; text-align:center'>".IMAGE_new."</td>\n<td style='width:55%'><a href='".e107::getUrl()->create('forum/forum/view', $forum)."'>".$tp->toHTML($forum['forum_name'])."</a>";
|
|
// <td style='width:5%; text-align:center'>".IMAGE_new."</td>\n<td style='width:55%'><a href='".e_PLUGIN."forum/forum_viewforum.php?{$forum['forum_id']}'>".$tp->toHTML($forum['forum_name'])."</a>";
|
|
|
|
$text .= "
|
|
<br /><span class='smallblacktext'>".$tp->toHTML($forum['forum_description'])." </span>
|
|
<br /><b>".FORLAN_140.":</b> ".e107::getUserClass()->uc_get_classname($forum['forum_class'])." <b>".LAN_FORUM_2015.":</b> ".e107::getUserClass()->uc_get_classname($forum['forum_postclass'])."
|
|
|
|
</td>
|
|
|
|
<td colspan='2' style='text-align:center'>";
|
|
|
|
if ($mode)
|
|
{
|
|
$text .= "<select name='forum_order[]' class='tbox'>\n";
|
|
for($a = 1; $a <= $forumCount; $a++)
|
|
{
|
|
$sel = ($forum['forum_order'] == $a ? "selected='selected'" : '');
|
|
$text .= "<option value='{$forum['forum_id']}.{$a}' {$sel}>{$a}</option>\n";
|
|
}
|
|
$text .= "</select>";
|
|
}
|
|
else
|
|
{
|
|
//$sub_img = count($subList[$forum['forum_parent']][$forum['forum_id']]) ? IMAGE_sub : IMAGE_nosub;
|
|
$sub_img = ADMIN_DOWN_ICON;
|
|
$sub_total = count($subList[$forum['forum_parent']][$forum['forum_id']]);
|
|
$text .= "
|
|
<div style='text-align:left; padding-left: 30px'>
|
|
<a class='btn btn-default e-tip' href='".e_SELF."?create.edit.{$forum['forum_id']}' title=\"".LAN_EDIT."\">".ADMIN_EDIT_ICON."</a>
|
|
<a class='btn btn-default e-tip' href='".e_SELF."?delete.{$forum['forum_id']}' title=\"".LAN_DELETE."\">".ADMIN_DELETE_ICON."</a>
|
|
<a class='btn btn-default e-tip' href='".e_SELF."?subs.{$forum['forum_id']}' title='Create Sub-Forum. Total: {$sub_total}'>".$sub_img."</a>
|
|
</div>
|
|
";
|
|
}
|
|
$text .= "</td>\n</tr>";
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!$mode)
|
|
{
|
|
$text .= "</table></div>";
|
|
$ns->tablerender(FORLAN_30, $mes->render() . $text);
|
|
}
|
|
else
|
|
{
|
|
$text .= "</table><div class='buttons-bar center'>".$frm->admin_button('update_order', LAN_UPDATE, 'update')."</div></form>";
|
|
$ns->tablerender(LAN_ORDER, $mes->render() . $text);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
function create_parents($sub_action, $id)
|
|
{
|
|
$frm = e107::getForm();
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
$ns = e107::getRender();
|
|
|
|
$id = (int)$id;
|
|
if ($sub_action == 'edit' && !$_POST['update_parent'])
|
|
{
|
|
if ($sql->select('forum', '*', "forum_id=$id"))
|
|
{
|
|
$row = $sql->fetch();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$row = array();
|
|
$row['forum_name'] = '';
|
|
$row['forum_class'] = e_UC_PUBLIC;
|
|
$row['forum_postclass'] = e_UC_MEMBER;
|
|
$row['forum_threadclass'] = e_UC_MEMBER;
|
|
}
|
|
|
|
$text = "
|
|
<form method='post' action='".e_SELF.'?'.e_QUERY."'>
|
|
<table class='table adminform'>
|
|
<colgroup>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tr>
|
|
<td>".LAN_NAME.":</td>
|
|
<td><input class='tbox' type='text' name='forum_name' size='60' value='".$tp->toForm($row['forum_name'])."' maxlength='250' /></td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_23.":</td>
|
|
<td>".e107::getUserClass()->uc_dropdown('forum_class', $row['forum_class'], 'nobody,public,member,admin,classes')."<span class='field-help'>".FORLAN_24."</span></td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_142.":</td>
|
|
<td>".e107::getUserClass()->uc_dropdown("forum_postclass", $row['forum_postclass'], 'nobody,public,member,admin,classes')."<span class='field-help'>".FORLAN_143."</span></td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_184.":</td>
|
|
<td>".e107::getUserClass()->uc_dropdown('forum_threadclass', $row['forum_threadclass'], 'nobody,public,member,admin,classes')."<span class='field-help'>".FORLAN_185."</span></td>
|
|
</tr>
|
|
</table>
|
|
<div class='buttons-bar center'>";
|
|
if ($sub_action == 'edit')
|
|
{
|
|
$text .= $frm->admin_button('update_parent', LAN_UPDATE, 'update');
|
|
}
|
|
else
|
|
{
|
|
$text .= $frm->admin_button('submit_parent', LAN_CREATE, 'submit');
|
|
}
|
|
$text .= "
|
|
</div>
|
|
</form>";
|
|
|
|
$ns->tablerender(FORLAN_75, $text);
|
|
}
|
|
|
|
function create_forums($sub_action, $id)
|
|
{
|
|
//global $e107;
|
|
$frm = e107::getForm();
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
$ns = e107::getRender();
|
|
|
|
$id = (int)$id;
|
|
if ($sub_action == 'edit' && !$_POST['update_forum'])
|
|
{
|
|
if ($sql->select('forum', '*', "forum_id=$id"))
|
|
{
|
|
$fInfo = $sql->fetch();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$fInfo = array(
|
|
'forum_parent' => 0,
|
|
'forum_moderators' => e_UC_ADMIN,
|
|
'forum_class' => e_UC_PUBLIC,
|
|
'forum_postclass' => e_UC_MEMBER,
|
|
'forum_threadclass' => e_UC_MEMBER
|
|
);
|
|
}
|
|
|
|
$text = "
|
|
<form method='post' action='".e_SELF.'?'.e_QUERY."'>\n
|
|
<table class='table adminform'>
|
|
<colgroup>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tr>
|
|
<td>".LAN_FORUM_0004.":</td>
|
|
<td>";
|
|
|
|
$sql->select('forum', '*', 'forum_parent=0');
|
|
$text .= "<select name='forum_parent' class='tbox'>\n";
|
|
while (list($fid, $fname) = $sql->fetch('num'))
|
|
{
|
|
$sel = ($fid == vartrue($fInfo['forum_parent']) ? "selected='selected'" : '');
|
|
$text .= "<option value='{$fid}' {$sel}>{$fname}</option>\n";
|
|
}
|
|
$text .= "</select>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".LAN_NAME.":</td>
|
|
<td><input class='tbox' type='text' name='forum_name' size='60' value='".$tp->toForm(vartrue($fInfo['forum_name']))."' maxlength='250' /><span class='field-help'>".FORLAN_179."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".LAN_DESCRIPTION.":</td>
|
|
<td><textarea class='tbox' name='forum_description' cols='50' rows='5'>".$tp->toForm(vartrue($fInfo['forum_description']))."</textarea></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".LAN_FORUM_2003.":</td>
|
|
<td>";
|
|
$text .= e107::getUserClass()->uc_dropdown('forum_moderators', $fInfo['forum_moderators'], 'admin,classes')."<span class='field-help'>".FORLAN_34."</span>";
|
|
$text .= "</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_23.":</td>
|
|
<td>".e107::getUserClass()->uc_dropdown('forum_class', $fInfo['forum_class'], 'nobody,public,member,admin,classes')."<span class='field-help'>".FORLAN_24."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_142.":</td>
|
|
<td>".e107::getUserClass()->uc_dropdown('forum_postclass', $fInfo['forum_postclass'], 'nobody,public,member,admin,classes')."<span class='field-help'>".FORLAN_143."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_184.":</td>
|
|
<td>".e107::getUserClass()->uc_dropdown('forum_threadclass', $fInfo['forum_threadclass'], 'nobody,public,member,admin,classes')."<span class='field-help'>".FORLAN_185."</span></td>
|
|
</tr>
|
|
</table>
|
|
|
|
<div class='buttons-bar center'>";
|
|
if ($sub_action == "edit")
|
|
{
|
|
$text .= $frm->admin_button('update_forum', LAN_UPDATE, 'update');
|
|
}
|
|
else
|
|
{
|
|
$text .= $frm->admin_button('submit_forum', LAN_CREATE, 'submit');
|
|
}
|
|
$text .= "
|
|
</div>
|
|
</form>
|
|
";
|
|
$ns->tablerender(LAN_FORUM_1001, $text);
|
|
}
|
|
|
|
|
|
// function show_message($message)
|
|
// {
|
|
|
|
// e107::getRender();->tablerender('', $message);
|
|
// }
|
|
|
|
|
|
function show_tools()
|
|
{
|
|
$sql = e107::getDb();
|
|
$ns = e107::getRender();
|
|
$tp = e107::getParser();
|
|
$frm = e107::getForm();
|
|
|
|
$txt = "
|
|
<form method='post' action='".e_SELF."?".e_QUERY."'>
|
|
<table class='table adminlist'>
|
|
<colgroup span='2'>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tr>
|
|
<td>".FORLAN_156."</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
";
|
|
if($sql->select("forum", "*", "1 ORDER BY forum_order"))
|
|
{
|
|
$fList = $sql->db_getList();
|
|
foreach($fList as $f)
|
|
{
|
|
$txt .= "<input type='checkbox' name='forumlist[{$f['forum_id']}]' value='1' /> ".$tp->toHTML($f['forum_name'])."<br />";
|
|
}
|
|
$txt .= "<input type='checkbox' name='forum_all' value='1' /> <strong>".LAN_PLUGIN_FORUM_ALLFORUMS."</strong>";
|
|
}
|
|
$txt .= "
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_158."</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<input type='checkbox' name='lastpost' value='1' /> ".FORLAN_159." <br />
|
|
<input type='checkbox' name='lastpost_nothread' value='1' checked='checked' /> ".FORLAN_160."
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_161."</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<input type='checkbox' name='counts' value='1' /> ".FORLAN_162."<br />
|
|
<input type='checkbox' name='counts_threads' value='1' /><span style='text-align: center'> ".FORLAN_182."<br />".FORLAN_183."</span><br />
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_163."</td>
|
|
</tr>
|
|
<tr>
|
|
<td><input type='checkbox' name='userpostcounts' value='1' /> ".FORLAN_164."<br /></td>
|
|
</tr>
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('tools', LAN_GO, 'submit')."
|
|
</div>
|
|
</form>
|
|
";
|
|
$ns->tablerender(FORLAN_166, $txt);
|
|
}
|
|
|
|
function show_prefs()
|
|
{
|
|
global $fPref;
|
|
$ns = e107::getRender();
|
|
$sql = e107::getDb();
|
|
//$e107 = e107::getInstance();
|
|
$frm = e107::getForm();
|
|
$mes = e107::getMessage();
|
|
|
|
$poll_installed = e107::isInstalled('poll');
|
|
|
|
|
|
if(!$poll_installed)
|
|
{
|
|
if($fPref->get('poll') == 1)
|
|
{
|
|
$fPref['forum_poll'] = e_UC_NOBODY;
|
|
$fPref->save(false, true);
|
|
}
|
|
}
|
|
|
|
$text = "
|
|
<form method='post' action='".e_SELF."?".e_QUERY."'>\n
|
|
<table class='table adminform'>
|
|
<colgroup span='2'>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tr>
|
|
<td>".FORLAN_44.":</td>
|
|
<td>".($fPref->get('enclose') ? "<input type='checkbox' name='forum_enclose' value='1' checked='checked' />" : "<input type='checkbox' name='forum_enclose' value='1' />")."<span class='field-help'>".FORLAN_45."</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_65.":</td>
|
|
<td><input class='tbox' type='text' name='forum_title' size='15' value='".$fPref->get('title')."' maxlength='100' /></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_47.":</td>
|
|
<td>".($fPref->get('notify') ? "<input type='checkbox' name='email_notify' value='1' checked='checked' />" : "<input type='checkbox' name='email_notify' value='1' />")."<span class='field-help'>".FORLAN_48."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_177.":</td>
|
|
<td>".($fPref->get('notify_on') ? "<input type='checkbox' name='email_notify_on' value='1' checked='checked' />" : "<input type='checkbox' name='email_notify_on' value='1' />")."<span class='field-help'>".FORLAN_178."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_49.":</td>";
|
|
if($poll_installed)
|
|
{
|
|
//<td>".e107::getUserClass()->uc_dropdown("mods[{$f['forum_id']}]", $f['forum_moderators'], 'admin,classes')."</td>
|
|
$text .= "<td>".e107::getUserClass()->uc_dropdown('forum_poll', $fPref->get('poll'), 'nobody,public,member,admin,main,classes').'<span class="field-help">'.FORLAN_50.'</span></td>';
|
|
}
|
|
else
|
|
{
|
|
$text .= "<td>".FORLAN_66."</td>";
|
|
}
|
|
$text .= "
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_70.":";
|
|
|
|
if(!$pref['image_post'])
|
|
{
|
|
$text .= "<br /><b>".FORLAN_139."</b>"; //
|
|
}
|
|
if(!is_writable(e_PLUGIN.'forum/attachments'))
|
|
{
|
|
$text .= "<br /><b>Attachment dir (".e_PLUGIN_ABS.'forum/attachments'.") is not writable!</b>"; //
|
|
}
|
|
|
|
$text .= "</td>
|
|
<td>".($fPref->get('attach') ? "<input type='checkbox' name='forum_attach' value='1' checked='checked' />" : "<input type='checkbox' name='forum_attach' value='1' />")."<span class='field-help'>".FORLAN_71." <a href='".e_ADMIN."upload.php'>".FORLAN_130."</a> ". FORLAN_131."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_134.":</td>
|
|
<td><input class='tbox' type='text' size='3' maxlength='5' name='forum_maxwidth' value='".$fPref->get('maxwidth')."' /><span class='field-help'>".FORLAN_135."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_136.":</td>
|
|
<td>".($fPref->get('linkimg') ? "<input type='checkbox' name='forum_linkimg' value='1' checked='checked' />" : "<input type='checkbox' name='forum_linkimg' value='1' />")."<span class='field-help'>".FORLAN_137."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_51.":</td>
|
|
<td>".($fPref->get('track') ? "<input type='checkbox' name='forum_track' value='1' checked='checked' />" : "<input type='checkbox' name='forum_track' value='1' />")."<span class='field-help'>".FORLAN_52."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_112.":</td>
|
|
<td>".($fPref->get('redirect') ? "<input type='checkbox' name='forum_redirect' value='1' checked='checked' />" : "<input type='checkbox' name='forum_redirect' value='1' />")."<span class='field-help'>".FORLAN_113."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_116.":</td>
|
|
<td>".($fPref->get('reported_post_email') ? "<input type='checkbox' name='reported_post_email' value='1' checked='checked' />" : "<input type='checkbox' name='reported_post_email' value='1' />")."<span class='field-help'>".FORLAN_122."</span></td>
|
|
</tr>
|
|
|
|
|
|
<tr>
|
|
<td>".FORLAN_126.":</td>
|
|
<td>".($fPref->get('forum_tooltip') ? "<input type='checkbox' name='forum_tooltip' value='1' checked='checked' />" : "<input type='checkbox' name='forum_tooltip' value='1' />")."<span class='field-help'>".FORLAN_127."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_128.":</td>
|
|
<td><input class='tbox' type='text' name='forum_tiplength' size='15' value='".$fPref->get('tiplength')."' maxlength='20' /><span class='field-help'>".FORLAN_129."</span></td>
|
|
</tr>
|
|
|
|
|
|
<tr>
|
|
<td>".FORLAN_53.":</td>
|
|
<td><input class='tbox' type='text' name='forum_eprefix' size='15' value='".$fPref->get('eprefix')."' maxlength='20' /><span class='field-help'>".FORLAN_54."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_55.":</td>
|
|
<td><input class='tbox' type='text' name='forum_popular' size='3' value='".$fPref->get('popular')."' maxlength='3' /><span class='field-help'>".FORLAN_56."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_57.":</td>
|
|
<td><input class='tbox' type='text' name='forum_postspage' size='3' value='".$fPref->get('postspage')."' maxlength='3' /><span class='field-help'>".FORLAN_58."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_186.":</td>
|
|
<td><input class='tbox' type='text' name='forum_threadspage' size='3' value='".$fPref->get('threadspage')."' maxlength='3' /><span class='field-help'>".FORLAN_187."</span></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_132.":</td>
|
|
<td>".($fPref->get('hilightsticky') ? "<input type='checkbox' name='forum_hilightsticky' value='1' checked='checked' />" : "<input type='checkbox' name='forum_hilightsticky' value='1' />")."<span class='field-help'>".FORLAN_133."</span></td>
|
|
</tr>
|
|
</table>
|
|
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('updateoptions', LAN_UPDATE, 'update')."
|
|
</div>
|
|
</form>
|
|
";
|
|
$ns->tablerender(FORLAN_7, $mes->render() . $text);
|
|
}
|
|
|
|
function show_reported($sub_action)
|
|
{
|
|
$rs = new form;
|
|
$sql = e107::getDb();
|
|
$ns = e107::getRender();
|
|
$tp = e107::getParser();
|
|
$mes = e107::getMessage();
|
|
|
|
if ($sub_action) {
|
|
$sql->select("generic", "*", "gen_id='".$sub_action."'");
|
|
$row = $sql->fetch();
|
|
$sql->select("user", "*", "user_id='". $row['gen_user_id']."'");
|
|
$user = $sql->fetch();
|
|
//$con = new convert;
|
|
$text = "
|
|
<table class='table adminlist'>
|
|
<colgroup span='2'>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tr>
|
|
<td>".FORLAN_171.":</td>
|
|
<td><a href='".e_PLUGIN_ABS."forum/forum_viewtopic.php?".$row['gen_intdata'].".post' rel='external'>#".$row['gen_intdata']."</a></td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_173.":</td>
|
|
<td>".$row['gen_ip']."</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_174.":</td>
|
|
<td><a href='".e107::getUrl()->create('user/profile/view', $user)."'>".$user['user_name']."</a>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".FORLAN_175.":</td>
|
|
<td>".e107::getDate()->convert_date($row['gen_datestamp'], "long")."</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".LAN_FORUM_2046.":</td>
|
|
<td>".$row['gen_chardata']."</td>
|
|
</tr>
|
|
<tr>
|
|
<td style='text-align:center' colspan='2'>
|
|
".$rs->form_open("post", e_SELF."?sr", "", "", "", " onsubmit=\"return confirm_('sr',".$row['gen_datestamp'].")\"")."
|
|
".$rs->form_button("submit", "delete[reported_{$row['gen_id']}]", FORLAN_172)."
|
|
".$rs->form_close()."
|
|
</td>
|
|
</tr>
|
|
</table>";
|
|
|
|
$ns->tablerender(FORLAN_116, $text);
|
|
|
|
}
|
|
else
|
|
{
|
|
if ($reported_total = $sql->select("generic", "*", "gen_type='reported_post' OR gen_type='Reported Forum Post'"))
|
|
{
|
|
$text = "
|
|
<table class='table adminlist'>
|
|
<tr>
|
|
<td>".FORLAN_170."</td>
|
|
<td>".LAN_OPTIONS."</td>
|
|
</tr>";
|
|
while ($row = $sql->fetch())
|
|
{
|
|
$text .= "
|
|
<tr>
|
|
<td<a href='".e_SELF."?sr.".$row['gen_id']."'>".FORLAN_171." #".$row['gen_intdata']."</a></td>
|
|
<td text-align:center; vertical-align:top; white-space: nowrap'>
|
|
".$rs->form_open("post", e_SELF."?sr", "", "", "", " onsubmit=\"return confirm_('sr',".$row['gen_datestamp'].")\"")."
|
|
".$rs->form_button("submit", "delete[reported_{$row['gen_id']}]", FORLAN_172)."
|
|
".$rs->form_close()."
|
|
</td>
|
|
</tr>";
|
|
}
|
|
$text .= "</table>";
|
|
}
|
|
else
|
|
{
|
|
//$text = "<div style='text-align:center'>".FORLAN_121."</div>";
|
|
$mes->addInfo(FORLAN_121);
|
|
}
|
|
$ns->tablerender(FORLAN_116, $mes->render().$text);
|
|
}
|
|
}
|
|
|
|
function show_prune()
|
|
{
|
|
$ns = e107::getRender();
|
|
$sql = e107::getDB();
|
|
$frm = e107::getForm();
|
|
|
|
// $sql->select("forum", "forum_id, forum_name", "forum_parent!=0 ORDER BY forum_order ASC");
|
|
$qry = "
|
|
SELECT f.forum_id, f.forum_name, sp.forum_name AS sub_parent, fp.forum_name AS forum_parent
|
|
FROM #forum AS f
|
|
LEFT JOIN #forum AS sp ON sp.forum_id = f.forum_sub
|
|
LEFT JOIN #forum AS fp ON fp.forum_id = f.forum_parent
|
|
WHERE f.forum_parent != 0
|
|
ORDER BY f.forum_parent ASC, f.forum_sub, f.forum_order ASC
|
|
";
|
|
$sql->gen($qry);
|
|
$forums = $sql->db_getList();
|
|
|
|
$text = "
|
|
<form method='post' action='".e_SELF."?".e_QUERY."'>\n
|
|
<table class='table adminlist'>
|
|
<tr>
|
|
<td>".FORLAN_60."</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_87." <input class='tbox' type='text' name='prune_days' size='6' value='' maxlength='3' /></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_2."<br />
|
|
".FORLAN_89." <input type='radio' name='prune_type' value='delete' />
|
|
".FORLAN_90." <input type='radio' name='prune_type' value='make_inactive' checked='checked' />
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".FORLAN_138.": <br />";
|
|
|
|
foreach($forums as $forum)
|
|
{
|
|
$for_name = $forum['forum_parent']." -> ";
|
|
$for_name .= ($forum['sub_parent'] ? $forum['sub_parent']." -> " : "");
|
|
$for_name .= $forum['forum_name'];
|
|
$text .= "<input type='checkbox' name='pruneForum[]' value='".$forum['forum_id']."' /> ".$for_name."<br />";
|
|
}
|
|
|
|
|
|
$text .= "
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('do_prune', LAN_PRUNE, 'submit')."
|
|
</div>
|
|
</form>";
|
|
$ns->tablerender(LAN_PRUNE, $text);
|
|
}
|
|
|
|
|
|
function show_mods()
|
|
{
|
|
global $for;
|
|
$ns = e107::getRender();
|
|
$sql = e107::getDB();
|
|
//$e107 = e107::getInstance();
|
|
$forumList = $for->forum_getforums('all');
|
|
$parentList = $for->forum_getparents('list');
|
|
$subList = $for->forumGetSubs('bysub');
|
|
$frm = e107::getForm();
|
|
$tp = e107::getParser();
|
|
|
|
$txt = "<form method='post' action='".e_SELF."?".e_QUERY."'>
|
|
<table class='table adminlist'>
|
|
<colgroup span='2'>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>";
|
|
|
|
foreach($parentList as $p)
|
|
{
|
|
$txt .= "
|
|
<tr>
|
|
<td colspan='2' ><strong>".$tp->toHTML($p['forum_name'])."</strong></td>
|
|
</tr>
|
|
";
|
|
|
|
foreach($forumList[$p['forum_id']] as $f)
|
|
{
|
|
$txt .= "
|
|
<tr>
|
|
<td>{$f['forum_name']}</td>
|
|
<td>".e107::getUserClass()->uc_dropdown("mods[{$f['forum_id']}]", $f['forum_moderators'], 'admin,classes')."</td>
|
|
</tr>
|
|
";
|
|
foreach($subList[$f['forum_id']] as $s)
|
|
{
|
|
$txt .= "
|
|
<tr>
|
|
<td> {$s['forum_name']}</td>
|
|
<td>".e107::getUserClass()->uc_dropdown("mods[{$s['forum_id']}]", $s['forum_moderators'], 'admin,classes')."</td>
|
|
</tr>
|
|
";
|
|
}
|
|
}
|
|
}
|
|
$txt .= "
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('setMods', LAN_UPDATE, 'update')."
|
|
</div>
|
|
</form>";
|
|
$ns->tablerender(LAN_FORUM_2003, $txt);
|
|
}
|
|
*/
|
|
//
|
|
/*
|
|
function show_rules()
|
|
{
|
|
$pref = e107::getPref();
|
|
$ns = e107::getRender();
|
|
$sql = e107::getDB();
|
|
$tp = e107::getParser();
|
|
$frm = e107::getForm();
|
|
*/
|
|
/*
|
|
$sql->select("wmessage");
|
|
list($null) = $sql->fetch();
|
|
list($null) = $sql->fetch();
|
|
list($null) = $sql->fetch();
|
|
list($id, $guestrules, $wm_active4) = $sql->fetch();
|
|
list($id, $memberrules, $wm_active5) = $sql->fetch();
|
|
list($id, $adminrules, $wm_active6) = $sql->fetch();
|
|
*/
|
|
|
|
/*
|
|
if($sql->select('generic','*',"gen_type='forum_rules_guest'"))
|
|
{
|
|
$guest_rules = $sql->fetch();
|
|
}
|
|
if($sql->select('generic','*',"gen_type='forum_rules_member'"))
|
|
{
|
|
$member_rules = $sql->fetch();
|
|
}
|
|
if($sql->select('generic','*',"gen_type='forum_rules_admin'"))
|
|
{
|
|
$admin_rules = $sql->fetch();
|
|
}
|
|
|
|
$guesttext = $tp->toForm(vartrue($guest_rules['gen_chardata']));
|
|
$membertext = $tp->toForm(vartrue($member_rules['gen_chardata']));
|
|
$admintext = $tp->toForm(vartrue($admin_rules['gen_chardata']));
|
|
|
|
$text = "
|
|
<form method='post' action='".e_SELF."?rules' id='wmform'>
|
|
<table class='table adminform'>
|
|
<colgroup span='2'>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tr>
|
|
<td>".WMGLAN_1.": <br />
|
|
".WMGLAN_6.":";
|
|
if (vartrue($guest_rules['gen_intdata']))
|
|
{
|
|
$text .= "<input type='checkbox' name='guest_active' value='1' checked='checked' />";
|
|
}
|
|
else
|
|
{
|
|
$text .= "<input type='checkbox' name='guest_active' value='1' />";
|
|
}
|
|
$text .= "</td>
|
|
|
|
<td>
|
|
".$frm->bbarea('guestrules', $guesttext)."
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".WMGLAN_2.": <br />
|
|
".WMGLAN_6.":";
|
|
if (vartrue($member_rules['gen_intdata']))
|
|
{
|
|
$text .= "<input type='checkbox' name='member_active' value='1' checked='checked' />";
|
|
}
|
|
else
|
|
{
|
|
$text .= "<input type='checkbox' name='member_active' value='1' />";
|
|
}
|
|
$text .= "</td>
|
|
|
|
<td>
|
|
".$frm->bbarea('memberrules', $membertext)."
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".WMGLAN_3.": <br />
|
|
".WMGLAN_6.": ";
|
|
|
|
if (vartrue($admin_rules['gen_intdata']))
|
|
{
|
|
$text .= "<input type='checkbox' name='admin_active' value='1' checked='checked' />";
|
|
}
|
|
else
|
|
{
|
|
$text .= "<input type='checkbox' name='admin_active' value='1' />";
|
|
}
|
|
|
|
$text .= "</td>
|
|
<td>
|
|
".$frm->bbarea('adminrules', $admintext)."
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".$frm->admin_button('frsubmit', LAN_UPDATE, 'submit')."
|
|
</div>
|
|
</form>";
|
|
|
|
$ns->tablerender(WMGLAN_5, $text);
|
|
|
|
echo "
|
|
<script type=\"text/javascript\">
|
|
function addtext1(sc){
|
|
document.getElementById('wmform').guestrules.value += sc;
|
|
}
|
|
function addtext2(sc){
|
|
document.getElementById('wmform').memberrules.value += sc;
|
|
}
|
|
function addtext3(sc){
|
|
document.getElementById('wmform').adminrules.value += sc;
|
|
}
|
|
function help1(help){
|
|
document.getElementById('wmform').helpguest.value = help;
|
|
}
|
|
function help2(help){
|
|
document.getElementById('wmform').helpmember.value = help;
|
|
}
|
|
function help3(help){
|
|
document.getElementById('wmform').helpadmin.value = help;
|
|
}
|
|
</script>
|
|
";
|
|
|
|
}
|
|
}
|
|
*/
|
|
?>
|