<?php
#CMS - CMS Made Simple
#(c)2004 by Ted Kulp (wishy@users.sf.net)
#This project's homepage is: http://cmsmadesimple.sf.net
#
#This program is free software; you can redistribute it and/or modify
#it under the terms of the GNU General Public License as published by
#the Free Software Foundation; either version 2 of the License, or
#(at your option) any later version.
#
#This program is distributed in the hope that it will be useful,
#but WITHOUT ANY WARRANTY; without even the implied warranty of
#MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
#GNU General Public License for more details.
#You should have received a copy of the GNU General Public License
#along with this program; if not, write to the Free Software
#Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
#$Id$
$CMS_ADMIN_PAGE=1;
require_once("../include.php");
require_once("../lib/classes/class.template.inc.php");
check_login();
global $gCms;
$db =& $gCms->GetDb();
$error = "";
$template = "";
if (isset($_POST["template"])) $template = $_POST["template"];
$orig_template = "";
if (isset($_POST["orig_template"])) $orig_template = $_POST["orig_template"];
$content = "";
if (isset($_POST["content"])) $content = $_POST["content"];
$stylesheet = "";
if (isset($_POST["stylesheet"])) $stylesheet = $_POST["stylesheet"];
$encoding = "";
if (isset($_POST["encoding"])) $encoding = $_POST["encoding"];
$from = "";
if (isset($_REQUEST["from"])) $from = $_REQUEST["from"];
$cssid = "";
if (isset($_REQUEST["cssid"])) $cssid = $_REQUEST["cssid"];
$active = 1;
if (!isset($_POST["active"]) && isset($_POST["edittemplate"])) $active = 0;
$ajax = false;
if (isset($_POST['ajax']) and $_POST['ajax']) $ajax = true;
$preview = false;
/* there is no point for preview as there isnt any content to show
tsw - 7.5.2007
if (isset($_POST["preview"])) $preview = true;
*/
$apply = false;
if (isset($_POST["apply"])) $apply = true;
$template_id = -1;
if (isset($_POST["template_id"])) $template_id = $_POST["template_id"];
else if (isset($_GET["template_id"])) $template_id = $_GET["template_id"];
if (isset($_POST["cancel"])) {
switch($from)
{
case 'content':
redirect("listcontent.php");
break;
case 'cssassoc':
redirect('templatecss.php?id='.$cssid.'&type=template');
break;
case 'module_TemplateManager':
redirect('moduleinterface.php?module=TemplateManager');
break;
default:
redirect("listtemplates.php");
break;
}
}
if ($preview || $apply)
{
$CMS_EXCLUDE_FROM_RECENT=1;
}
$userid = get_userid();
$access = check_permission($userid, 'Modify Templates');
$use_javasyntax = false;
if (get_preference($userid, 'use_javasyntax') == "1") $use_javasyntax = true;
global $gCms;
$templateops =& $gCms->GetTemplateOperations();
if ($access)
{
if (isset($_POST["edittemplate"]) && !$preview)
{
$validinfo = true;
if ($template == "")
{
$error .= "<li>".lang('nofieldgiven', array(lang('name')))."</li>";
$validinfo = false;
}
else if ($template != $orig_template)
{
$query = "SELECT template_id from ".cms_db_prefix()."templates WHERE template_name = ?";
$row = &$db->GetRow($query, array($template));
if ($row)
{
$error .= "<li>".lang('templateexists')."</li>";
$validinfo = false;
}
}
if ($content == "")
{
$error .= "<li>".lang('nofieldgiven', array(lang('content')))."</li>";
$validinfo = false;
}
if ($validinfo)
{
$onetemplate = $templateops->LoadTemplateByID($template_id);
$onetemplate->name = $template;
$onetemplate->content = $content;
$onetemplate->stylesheet = $stylesheet;
$onetemplate->encoding = $encoding;
$onetemplate->active = $active;
#Perform the edittemplate_pre callback
foreach($gCms->modules as $key=>$value)
{
if ($gCms->modules[$key]['installed'] == true &&
$gCms->modules[$key]['active'] == true)
{
$gCms->modules[$key]['object']->EditTemplatePre($onetemplate);
}
}
Events::SendEvent('Core', 'EditTemplatePre', array('template' => &$onetemplate));
$result = $onetemplate->Save();
if ($result)
{
#Make sure the new name is used if this is an apply
$orig_template = $template;
#Perform the edittemplate_post callback
foreach($gCms->modules as $key=>$value)
{
if ($gCms->modules[$key]['installed'] == true &&
$gCms->modules[$key]['active'] == true)
{
$gCms->modules[$key]['object']->EditTemplatePost($onetemplate);
}
}
Events::SendEvent('Core', 'EditTemplatePost', array('template' => &$onetemplate));
audit($template_id, $onetemplate->name, 'Edited Template');
if (!$apply)
{
switch($from)
{
case 'content':
redirect("listcontent.php");
break;
case 'cssassoc':
redirect('templatecss.php?id='.$cssid.'&type=template');
break;
case 'module_TemplateManager':
redirect('moduleinterface.php?module=TemplateManager');
break;
default:
redirect("listtemplates.php");
break;
}
}
}
else
{
$error .= "<li>".lang('errorupdatingtemplate')."</li>";
}
}
if ($ajax)
{
header('Content-Type: text/xml');
print '<?xml version="1.0" encoding="UTF-8"?>';
print '<EditTemplate>';
if ($error)
{
print '<Response>Error</Response>';
print '<Details><![CDATA[' . $error . ']]></Details>';
}
else
{
print '<Response>Success</Response>';
print '<Details><![CDATA[' . lang('edittemplatesuccess') . ']]></Details>';
}
print '</EditTemplate>';
exit;
}
}
else if ($template_id != -1 && !$preview)
{
$onetemplate = $templateops->LoadTemplateByID($template_id);
$template = $onetemplate->name;
$orig_template = $onetemplate->name;
$content = $onetemplate->content;
$stylesheet = $onetemplate->stylesheet;
$encoding = $onetemplate->encoding;
$active = $onetemplate->active;
$lastedited = $onetemplate->modified_date;
}
}
if (strlen($template) > 0)
{
$CMS_ADMIN_SUBTITLE = $template;
}
$addlScriptSubmit = '';
foreach (array_keys($gCms->modules) as $moduleKey)
{
$module =& $gCms->modules[$moduleKey];
if (!($module['installed'] && $module['active'] && $module['object']->IsSyntaxHighlighter()))
{
continue;
}
if ($module['object']->SyntaxActive() or get_preference(get_userid(), 'syntaxhighlighter') == $module['object']->GetName())
{
$addlScriptSubmit .= $module['object']->SyntaxPageFormSubmit();
}
}
$headtext = <<<EOSCRIPT
<script type="text/javascript">
window.Edit_Template_Apply = function(button)
{
$addlScriptSubmit
$('Edit_Template_Result').innerHTML = '';
button.disabled = 'disabled';
var data = new Array();
data.push('ajax=1');
data.push('apply=1');
// Have to handle some of the serialization here (rather than Form.serialize()) because the cancel button can break things.
var elements = Form.getElements($('Edit_Template'));
for (var cnt = 0; cnt < elements.length; cnt++)
{
var elem = elements[cnt];
if (elem.type == 'submit')
{
// Leave off all submit buttons
continue;
}
var query = Form.Element.serialize(elem);
data.push(query);
}
new Ajax.Request(
'{$_SERVER['REQUEST_URI']}'
, {
method: 'post'
, parameters: data.join('&')
, onSuccess: function(t)
{
button.removeAttribute('disabled');
var response = t.responseXML.documentElement.childNodes[0];
var details = t.responseXML.documentElement.childNodes[1];
if (response.textContent) { response = response.textContent; } else { response = response.text; }
if (details.textContent) { details = details.textContent; } else { details = details.text; }
var htmlShow = '';
if (response == 'Success')
{
htmlShow = '<div class="pagemcontainer"><p class="pagemessage">' + details + '</p></div>';
}
else
{
htmlShow = '<div class="pageerrorcontainer"><ul class="pageerror">';
htmlShow += details;
htmlShow += '</ul></div>';
}
$('Edit_Template_Result').innerHTML = htmlShow;
}
, onFailure: function(t)
{
alert('Could not save: ' + t.status + ' -- ' + t.statusText);
}
}
);
return false;
}
</script>
EOSCRIPT;
include_once("header.php");
print '<div id="Edit_Template_Result"></div>';
$submitbtns = '
<!-- <input type="submit" name="preview" value="'.lang('preview').'" class="button" onmouseover="this.className=\'buttonHover\'" onmouseout="this.className=\'button\'" /> -->
<input type="submit" value="'.lang('submit').'" class="pagebutton" onmouseover="this.className=\'pagebuttonhover\'" onmouseout="this.className=\'pagebutton\'" />
<input type="submit" onclick="return window.Edit_Template_Apply(this);" name="apply" value="'.lang('apply').'" class="pagebutton" onmouseover="this.className=\'pagebuttonhover\'" onmouseout="this.className=\'pagebutton\'" />
<input type="submit" name="cancel" value="'.lang('cancel').'" class="pagebutton" onmouseover="this.className=\'pagebuttonhover\'" onmouseout="this.className=\'pagebutton\'" />
';
if (!$access)
{
echo "<div class=\"pageerrorcontainer\"><p class=\"pageerror\">".lang('noaccessto', array(lang('edittemplate')))."</p></div>";
}
else
{
if ($error != "")
{
echo "<div class=\"pageerrorcontainer\"><ul class=\"pageerror\">".$error."</ul></div>";
}
/*
if ($preview)
{
$data["title"] = "TITLE HERE";
$data["content"] = "Test Content";
$data["template_id"] = $template_id;
$data["stylesheet"] = $stylesheet;
$data["encoding"] = $encoding;
$data["template"] = $content;
$tmpfname = '';
if (is_writable($config["previews_path"]))
{
$tmpfname = tempnam($config["previews_path"], "cmspreview");
}
else
{
$tmpfname = tempnam(TMP_CACHE_LOCATION, "cmspreview");
}
$handle = fopen($tmpfname, "w");
fwrite($handle, serialize($data));
fclose($handle);
//?>
<div class="pagecontainer">
<p class="pageheader"><?php echo lang('preview')?></p>
<iframe class="preview" name="preview" src="<?php echo $config["root_url"]?>/preview.php?tmpfile=<?php echo urlencode(basename($tmpfname))?>"></iframe>
</div>
//<?php
}
*/
?>
<div class="pagecontainer">
<?php echo $themeObject->ShowHeader('edittemplate'); ?>
<form id="Edit_Template" method="post" action="edittemplate.php">
<p class="pageshowrows">
<a href="listcssassoc.php?type=template&id=<?php echo $onetemplate->id ?>" target="_blank">
<?php echo $themeObject->DisplayImage('icons/system/css.gif', lang('attachstylesheets'),'','','systemicon'); ?>
</a>
</p>
<div class="pageoverflow">
<p class="pagetext"> </p>
<p class="pageinput">
<?php echo $submitbtns; ?>
</p>
</div>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('name')?>:</p>
<p class="pageinput"><input type="text" class="name" name="template" maxlength="255" value="<?php echo $template?>" /></p>
</div>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('content')?>:</p>
<p class="pageinput"><?php echo create_textarea(false, $content, 'content', 'pagebigtextarea', 'content', $encoding, '', '80', '15','','html')?></p>
</div>
<?php if ($templateops->StylesheetsUsed() > 0) { ?>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('stylesheet')?>:</p>
<p class="pageinput"><?php echo create_textarea(false, $stylesheet, 'stylesheet', 'pagebigtextarea', '', $encoding, '', '80', '15','','css')?></p>
</div>
<?php } ?>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('active')?>:</p>
<p class="pageinput"><input class="pagecheckbox" type="checkbox" name="active" <?php echo ($active == 1?"checked=\"checked\"":"") ?> /> </p>
</div>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('last_modified_at')?>:</p>
<p class="pageinput"><?php echo strftime( get_preference(get_userid(),'date_format_string','%x %X') ,$lastedited); ?></p>
</div>
<?php if( $encoding != "" ){ ?>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('encoding')?>:</p>
<p class="pageinput"><?php echo create_encoding_dropdown('encoding', $encoding) ?></p>
</div>
<?php } ?>
<div class="pageoverflow">
<p class="pagetext"> </p>
<p class="pageinput">
<input type="hidden" name="orig_template" value="<?php echo $orig_template?>" />
<input type="hidden" name="template_id" value="<?php echo $template_id?>" />
<input type="hidden" name="from" value="<?php echo $from?>" />
<input type="hidden" name="cssid" value="<?php echo $cssid?>" />
<input type="hidden" name="edittemplate" value="true" />
<?php echo $submitbtns; ?>
</p>
</div>
</form>
</div>
<?php
}
echo '<p class="pageback"><a class="pageback" href="'.$themeObject->BackUrl().'">« '.lang('back').'</a></p>';
include_once("footer.php");
# vim:ts=4 sw=4 noet
?>