1
0
mirror of https://github.com/e107inc/e107.git synced 2025-01-17 12:48:24 +01:00

Theme manager can now install theme-recommended plugins without leaving the page. Notice removal. theme.xml spec modified slightly, to allow themers to provide links to external URLs of 'required' plugins.

This commit is contained in:
CaMer0n 2009-07-14 03:18:17 +00:00
parent 0ef3c5d7cf
commit 364967b9c5
7 changed files with 203 additions and 127 deletions

View File

@ -11,8 +11,8 @@
| GNU General Public License (http://gnu.org). | GNU General Public License (http://gnu.org).
| |
| $Source: /cvs_backup/e107_0.8/e107_admin/notify.php,v $ | $Source: /cvs_backup/e107_0.8/e107_admin/notify.php,v $
| $Revision: 1.7 $ | $Revision: 1.8 $
| $Date: 2009-07-10 14:25:22 $ | $Date: 2009-07-14 03:18:16 $
| $Author: e107coders $ | $Author: e107coders $
+----------------------------------------------------------------------------+ +----------------------------------------------------------------------------+
*/ */
@ -71,21 +71,24 @@ class notify_config
$this -> notify_prefs = $eArrayStorage -> ReadArray($this -> notify_prefs); $this -> notify_prefs = $eArrayStorage -> ReadArray($this -> notify_prefs);
// load every e_notify.php file. // load every e_notify.php file.
foreach($pref['e_notify_list'] as $val) if($pref['e_notify_list'])
{ {
if (!isset($this -> notify_prefs['plugins'][$val])) foreach($pref['e_notify_list'] as $val)
{ {
$this -> notify_prefs['plugins'][$val] = TRUE; if (!isset($this -> notify_prefs['plugins'][$val]))
if (is_readable(e_PLUGIN.$val."/e_notify.php"))
{ {
require_once(e_PLUGIN.$val.'/e_notify.php'); $this -> notify_prefs['plugins'][$val] = TRUE;
foreach ($config_events as $event_id => $event_text) if (is_readable(e_PLUGIN.$val."/e_notify.php"))
{ {
$this -> notify_prefs['event'][$event_id] = array('class' => '255', 'email' => ''); require_once(e_PLUGIN.$val.'/e_notify.php');
foreach ($config_events as $event_id => $event_text)
{
$this -> notify_prefs['event'][$event_id] = array('class' => '255', 'email' => '');
}
$recalibrate = true;
} }
$recalibrate = true;
} }
} }
} }
@ -102,21 +105,15 @@ class notify_config
global $ns, $rs, $frm, $emessage; global $ns, $rs, $frm, $emessage;
$text = "<div style='text-align: center'> $text = "<div style='text-align: center'>
<div>".NT_LAN_2.":</div>
<form action='".e_SELF."?results' method='post' id='scanform'> <form action='".e_SELF."?results' method='post' id='scanform'>
<fieldset id='core-notify-config'> <fieldset id='core-notify-config'>
<legend>".NU_LAN_1."</legend>
<table cellpadding='0' cellspacing='0' class='adminform'> <table cellpadding='0' cellspacing='0' class='adminform'>
<colgroup span='2'> <colgroup span='2'>
<col class='col-label' /> <col class='col-label' />
<col class='col-control' /> <col class='col-control' />
</colgroup> </colgroup>
<thead>
<tr>
<th colspan='2'>".NT_LAN_2.":</th>
</tr>
</thead>";
$text .= "<tbody>
<tr><td colspan='2'>".NU_LAN_1."</td></tr>
"; ";
$text .= $this -> render_event('usersup', NU_LAN_2); $text .= $this -> render_event('usersup', NU_LAN_2);
@ -124,47 +121,67 @@ class notify_config
$text .= $this -> render_event('login', NU_LAN_4); $text .= $this -> render_event('login', NU_LAN_4);
$text .= $this -> render_event('logout', NU_LAN_5); $text .= $this -> render_event('logout', NU_LAN_5);
$text .= "<tr> $text .= "</table></fieldset>
<td colspan='2'>".NS_LAN_1."</td> <fieldset id='core-notify-2'>
</tr>"; <legend>".NS_LAN_1."</legend>
<table cellpadding='0' cellspacing='0' class='adminform'>
<colgroup span='2'>
<col class='col-label' />
<col class='col-control' />
</colgroup>";
$text .= $this -> render_event('flood', NS_LAN_2); $text .= $this -> render_event('flood', NS_LAN_2);
$text .= "<tr> $text .= "</table></fieldset>
<td colspan='2'>".NN_LAN_1."</td> <fieldset id='core-notify-3'>
</tr>"; <legend>".NN_LAN_1."</legend>
<table cellpadding='0' cellspacing='0' class='adminform'>
<colgroup span='2'>
<col class='col-label' />
<col class='col-control' />
</colgroup>";
$text .= $this -> render_event('subnews', NN_LAN_2); $text .= $this -> render_event('subnews', NN_LAN_2);
$text .= $this -> render_event('newspost', NN_LAN_3); $text .= $this -> render_event('newspost', NN_LAN_3);
$text .= $this -> render_event('newsupd', NN_LAN_4); $text .= $this -> render_event('newsupd', NN_LAN_4);
$text .= $this -> render_event('newsdel', NN_LAN_5); $text .= $this -> render_event('newsdel', NN_LAN_5);
$text .= "<tr> $text .= "</table></fieldset>
<td colspan='2'>".NF_LAN_1."</td> <fieldset id='core-notify-4'>
</tr>"; <legend>".NF_LAN_1."</legend>
<table cellpadding='0' cellspacing='0' class='adminform'>
<colgroup span='2'>
<col class='col-label' />
<col class='col-control' />
</colgroup>";
$text .= $this -> render_event('fileupload', NF_LAN_2); $text .= $this -> render_event('fileupload', NF_LAN_2);
$text .= "</table>";
foreach ($this -> notify_prefs['plugins'] as $plugin_id => $plugin_settings) foreach ($this -> notify_prefs['plugins'] as $plugin_id => $plugin_settings)
{ {
if(is_readable(e_PLUGIN.$plugin_id.'/e_notify.php')) if(is_readable(e_PLUGIN.$plugin_id.'/e_notify.php'))
{ {
require(e_PLUGIN.$plugin_id.'/e_notify.php'); require(e_PLUGIN.$plugin_id.'/e_notify.php');
$text .= "<tr> $text .= "</fieldset>
<td colspan='2'>".$config_category."</td> <fieldset id='core-notify-".str_replace(" ","_",$config_category)."'>
</tr>"; <legend>".$config_category."</legend>
<table cellpadding='0' cellspacing='0' class='adminform'>
<colgroup span='2'>
<col class='col-label' />
<col class='col-control' />
</colgroup>";
foreach ($config_events as $event_id => $event_text) foreach ($config_events as $event_id => $event_text)
{ {
$text .= $this -> render_event($event_id, $event_text); $text .= $this -> render_event($event_id, $event_text);
} }
$text .= "</table> ";
} }
} }
$text .= " </tr> $text .= "
</tbody>
</table>
<div class='buttons-bar center'>"; <div class='buttons-bar center'>";
$text .= $frm->admin_button('update', LAN_UPDATE,'update'); $text .= $frm->admin_button('update', LAN_UPDATE,'update');
$text .= " $text .= "

View File

@ -11,8 +11,8 @@
| GNU General Public License (http://gnu.org). | GNU General Public License (http://gnu.org).
| |
| $Source: /cvs_backup/e107_0.8/e107_admin/plugin.php,v $ | $Source: /cvs_backup/e107_0.8/e107_admin/plugin.php,v $
| $Revision: 1.30 $ | $Revision: 1.31 $
| $Date: 2009-07-13 09:31:19 $ | $Date: 2009-07-14 03:18:16 $
| $Author: e107coders $ | $Author: e107coders $
+----------------------------------------------------------------------------+ +----------------------------------------------------------------------------+
*/ */
@ -58,7 +58,7 @@ class pluginManager{
$tmp = explode('.', e_QUERY); $tmp = explode('.', e_QUERY);
$this -> action = ($tmp[0]) ? $tmp[0] : "installed"; $this -> action = ($tmp[0]) ? $tmp[0] : "installed";
$this -> id = intval($tmp[1]); $this -> id = varset($tmp[1]) ? intval($tmp[1]) : "";
$this-> fields = array( $this-> fields = array(
@ -147,12 +147,6 @@ class pluginManager{
$this -> pluginUpload(); $this -> pluginUpload();
} }
if($emessage->hasMessage) // Would prefer a method like this, but it doesn't work.
{
$emessage = &eMessage::getInstance();
$ns->tablerender(NWSLAN_4, $emessage->render());
}
if(isset($_POST['install-selected'])) if(isset($_POST['install-selected']))
{ {
foreach($_POST['plugin_checkbox'] as $val) foreach($_POST['plugin_checkbox'] as $val)
@ -672,7 +666,7 @@ class pluginManager{
global $plugin,$ns,$frm; global $plugin,$ns,$frm;
$text .= " $text = "
<form action='".e_SELF."?".e_QUERY."' id='pluginmanager_list' method='post'> <form action='".e_SELF."?".e_QUERY."' id='pluginmanager_list' method='post'>
<fieldset id='core-newspost-list'> <fieldset id='core-newspost-list'>
<legend class='e-hideme'>".NWSLAN_4."</legend> <legend class='e-hideme'>".NWSLAN_4."</legend>
@ -729,6 +723,8 @@ class pluginManager{
if (empty($pluginList)) return ''; if (empty($pluginList)) return '';
$text = "";
foreach($pluginList as $plug) foreach($pluginList as $plug)
{ {
$_path = e_PLUGIN.$plug['plugin_path'].'/'; $_path = e_PLUGIN.$plug['plugin_path'].'/';
@ -757,7 +753,7 @@ class pluginManager{
$plugAuthor = varset($plug_vars['author']['@attributes']['name'],''); $plugAuthor = varset($plug_vars['author']['@attributes']['name'],'');
$plugURL = varset($plug_vars['author']['@attributes']['url'],''); $plugURL = varset($plug_vars['author']['@attributes']['url'],'');
$plugReadme = ""; $plugReadme = "";
if($plug['plugin_installflag']) if(varset($plug['plugin_installflag']))
{ {
$plugName = "<a title='{$conf_title}' href='{$conf_file}' >".$tp->toHTML($plug['plugin_name'], false, "defs,emotes_off, no_make_clickable")."</a>"; $plugName = "<a title='{$conf_title}' href='{$conf_file}' >".$tp->toHTML($plug['plugin_name'], false, "defs,emotes_off, no_make_clickable")."</a>";
} }
@ -765,18 +761,18 @@ class pluginManager{
{ {
$plugName = $tp->toHTML($plug['plugin_name'], false, "defs,emotes_off, no_make_clickable"); $plugName = $tp->toHTML($plug['plugin_name'], false, "defs,emotes_off, no_make_clickable");
} }
if($plug_vars['readme']) // 0.7 plugin.php if(varset($plug_vars['readme'])) // 0.7 plugin.php
{ {
$plugReadme = $plug_vars['readme']; $plugReadme = $plug_vars['readme'];
} }
if($plug_vars['readMe']) // 0.8 plugin.xml if(varset($plug_vars['readMe'])) // 0.8 plugin.xml
{ {
$plugReadme = $plug_vars['readMe']; $plugReadme = $plug_vars['readMe'];
} }
$text .= "<tr>"; $text .= "<tr>";
if(is_array($this-> fields['plugin_checkboxes'])) if(varset($this-> fields['plugin_checkboxes']))
{ {
$rowid = "plugin_checkbox[".$plug['plugin_id']."]"; $rowid = "plugin_checkbox[".$plug['plugin_id']."]";
$text .= "<td class='center middle'>".$frm->checkbox($rowid, $plug['plugin_id'])."</td>\n"; $text .= "<td class='center middle'>".$frm->checkbox($rowid, $plug['plugin_id'])."</td>\n";
@ -793,7 +789,7 @@ class pluginManager{
$text .= (in_array("plugin_notes",$this->fieldpref)) ? "<td class='center middle'>".($plugReadme ? "<a href='".e_PLUGIN.$plug['plugin_path']."/".$plugReadme."' title='".$plugReadme."'><img src='".e_IMAGE_ABS."admin_images/info_16.png' alt='' style='border:0px' /></a>" : "&nbsp;")."</td>" : ""; $text .= (in_array("plugin_notes",$this->fieldpref)) ? "<td class='center middle'>".($plugReadme ? "<a href='".e_PLUGIN.$plug['plugin_path']."/".$plugReadme."' title='".$plugReadme."'><img src='".e_IMAGE_ABS."admin_images/info_16.png' alt='' style='border:0px' /></a>" : "&nbsp;")."</td>" : "";
$text .= (in_array("plugin_description",$this->fieldpref)) ? "<td class='middle'>".$tp->toHTML($plug_vars['description'], false, "defs,emotes_off, no_make_clickable")."</td>" : ""; $text .= (in_array("plugin_description",$this->fieldpref)) ? "<td class='middle'>".$tp->toHTML($plug_vars['description'], false, "defs,emotes_off, no_make_clickable")."</td>" : "";
$text .= (in_array("plugin_compatible",$this->fieldpref)) ? "<td class='center middle'>".varset($plug_vars['@attributes']['compatibility'],'')."</td>" : ""; $text .= (in_array("plugin_compatible",$this->fieldpref)) ? "<td class='center middle'>".varset($plug_vars['@attributes']['compatibility'],'')."</td>" : "";
$text .= (in_array("plugin_compliant",$this->fieldpref)) ? "<td class='center middle'>".(($plug_vars['compliant'] || $plug_vars['@attributes']['xhtmlcompliant']=="true") ? ADMIN_TRUE_ICON : "&nbsp;")."</td>" : ""; $text .= (in_array("plugin_compliant",$this->fieldpref)) ? "<td class='center middle'>".((varset($plug_vars['compliant']) || varsettrue($plug_vars['@attributes']['xhtmlcompliant'])) ? ADMIN_TRUE_ICON : "&nbsp;")."</td>" : "";
// Plugin options Column -------------- // Plugin options Column --------------

View File

@ -9,8 +9,8 @@
* Form Handler * Form Handler
* *
* $Source: /cvs_backup/e107_0.8/e107_handlers/form_handler.php,v $ * $Source: /cvs_backup/e107_0.8/e107_handlers/form_handler.php,v $
* $Revision: 1.30 $ * $Revision: 1.31 $
* $Date: 2009-07-08 06:58:00 $ * $Date: 2009-07-14 03:18:16 $
* $Author: e107coders $ * $Author: e107coders $
* *
*/ */
@ -583,7 +583,7 @@ class e_form
foreach($columnsArray as $key=>$fld) foreach($columnsArray as $key=>$fld)
{ {
if($fld['forced'] !== TRUE) if(!varset($fld['forced']))
{ {
$checked = (in_array($key,$columnsDefault)) ? TRUE : FALSE; $checked = (in_array($key,$columnsDefault)) ? TRUE : FALSE;
$text .= $this->checkbox('e-columns[]', $key, $checked). $fld['title']."<br />\n"; $text .= $this->checkbox('e-columns[]', $key, $checked). $fld['title']."<br />\n";
@ -600,10 +600,11 @@ class e_form
function colGroup($fieldarray,$columnPref='') function colGroup($fieldarray,$columnPref='')
{ {
$text = "";
foreach($fieldarray as $key=>$val) foreach($fieldarray as $key=>$val)
{ {
if(in_array($key,$columnPref) || $key=='options' || $val['forced']==TRUE) if(in_array($key,$columnPref) || $key=='options' || varsettrue($val['forced']))
{ {
$text .= "\n<col style='width: ".$val['width'].";'></col>"; $text .= "\n<col style='width: ".$val['width'].";'></col>";
} }
@ -613,14 +614,14 @@ class e_form
function thead($fieldarray,$columnPref='') function thead($fieldarray,$columnPref='')
{ {
$text = "";
foreach($fieldarray as $key=>$val) foreach($fieldarray as $key=>$val)
{ {
if(in_array($key,$columnPref) || $key == "options" || ($val['forced']==TRUE)) if(in_array($key,$columnPref) || $key == "options" || (varsettrue($val['forced'])))
{ {
$cl = ($val['thclass']) ? "class='".$val['thclass']."'" : ""; $cl = (varset($val['thclass'])) ? "class='".$val['thclass']."'" : "";
$text .= "\n\t<th id='$key' {$cl}>"; $text .= "\n\t<th id='$key' {$cl}>";
$text .= ($val['url']) ? "<a href='".$val['url']."'>" : ""; // Really this column-sorting link should be auto-generated, or be autocreated via unobtrusive js. $text .= (varset($val['url'])) ? "<a href='".$val['url']."'>" : ""; // Really this column-sorting link should be auto-generated, or be autocreated via unobtrusive js.
$text .= $val['title']; $text .= $val['title'];
$text .= ($key == "options") ? $this->columnSelector($fieldarray,$columnPref) : ""; $text .= ($key == "options") ? $this->columnSelector($fieldarray,$columnPref) : "";

View File

@ -11,8 +11,8 @@
| GNU General Public License (http://gnu.org). | GNU General Public License (http://gnu.org).
| |
| $Source: /cvs_backup/e107_0.8/e107_handlers/plugin_class.php,v $ | $Source: /cvs_backup/e107_0.8/e107_handlers/plugin_class.php,v $
| $Revision: 1.66 $ | $Revision: 1.67 $
| $Date: 2009-07-09 22:12:21 $ | $Date: 2009-07-14 03:18:16 $
| $Author: e107coders $ | $Author: e107coders $
+----------------------------------------------------------------------------+ +----------------------------------------------------------------------------+
*/ */
@ -1216,27 +1216,30 @@ class e107plugin
{ {
$pref_array = array($pref_array); $pref_array = array($pref_array);
} }
foreach($pref_array as $k => $p) if(is_array($pref_array))
{ {
$attrib = $p['@attributes']; foreach($pref_array as $k => $p)
if(isset($attrib['type']) && $attrib['type'] == 'array')
{ {
$name = $attrib['name']; $attrib = $p['@attributes'];
$tmp = $this->parse_prefs($pref_array[$k]['key']); if(isset($attrib['type']) && $attrib['type'] == 'array')
$ret['all'][$name] = $tmp['all'];
$ret['active'][$name] = $tmp['active'];
$ret['inactive'][$name] = $tmp['inactive'];
}
else
{
$ret['all'][$attrib['name']] = $attrib['value'];
if(!isset($attrib['active']) || $attrib['active'] == 'true')
{ {
$ret['active'][$attrib['name']] = $attrib['value']; $name = $attrib['name'];
$tmp = $this->parse_prefs($pref_array[$k]['key']);
$ret['all'][$name] = $tmp['all'];
$ret['active'][$name] = $tmp['active'];
$ret['inactive'][$name] = $tmp['inactive'];
} }
else else
{ {
$ret['inactive'][$attrib['name']] = $attrib['value']; $ret['all'][$attrib['name']] = $attrib['value'];
if(!isset($attrib['active']) || $attrib['active'] == 'true')
{
$ret['active'][$attrib['name']] = $attrib['value'];
}
else
{
$ret['inactive'][$attrib['name']] = $attrib['value'];
}
} }
} }
} }
@ -1253,7 +1256,7 @@ class e107plugin
$plug['plug_action'] = 'install'; $plug['plug_action'] = 'install';
// $plug_vars = $this->parse_plugin_php($plug['plugin_path']); // $plug_vars = $this->parse_plugin_php($plug['plugin_path']);
include_once($_path.'plugin.php'); include($_path.'plugin.php');
$func = $eplug_folder.'_install'; $func = $eplug_folder.'_install';
if (function_exists($func)) if (function_exists($func))
@ -1276,6 +1279,7 @@ class e107plugin
} }
} }
if (is_array($eplug_prefs)) if (is_array($eplug_prefs))
{ {
$this->manage_prefs('add', $eplug_prefs); $this->manage_prefs('add', $eplug_prefs);
@ -1339,6 +1343,8 @@ class e107plugin
// install plugin ... // install plugin ...
$id = (int)$id; $id = (int)$id;
$plug = $this->getinfo($id); $plug = $this->getinfo($id);
$plug['plug_action'] = 'install'; $plug['plug_action'] = 'install';
if ($plug['plugin_installflag'] == FALSE) if ($plug['plugin_installflag'] == FALSE)

View File

@ -11,8 +11,8 @@
| GNU General Public License (http://gnu.org). | GNU General Public License (http://gnu.org).
| |
| $Source: /cvs_backup/e107_0.8/e107_handlers/theme_handler.php,v $ | $Source: /cvs_backup/e107_0.8/e107_handlers/theme_handler.php,v $
| $Revision: 1.34 $ | $Revision: 1.35 $
| $Date: 2009-07-12 14:44:56 $ | $Date: 2009-07-14 03:18:16 $
| $Author: e107coders $ | $Author: e107coders $
+----------------------------------------------------------------------------+ +----------------------------------------------------------------------------+
*/ */
@ -31,6 +31,8 @@ class themeHandler{
function themeHandler() { function themeHandler() {
global $emessage;
require_once(e_HANDLER."form_handler.php"); require_once(e_HANDLER."form_handler.php");
$this->frm = new e_form(); //enable inner tabindex counter $this->frm = new e_form(); //enable inner tabindex counter
@ -85,6 +87,17 @@ class themeHandler{
} }
if(isset($_POST['installplugin']))
{
$key = key($_POST['installplugin']);
include_lan(e_LANGUAGEDIR.e_LANGUAGE."/admin/lan_plugin.php");
require_once(e_HANDLER."plugin_class.php");
$eplug = new e107plugin;
$message = $eplug->install_plugin($key);
$emessage->add($message, E_MESSAGE_SUCCESS);
}
} }
@ -211,7 +224,7 @@ class themeHandler{
if (!$_POST['ac'] == md5(ADMINPWCHANGE)) { if (!$_POST['ac'] == md5(ADMINPWCHANGE)) {
exit; exit;
} }
global $ns; global $ns, $emessage;
extract($_FILES); extract($_FILES);
if(!is_writable(e_THEME)) if(!is_writable(e_THEME))
{ {
@ -229,9 +242,10 @@ class themeHandler{
} else if (strstr($file_userfile['type'][0], "zip")) { } else if (strstr($file_userfile['type'][0], "zip")) {
$fileType = "zip"; $fileType = "zip";
} else { } else {
$ns->tablerender(TPVLAN_16, TPVLAN_17); $emessage->add(TPVLAN_17, E_MESSAGE_ERROR);
require_once("footer.php"); // $ns->tablerender(TPVLAN_16, TPVLAN_17);
exit; // require_once("footer.php");
return;
} }
if ($fileSize) { if ($fileSize) {
@ -256,9 +270,10 @@ class themeHandler{
} else { } else {
$error = TPVLAN_47.PclErrorString().", ".TPVLAN_48.intval(PclErrorCode()); $error = TPVLAN_47.PclErrorString().", ".TPVLAN_48.intval(PclErrorCode());
} }
$ns->tablerender(TPVLAN_16, TPVLAN_18." ".$archiveName." ".$error);
require_once("footer.php"); $emessage->add(TPVLAN_18." ".$archiveName." ".$error, E_MESSAGE_ERROR);
exit; // $ns->tablerender(TPVLAN_16, TPVLAN_18." ".$archiveName." ".$error);
return;
} }
$folderName = substr($fileList[0]['stored_filename'], 0, (strpos($fileList[0]['stored_filename'], "/"))); $folderName = substr($fileList[0]['stored_filename'], 0, (strpos($fileList[0]['stored_filename'], "/")));
@ -271,9 +286,9 @@ class themeHandler{
function showThemes($mode='main') function showThemes($mode='main')
{ {
global $ns, $pref; global $ns, $pref, $emessage;
echo "<div class='center'> echo "<div>
<form enctype='multipart/form-data' method='post' action='".e_SELF."?".$mode."'>\n"; <form enctype='multipart/form-data' method='post' action='".e_SELF."?".$mode."'>\n";
@ -287,7 +302,7 @@ class themeHandler{
} }
} }
$ns->tablerender(TPVLAN_26." :: ".TPVLAN_33, $text); $ns->tablerender(TPVLAN_26." :: ".TPVLAN_33, $emessage->render(). $text);
} }
if($mode == "admin") // Show Admin Configuration if($mode == "admin") // Show Admin Configuration
@ -300,7 +315,7 @@ class themeHandler{
$text = $this -> renderTheme(2, $theme); $text = $this -> renderTheme(2, $theme);
} }
} }
$ns->tablerender(TPVLAN_26." :: ".TPVLAN_34, $text); $ns->tablerender(TPVLAN_26." :: ".TPVLAN_34, $emessage->render(). $text);
} }
@ -318,7 +333,7 @@ class themeHandler{
$text .= $this -> renderTheme(FALSE, $theme); $text .= $this -> renderTheme(FALSE, $theme);
} }
$text .= "<div class='clear'>&nbsp;</div>"; $text .= "<div class='clear'>&nbsp;</div>";
$ns->tablerender(TPVLAN_26." :: ".TPVLAN_39, $text); $ns->tablerender(TPVLAN_26." :: ".TPVLAN_39, $emessage->render().$text);
} }
@ -328,9 +343,9 @@ class themeHandler{
function renderUploadForm() function renderUploadForm()
{ {
global $sql,$ns; global $sql,$ns, $emessage;
if(!is_writable(e_THEME)) { if(!is_writable(e_THEME)) {
$ns->tablerender(TPVLAN_16, TPVLAN_15); $ns->tablerender(TPVLAN_16, TPVLAN_15);
$text = ""; $text = "";
} }
@ -364,7 +379,7 @@ class themeHandler{
</div>\n"; </div>\n";
} }
$ns->tablerender(TPVLAN_26." :: ".TPVLAN_38, $text); $ns->tablerender(TPVLAN_26." :: ".TPVLAN_38,$emessage->render(). $text);
} }
@ -553,7 +568,7 @@ class themeHandler{
$this->loadThemeConfig(); // load customn theme configuration fieldss. $this->loadThemeConfig(); // load customn theme configuration fieldss.
$menuPresetCount = 0; $menuPresetCount = 0;
foreach($theme['layouts'] as $key=>$val) foreach($theme['layouts'] as $key=>$val)
{ {
if($val['menuPresets']) if($val['menuPresets'])
@ -611,9 +626,9 @@ class themeHandler{
<td style='vertical-align:top; width:24%;'><b>".TPVLAN_53."</b></td> <td style='vertical-align:top; width:24%;'><b>".TPVLAN_53."</b></td>
<td colspan='2' style='vertical-align:top width:auto;'>"; <td colspan='2' style='vertical-align:top width:auto;'>";
foreach($theme['layouts'] as $key=>$val) foreach($theme['pluginOptions'] as $key=>$val)
{ {
$text .= $this->renderPlugins($val['@attributes']['plugins']); $text .= $this->renderPlugins($theme['pluginOptions']);
$text .= "&nbsp;"; $text .= "&nbsp;";
} }
@ -648,7 +663,7 @@ class themeHandler{
<td colspan='2' style='vertical-align:top'> <td colspan='2' style='vertical-align:top'>
<table class='adminlist' style='auto;width:100%' > <table class='adminlist' style='auto;width:100%' >
<tr>"; <tr>";
$itext .= ($mode == 1) ? "<td style='width:15%;text-align:center;vertical-align:top;'>".TPVLAN_55."</td>" : ""; $itext .= ($mode == 1) ? "<td style='width:15%;vertical-align:top;'>".TPVLAN_55."</td>" : "";
$itext .= " $itext .= "
<td style='width:20%'>".TPVLAN_52."</td> <td style='width:20%'>".TPVLAN_52."</td>
<td style='width:65%'>".TPVLAN_56."</td> <td style='width:65%'>".TPVLAN_56."</td>
@ -808,23 +823,36 @@ class themeHandler{
return $text; return $text;
} }
function renderPlugins($val) function renderPlugins($tmp)
{ {
$tmp = explode(",",$val); global $frm,$sql;
$tmp = array_filter($tmp); // $tmp = explode(",",$val);
// $tmp = array_filter($tmp);
foreach($tmp as $plug) foreach($tmp['plugin'] as $p)
{ {
$plug = trim($plug); $plug = trim($p['@attributes']['name']);
if(plugInstalled($plug)) if(plugInstalled($plug))
{ {
$text .= $plug." ".ADMIN_TRUE_ICON; $text .= $plug." ".ADMIN_TRUE_ICON;
} }
else else
{ {
$text .= "<a href='".e_ADMIN."plugin.php?avail'>".$plug."</a> ".ADMIN_FALSE_ICON; if($sql -> db_Select("plugin", "plugin_id", " plugin_path = '".$plug."' LIMIT 1 "))
{
$row = $sql -> db_Fetch(MYSQL_ASSOC);
$name = "installplugin[".$row['plugin_id']."]";
$text .= $this->frm->admin_button($name, ADLAN_121." ".$plug."",'delete');
}
else
{
$text .= (isset($p['@attributes']['url']) && ($p['@attributes']['url']!='core')) ? "<a rel='external' href='".$p['@attributes']['url']."'>".$plug."</a> " : "<i>".$plug."</i>";
$text .= ADMIN_FALSE_ICON;
}
} }
$text .= "&nbsp;&nbsp;"; $text .= "&nbsp;&nbsp;&nbsp;";
} }
return $text; return $text;
@ -852,7 +880,7 @@ class themeHandler{
function setTheme() function setTheme()
{ {
global $pref, $e107cache, $ns, $sql; global $pref, $e107cache, $ns, $sql, $emessage;
$themeArray = $this -> getThemes("id"); $themeArray = $this -> getThemes("id");
$pref['sitetheme'] = $themeArray[$this -> id]; $pref['sitetheme'] = $themeArray[$this -> id];
@ -864,10 +892,18 @@ class themeHandler{
$sql -> db_Delete("menus", "menu_layout !='' "); $sql -> db_Delete("menus", "menu_layout !='' ");
$e107cache->clear_sys(); $e107cache->clear_sys();
save_prefs(); if(save_prefs())
{
$emessage->add(TPVLAN_3." <b>'".$themeArray[$this -> id]."'</b>", E_MESSAGE_SUCCESS);
}
else
{
$emessage->add(TPVLAN_3." <b>'".$themeArray[$this -> id]."'</b>", E_MESSAGE_ERROR);
}
$this->theme_adminlog('01',$pref['sitetheme'].', '.$pref['themecss']); $this->theme_adminlog('01',$pref['sitetheme'].', '.$pref['themecss']);
$ns->tablerender("Admin Message", "<br /><div style='text-align:center;'>".TPVLAN_3." <b>'".$themeArray[$this -> id]."'</b>.</div><br />");
// $ns->tablerender("Admin Message", "<br /><div style='text-align:center;'>".TPVLAN_3." <b>'".$themeArray[$this -> id]."'</b>.</div><br />");
} }
function findDefault($theme) function findDefault($theme)
@ -903,42 +939,58 @@ class themeHandler{
function setAdminTheme() function setAdminTheme()
{ {
global $pref, $e107cache, $ns; global $pref, $e107cache, $ns, $emessage;
$themeArray = $this -> getThemes("id"); $themeArray = $this -> getThemes("id");
$pref['admintheme'] = $themeArray[$this -> id]; $pref['admintheme'] = $themeArray[$this -> id];
$pref['admincss'] = file_exists(THEME.'admin_style.css') ? 'admin_style.css' : 'style.css'; $pref['admincss'] = file_exists(THEME.'admin_style.css') ? 'admin_style.css' : 'style.css';
$e107cache->clear_sys(); $e107cache->clear_sys();
save_prefs(); if(save_prefs())
$this->theme_adminlog('02',$pref['admintheme'].', '.$pref['admincss']); {
$ns->tablerender("Admin Message", "<br /><div style='text-align:center;'>".TPVLAN_40." <b>'".$themeArray[$this -> id]."'</b>.</div><br />"); $emessage->add(TPVLAN_40." <b>'".$themeArray[$this -> id]."'</b>", E_MESSAGE_SUCCESS); // Default Message
$this->theme_adminlog('02',$pref['admintheme'].', '.$pref['admincss']);
}
// $ns->tablerender("Admin Message", "<br /><div style='text-align:center;'>".TPVLAN_40." <b>'".$themeArray[$this -> id]."'</b>.</div><br />");
// $this->showThemes('admin'); // $this->showThemes('admin');
} }
function setStyle() function setStyle()
{ {
global $pref, $e107cache, $ns, $sql; global $pref, $e107cache, $ns, $sql, $emessage;
$pref['themecss'] = $_POST['themecss']; $pref['themecss'] = $_POST['themecss'];
$pref['image_preload'] = $_POST['image_preload']; $pref['image_preload'] = $_POST['image_preload'];
$pref['sitetheme_deflayout'] = $_POST['layout_default']; $pref['sitetheme_deflayout'] = $_POST['layout_default'];
$e107cache->clear_sys(); $e107cache->clear_sys();
save_prefs(); if(save_prefs())
$this -> setThemeConfig(); {
$this->theme_adminlog('03',$pref['image_preload'].', '.$pref['themecss']); $emessage->add(TPVLAN_37, E_MESSAGE_SUCCESS); // Default Message
$ns->tablerender(TPVLAN_36, "<br /><div style='text-align:center;'>".TPVLAN_37.".<br /></div><br />"); $emessage->add($this -> setThemeConfig(),E_MESSAGE_SUCCESS); // Custom Message from theme config.
$this->theme_adminlog('03',$pref['image_preload'].', '.$pref['themecss']);
}
else
{
$emessage->add(TPVLAN_43, E_MESSAGE_ERROR);
}
} }
function setAdminStyle() function setAdminStyle()
{ {
global $pref, $e107cache, $ns; global $pref, $e107cache, $ns, $emessage;
$pref['admincss'] = $_POST['admincss']; $pref['admincss'] = $_POST['admincss'];
$pref['adminstyle'] = $_POST['adminstyle']; $pref['adminstyle'] = $_POST['adminstyle'];
$e107cache->clear_sys(); $e107cache->clear_sys();
save_prefs(); if(save_prefs())
$this->theme_adminlog('04',$pref['adminstyle'].', '.$pref['admincss']); {
$ns->tablerender(TPVLAN_36, "<br /><div style='text-align:center;'>".TPVLAN_43.".</div><br />"); $emessage->add(TPVLAN_43, E_MESSAGE_SUCCESS);
$this->theme_adminlog('04',$pref['adminstyle'].', '.$pref['admincss']);
}
else
{
$emessage->add(TPVLAN_43, E_MESSAGE_ERROR);
}
} }
function SetCustomPages($array) function SetCustomPages($array)

View File

@ -11,9 +11,9 @@
| GNU General Public License (http://gnu.org). | GNU General Public License (http://gnu.org).
| |
| $Source: /cvs_backup/e107_0.8/e107_handlers/xml_class.php,v $ | $Source: /cvs_backup/e107_0.8/e107_handlers/xml_class.php,v $
| $Revision: 1.10 $ | $Revision: 1.11 $
| $Date: 2008-12-20 20:18:59 $ | $Date: 2009-07-14 03:18:16 $
| $Author: e107steved $ | $Author: e107coders $
+----------------------------------------------------------------------------+ +----------------------------------------------------------------------------+
*/ */
@ -192,7 +192,7 @@ class xmlClass
} }
$xml = false; $xml = false;
if(strpos($filename, '://') !== false) if(strpos($fname, '://') !== false)
{ {
$this->getRemoteFile($fname); $this->getRemoteFile($fname);
} }

View File

@ -3,8 +3,12 @@
<author name ="Steve Dunstan [jalist]" email="jalist@e107.org" url="http://e107.org"/> <author name ="Steve Dunstan [jalist]" email="jalist@e107.org" url="http://e107.org"/>
<description>Classic e107 theme</description> <description>Classic e107 theme</description>
<compliance xhtml="true" css="true"/> <compliance xhtml="true" css="true"/>
<pluginOptions>
<plugin name='chatbox_menu' url='core' />
<plugin name='poll' url='core' />
</pluginOptions>
<layouts> <layouts>
<layout name='3_column' title='3 Columns' preview='preview.jpg' previewFull='preview_full.png' plugins='chatbox_menu,poll' default='true' > <layout name='3_column' title='3 Columns' preview='preview.jpg' previewFull='preview_full.png' default='true' >
<menuPresets> <menuPresets>
<area id='1' > <area id='1' >
<menu name='login' /> <menu name='login' />