File Manager
<?php
#CMS - CMS Made Simple
#(c)2004 by Ted Kulp (wishy@users.sf.net)
#This project's homepage is: http://www.cmsmadesimple.org
#
#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: edittemplate.php 8303 2012-09-22 01:48:56Z stikki $
$CMS_ADMIN_PAGE=1;
require_once("../include.php");
require_once("../lib/classes/class.template.inc.php");
$urlext='?'.CMS_SECURE_PARAM_NAME.'='.$_SESSION[CMS_USER_KEY];
check_login();
$gCms = cmsms();
$db = $gCms->GetDb();
$lastedited = time();
$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;
$default = false;
$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".$urlext);
break;
case 'cssassoc':
redirect('templatecss.php'.$urlext.'&id='.$cssid.'&type=template');
break;
case 'module_TemplateManager':
redirect('moduleinterface.php'.$urlext.'&module=TemplateManager');
break;
default:
redirect("listtemplates.php".$urlext);
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;
$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 ($templateops->CheckExistingTemplateName($template, $template_id))
{
$error .= "<li>".lang('templateexists')."</li>";
$validinfo = false;
}
if ($content == "")
{
$error .= "<li>".lang('nofieldgiven', array(lang('content')))."</li>";
$validinfo = false;
}
if( $validinfo ) {
try {
$parser = cmsms()->get_template_parser();
cms_utils::set_app_data('tmp_template',$content);
try {
$parser->fetch('template:appdata;tmp_template'); // do the magic.
}
catch ( SmartyCompilerException $e ) {
$error .= "<li>".$e->getMessage().'</li>';
$validinfo = false;
}
$contentBlocks = CMS_Content_Block::get_content_blocks();
if( !is_array($contentBlocks) || count($contentBlocks) == 0 ) {
throw new CmsEditContentException('No content blocks defined in template');
}
if( !isset($contentBlocks['content_en']) ) {
throw new CmsEditContentException('No default content block {content} or {content block=\'content_en\'} defined in template');
}
// if we got here, we're golden.
}
catch( CmsEditContentException $e ) {
$error .= "<li>".$e->getMessage().'</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;
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;
Events::SendEvent('Core', 'EditTemplatePost', array('template' => &$onetemplate));
// put mention into the admin log
audit($template_id, 'HTML-template: '.$onetemplate->name, 'Edited');
if (!$apply)
{
switch($from)
{
case 'content':
redirect("listcontent.php".$urlext);
break;
case 'cssassoc':
redirect('templatecss.php'.$urlext.'&id='.$cssid.'&type=template');
break;
case 'module_TemplateManager':
redirect('moduleinterface.php'.$urlext.'&module=TemplateManager');
break;
default:
redirect("listtemplates.php".$urlext);
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;
$default = $onetemplate->default;
$active = $onetemplate->active;
$lastedited = $onetemplate->modified_date;
}
}
if (strlen($template) > 0)
{
$CMS_ADMIN_SUBTITLE = $template;
}
$addlScriptSubmit = '';
$modobj = cms_utils::get_syntax_highlighter_module();
if( is_object($modobj) )
{
$addlScriptSubmit = $modobj->SyntaxPageFormSubmit();
}
$closestr = cms_html_entity_decode(lang('close'));
$headtext = <<<EOSCRIPT
<script type="text/javascript">
// <![CDATA[
jQuery(document).ready(function(){
jQuery('[name=apply]').live('click',function(){
var data = jQuery('#Edit_Template').find('input:not([type=submit]), select, textarea').serializeArray();
data.push({ 'name': 'ajax', 'value': 1});
data.push({ 'name': 'apply', 'value': 1 });
$.post('{$_SERVER['REQUEST_URI']}',data,function(resultdata,text){
var event = jQuery.Event('cms_ajax_apply');
event.response = $(resultdata).find('Response').text();
event.details = $(resultdata).find('Details').text();
event.close = '{$closestr}';
jQuery('body').trigger(event);
},'xml');
return false;
});
jQuery('body').bind('cms_ajax_apply',function(e){
var htmlShow = '';
if( e.response == 'Success' )
{
htmlShow = '<div class="pagemcontainer"><p class="pagemessage">' + e.details + '<\/p><\/div>';
$('[name=cancel]').fadeOut();
$('[name=cancel]').attr('value','{$closestr}');
$('[name=cancel]').fadeIn();
}
else
{
htmlShow = '<div class="pageerrorcontainer"><ul class="pageerror">';
htmlShow += e.details;
htmlShow += '<\/ul><\/div>';
}
jQuery('#Edit_Template_Result').html(htmlShow);
});
});
// ]]>
</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" />
<input type="submit" name="cancel" value="'.lang('cancel').'" class="pagebutton" />
<input type="submit" name="apply" value="'.lang('apply').'" class="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>";
}
?>
<div class="pagecontainer">
<?php echo $themeObject->ShowHeader('edittemplate'); ?>
<form id="Edit_Template" method="post" action="edittemplate.php?<?php echo CMS_SECURE_PARAM_NAME.'='.$_SESSION[CMS_USER_KEY] ?>">
<div>
<input type="hidden" name="template_id" value="<?php echo $template_id ?>" />
</div>
<div class="pageoverflow">
<p class="pagetext"> </p>
<div class="pageinput">
<?php echo $submitbtns; ?><a href="listcssassoc.php<?php echo $urlext ?>&type=template&id=<?php echo $template_id ?>" rel="external"><?php echo $themeObject->DisplayImage('icons/system/css.gif', lang('attachstylesheets'),'','','systemicon'); ?>
</a><?php echo " [" . lang('new_window') . "]" ;?></div>
</div>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('name')?>:</p>
<div class="pageinput"><input type="text" class="name" name="template" maxlength="255" value="<?php echo $template?>" /></div>
</div>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('content')?>:</p>
<div class="pageinput"><?php echo create_textarea(false, $content, 'content', 'pagebigtextarea', 'content', $encoding, '', '80', '15','','html')?></div>
</div>
<?php if ($templateops->StylesheetsUsed() > 0) { ?>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('stylesheet')?>:</p>
<div class="pageinput"><?php echo create_textarea(false, $stylesheet, 'stylesheet', 'pagebigtextarea', '', $encoding, '', '80', '15','','css')?></div>
</div>
<?php } if ($default == 0 ) { ?>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('active')?>:</p>
<div class="pageinput"><input class="pagecheckbox" type="checkbox" name="active" <?php echo ($active == 1?"checked=\"checked\"":"") ?> /> </div>
</div>
<?php } else { ?>
<div><input type="hidden" name="active" value="<?php echo $active; ?>">
<?php } ?>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('last_modified_at')?>:</p>
<div class="pageinput">
<?php
$dateformat = trim(get_preference(get_userid(),'date_format_string','%x %X'));
if( empty($dateformat) )
{
$dateformat = '%x %X';
}
echo strftime( $dateformat ,$lastedited);
?></div>
</div>
<?php if( $encoding != "" ){ ?>
<div class="pageoverflow">
<p class="pagetext"><?php echo lang('encoding')?>:</p>
<div class="pageinput"><?php echo create_encoding_dropdown('encoding', $encoding) ?></div>
</div>
<?php } ?>
<div class="pageoverflow">
<p class="pagetext"> </p>
<div 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; ?><a href="listcssassoc.php<?php echo $urlext ?>&type=template&id=<?php echo $template_id ?>" rel="external"><?php echo $themeObject->DisplayImage('icons/system/css.gif', lang('attachstylesheets'),'','','systemicon'); ?></a><?php echo " [" . lang('new_window') . "]" ;?></div>
</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
?>
File Manager Version 1.0, Coded By Lucas
Email: hehe@yahoo.com