mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-26 13:16:14 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			3376 lines
		
	
	
		
			104 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			3376 lines
		
	
	
		
			104 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| // -------------------------------------------------------------
 | |
| //
 | |
| // $Id$
 | |
| //
 | |
| // FILENAME  : admin_styles.php
 | |
| // STARTED   : Thu Aug 7 2003
 | |
| // COPYRIGHT : © 2003 phpBB Group
 | |
| // WWW       : http://www.phpbb.com/
 | |
| // LICENCE   : GPL vs2.0 [ see /docs/COPYING ] 
 | |
| // 
 | |
| // -------------------------------------------------------------
 | |
| 
 | |
| // TODO
 | |
| // For M-3
 | |
| // BBCode support
 | |
| // Replace template/s, stylesheet, images, etc.
 | |
| // Previews of templates, imagesets, themes ... unified
 | |
| // Security review
 | |
| 
 | |
| // BUGS
 | |
| // Editing template -> store in DB -> some kind of failure
 | |
| 
 | |
| if (!empty($setmodules))
 | |
| {
 | |
| 	if (!$auth->acl_get('a_styles'))
 | |
| 	{
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	$filename = basename(__FILE__);
 | |
| 	$module['STYLE']['MANAGE_STYLE']	= "$filename$SID&mode=style";
 | |
| 	$module['STYLE']['MANAGE_TEMPLATE'] = "$filename$SID&mode=template";
 | |
| 	$module['STYLE']['MANAGE_THEME']	= "$filename$SID&mode=theme";
 | |
| 	$module['STYLE']['MANAGE_IMAGESET'] = "$filename$SID&mode=imageset";
 | |
| 
 | |
| 	return;
 | |
| }
 | |
| 
 | |
| define('IN_PHPBB', 1);
 | |
| // Include files
 | |
| $phpbb_root_path = '../';
 | |
| $phpEx = substr(strrchr(__FILE__, '.'), 1);
 | |
| require('pagestart.' . $phpEx);
 | |
| 
 | |
| // Do we have styles admin permissions?
 | |
| if (!$auth->acl_get('a_styles'))
 | |
| {
 | |
| 	trigger_error($user->lang['NO_ADMIN']);
 | |
| }
 | |
| 
 | |
| 
 | |
| // Get some vars
 | |
| $update = (isset($_POST['update'])) ? true : false;
 | |
| $mode = (isset($_REQUEST['mode'])) ? htmlspecialchars($_REQUEST['mode']) : '';
 | |
| $id = (isset($_REQUEST['id'])) ? intval($_REQUEST['id'])  : '';
 | |
| 
 | |
| if (isset($_REQUEST['action']))
 | |
| {
 | |
| 	$action = htmlspecialchars($_REQUEST['action']);
 | |
| }
 | |
| else
 | |
| {
 | |
| 	$action = '';
 | |
| 	if (isset($_POST['add']))
 | |
| 	{
 | |
| 		$action = 'add';
 | |
| 	}
 | |
| 	else if (isset($_POST['preview']))
 | |
| 	{
 | |
| 		$action = 'preview';
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Set some basic vars
 | |
| $error = $cfg = array();
 | |
| 
 | |
| $safe_mode	= (@ini_get('safe_mode') || @strtolower(ini_get('safe_mode')) == 'on') ? true : false;
 | |
| $file_uploads = (@ini_get('file_uploads') || strtolower(@ini_get('file_uploads')) == 'on') ? true : false; 
 | |
| 
 | |
| // Generate list of archive types inc. regexp | match
 | |
| $archive_types = '<u>.tar</u>';
 | |
| $archive_preg = '\.tar';
 | |
| foreach (array('tar.gz' => 'zlib', 'tar.bz2' => 'bz2', 'zip' => 'zlib') as $type => $module)
 | |
| {
 | |
| 	if (!@extension_loaded($module))
 | |
| 	{
 | |
| 		continue;
 | |
| 	}
 | |
| 	$archive_types .= ", <u>.$type</u>";
 | |
| 	$archive_preg .= '|\.' . preg_quote($type);
 | |
| }
 | |
| 
 | |
| // --------------------
 | |
| // Start program proper
 | |
| // --------------------
 | |
| 
 | |
| // Mode indepedent actions
 | |
| switch ($action)
 | |
| {
 | |
| 	case 'export':
 | |
| 		if ($id)
 | |
| 		{
 | |
| 			export($mode, $id);
 | |
| 		}
 | |
| 		break;
 | |
| 
 | |
| 	case 'add':
 | |
| 	case 'install':
 | |
| 	case 'details':
 | |
| 		install($mode, $action, $id);
 | |
| 		break;
 | |
| 
 | |
| 	case 'delete':
 | |
| 		if ($id)
 | |
| 		{
 | |
| 			remove($mode, $id);
 | |
| 		}
 | |
| 		break;
 | |
| }
 | |
| 
 | |
| // Mode based actions
 | |
| switch ($mode)
 | |
| {
 | |
| 	// STYLES
 | |
| 	case 'style':
 | |
| 		switch ($action)
 | |
| 		{
 | |
| 			case 'activate':
 | |
| 			case 'deactivate':
 | |
| 				if ($id == $config['default_style'])
 | |
| 				{
 | |
| 					trigger_error($user->lang['DEACTIVATE_DEFAULT']);
 | |
| 				}
 | |
| 
 | |
| 				$sql = 'UPDATE ' . STYLES_TABLE . '
 | |
| 					SET style_active = ' . (($action == 'activate') ? 1 : 0) . ' 
 | |
| 					WHERE style_id = ' . $id;
 | |
| 				$db->sql_query($sql);
 | |
| 
 | |
| 				// Set style to default for any member using deactivated style
 | |
| 				$sql = 'UPDATE ' . USERS_TABLE . ' 
 | |
| 					SET user_style = ' . $config['default_style'] . " 
 | |
| 					WHERE user_style = $id";
 | |
| 				$db->sql_query($sql);
 | |
| 				break;
 | |
| 		}
 | |
| 
 | |
| 		frontend('style', array('delete', 'export'));
 | |
| 		break;
 | |
| 
 | |
| 
 | |
| 	// TEMPLATES
 | |
| 	case 'template':
 | |
| 		$tpllist = array(
 | |
| 			'misc'		=> array(
 | |
| 				'confirm_body.html', 'faq_body.html', 'index_body.html',  'message_body.html', 'viewonline_body.html', 
 | |
| 			),
 | |
| 			'includes'	=> array(
 | |
| 				'overall_footer.html', 'overall_header.html', 'simple_footer.html', 'simple_header.html', 'searchbox.html', 'jumpbox.html',
 | |
| 			), 
 | |
| 			'forum'		=> array(
 | |
| 				'viewforum_body.html', 'viewforum_subforum.html', 
 | |
| 			),
 | |
| 			'topic'		=> array(
 | |
| 				'viewtopic_attach_body.html', 'viewtopic_body.html', 'viewtopic_print.html',
 | |
| 			),
 | |
| 			'group'		=> array(
 | |
| 				'gcp_body.html', 'gcp_pending_info.html', 'gcp_user_body.html', 
 | |
| 			),
 | |
| 			'user'		=> array(
 | |
| 				'ucp_agreement.html', 'ucp_footer.html', 'ucp_header.html', 'ucp_main.html', 'ucp_pm_body.html', 'ucp_pm_popup.html', 'ucp_pm_preview.html', 'ucp_pm_read.html', 'ucp_prefs.html', 'ucp_profile.html', 'ucp_register.html', 'ucp_remind.html', 
 | |
| 			),
 | |
| 			'profile'	=> array(
 | |
| 				'memberlist_body.html', 'memberlist_email.html', 'memberlist_im.html', 'memberlist_view.html', 
 | |
| 			), 
 | |
| 			'mod'		=> array(
 | |
| 				'mcp_forum.html', 'mcp_foruminfo.html', 'mcp_front.html', 'mcp_header.html', 'mcp_jumpbox.html', 'mcp_move.html', 'mcp_post.html', 'mcp_queue.html', 'mcp_reports.html', 'mcp_topic.html', 'mcp_viewlogs.html', 'report_body.html', 
 | |
| 			),
 | |
| 			'search'	=> array(
 | |
| 				'search_body.html', 'search_results_posts.html', 'search_results_topics.html', 
 | |
| 			),
 | |
| 			'posting'	=> array(
 | |
| 				'posting_attach_body.html', 'posting_body.html', 'posting_poll_body.html', 'posting_preview.html', 'posting_smilies.html', 'posting_topic_review.html', 
 | |
| 			),
 | |
| 			'login'		=> array(
 | |
| 				'login_body.html', 'login_forum.html', 
 | |
| 			), 
 | |
| 			'custom'	=> array(), 
 | |
| 		);
 | |
| 
 | |
| 		// Lights, Camera ...
 | |
| 		switch ($action)
 | |
| 		{
 | |
| 			case 'edit':
 | |
| 				$tplcols = (isset($_POST['tplcols'])) ? max(20, intval($_POST['tplcols'])) : 80;
 | |
| 				$tplrows = (isset($_POST['tplrows'])) ? max(5, intval($_POST['tplrows'])) : 20;
 | |
| 				$tplname = (isset($_POST['tplname'])) ? htmlspecialchars($_POST['tplname'])  : '';
 | |
| 				$tpldata = (!empty($_POST['tpldata'])) ? stripslashes($_POST['tpldata']) : ''; // NB : STRIPSLASHED!
 | |
| 
 | |
| 				if ($id)
 | |
| 				{
 | |
| 					$sql = 'SELECT * 
 | |
| 						FROM ' . STYLES_TPL_TABLE . "
 | |
| 						WHERE template_id = $id";
 | |
| 					$result = $db->sql_query($sql);
 | |
| 
 | |
| 					if (!(extract($db->sql_fetchrow($result))))
 | |
| 					{
 | |
| 						trigger_error($user->lang['NO_TEMPLATE']);
 | |
| 					}
 | |
| 					$db->sql_freeresult($result);
 | |
| 
 | |
| 					// User wants to submit data ...
 | |
| 					if ($update)
 | |
| 					{
 | |
| 						// Where is the template stored?
 | |
| 						if (!$template_storedb && is_writeable("{$phpbb_root_path}styles/$template_path/template/$tplname"))
 | |
| 						{
 | |
| 							if (!($fp = fopen("{$phpbb_root_path}styles/$template_path/template/$tplname", 'wb')))
 | |
| 							{
 | |
| 								trigger_error($user->lang['NO_TEMPLATE']);
 | |
| 							}
 | |
| 							$stylesheet = fwrite($fp, $tpldata);
 | |
| 							fclose($fp);
 | |
| 						}
 | |
| 						else
 | |
| 						{
 | |
| 							$db->sql_transaction('begin');
 | |
| 
 | |
| 							if (!$template_storedb)
 | |
| 							{
 | |
| 								// We change the path to one relative to the root rather than the theme folder
 | |
| 								$sql = 'UPDATE ' . STYLES_TPL_TABLE . ' 
 | |
| 									SET template_storedb = 1 
 | |
| 									WHERE template_id = ' . $id;
 | |
| 								$db->sql_query($sql);
 | |
| 
 | |
| 								$filelist = filelist("{$phpbb_root_path}styles/$template_path/template");
 | |
| 								$filelist = array('/template' => $filelist['']);
 | |
| 								store_templates('insert', $id, $template_path, $filelist);
 | |
| 							}
 | |
| 
 | |
| 							$sql = 'UPDATE ' . STYLES_TPLDATA_TABLE . " 
 | |
| 								SET template_data = '" . $db->sql_escape($tpldata) . "', template_mtime = " . time() . " 
 | |
| 								WHERE template_id = $id 
 | |
| 									AND template_filename = '" . $db->sql_escape($tplname) . "'";
 | |
| 							$db->sql_query($sql);
 | |
| 
 | |
| 							$db->sql_transaction('commit');
 | |
| 						}
 | |
| 
 | |
| 						@unlink("{$phpbb_root_path}cache/tpl_{$template_name}_$tplname.$phpEx");
 | |
| 
 | |
| 						$error[] = $user->lang['TEMPLATE_UPDATED'];
 | |
| 						add_log('admin', 'LOG_EDIT_TEMPLATE', $template_name, $tplname);
 | |
| 					}
 | |
| 
 | |
| 					$test_ary = array();
 | |
| 					foreach ($tpllist as $category => $tpl_ary)
 | |
| 					{
 | |
| 						$test_ary = array_merge($test_ary, $tpl_ary);
 | |
| 					}
 | |
| 
 | |
| 					if (!$template_storedb)
 | |
| 					{
 | |
| 						$dp = @opendir("{$phpbb_root_path}styles/$template_path/template");
 | |
| 						while ($file = readdir($dp))
 | |
| 						{
 | |
| 							if (!strstr($file, 'bbcode.') && strstr($file, '.html') && !in_array($file, $test_ary) &&  is_file("{$phpbb_root_path}styles/$template_path/template/$file"))
 | |
| 							{
 | |
| 								$tpllist['custom'][] = $file;
 | |
| 							}
 | |
| 						}
 | |
| 						closedir($dp);
 | |
| 						unset($matches);
 | |
| 						unset($test_ary);
 | |
| 
 | |
| 						if ($tplname)
 | |
| 						{
 | |
| 							if (!($fp = fopen("{$phpbb_root_path}styles/$template_path/template/$tplname", 'r')))
 | |
| 							{
 | |
| 								trigger_error($user->lang['NO_TEMPLATE']);
 | |
| 							}
 | |
| 							$tpldata = fread($fp, filesize("{$phpbb_root_path}styles/$template_path/template/$tplname"));
 | |
| 							fclose($fp);
 | |
| 						}
 | |
| 
 | |
| 					}
 | |
| 					else
 | |
| 					{
 | |
| 						$sql = 'SELECT * 
 | |
| 							FROM ' . STYLES_TPLDATA_TABLE . " 
 | |
| 							WHERE template_id = $id";
 | |
| 						$result = $db->sql_query($sql);
 | |
| 
 | |
| 						while ($row = $db->sql_fetchrow($result))
 | |
| 						{
 | |
| 							if (!strstr($row['template_filename'], 'bbcode.') && !in_array($row['template_filename'], $test_ary))
 | |
| 							{
 | |
| 								$tpllist['custom'][] = $row['template_filename'];
 | |
| 							}
 | |
| 
 | |
| 							if ($row['template_filename'] == $tplname)
 | |
| 							{
 | |
| 								$tpldata = $row['template_data'];
 | |
| 							}
 | |
| 						}
 | |
| 						$db->sql_freeresult($result);
 | |
| 					}
 | |
| 
 | |
| 					// List of included templates
 | |
| 					if ($tplname)
 | |
| 					{
 | |
| 						preg_match_all('#<!\-\- INCLUDE (.*?) \-\->#', $tpldata, $included_tpls);
 | |
| 						$included_tpls = $included_tpls[1];
 | |
| 					}
 | |
| 				}
 | |
| 				unset($test_ary);
 | |
| 
 | |
| 				// Generate list of template options
 | |
| 				$tpl_options = '';
 | |
| 				ksort($tpllist);
 | |
| 				foreach ($tpllist as $category => $tpl_ary)
 | |
| 				{
 | |
| 					sort($tpl_ary);
 | |
| 					$tpl_options .= '<option class="sep">' . $category . '</option>';
 | |
| 
 | |
| 					foreach ($tpl_ary as $tpl_file)
 | |
| 					{
 | |
| 						$selected = ($tpl_file == $tplname) ? ' selected="selected"' : '';
 | |
| 						$tpl_options .= '<option value="' . $tpl_file . '"' . $selected . '>' . (($category == 'custom') ? $tpl_file : $tpl_file) . '</option>';
 | |
| 					}
 | |
| 				}
 | |
| 
 | |
| 				// Output page
 | |
| 				adm_page_header($user->lang['EDIT_TEMPLATE']);
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <h1><?php echo $user->lang['EDIT_TEMPLATE']; ?></h1>
 | |
| 
 | |
| <p><?php echo $user->lang['EDIT_TEMPLATE_EXPLAIN']; ?></p>
 | |
| 
 | |
| <p><?php echo $user->lang['SELECTED_TEMPLATE'] . ": <b>$template_name</b>"; ?></p>
 | |
| 
 | |
| <form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&mode=$mode&id=$template_id&action=$action"; ?>"><table cellspacing="1" cellpadding="1" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<td align="right"><?php echo $user->lang['SELECT_TEMPLATE']; ?>: <select name="tplname" onchange="if (this.options[this.selectedIndex].value != '') this.form.submit();"><?php echo $tpl_options; ?></select>  <input class="btnlite" type="submit" value="<?php echo $user->lang['SELECT']; ?>" tabindex="100" /></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td><table class="bg" cellspacing="1" cellpadding="4" border="0">
 | |
| 			<tr>
 | |
| 				<td class="cat"><?php echo $user->lang['TEXT_COLUMNS']; ?>: <input class="post" type="text" name="tplcols" size="3" maxlength="3" value="<?php echo $tplcols; ?>" />  <?php echo $user->lang['TEXT_ROWS']; ?>: <input class="post" type="text" name="tplrows" size="3" maxlength="3" value="<?php echo $tplrows; ?>" />  <input class="btnlite" type="submit" value="<?php echo $user->lang['UPDATE']; ?>" /></td>
 | |
| 			</tr>
 | |
| <?php
 | |
| 
 | |
| 				if (sizeof($error))
 | |
| 				{
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<td class="row1" style="color:green" align="center"><?php echo implode('<br />', $error); ?></td>
 | |
| 			</tr>
 | |
| <?php
 | |
| 
 | |
| 				}
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<th><?php echo $user->lang['RAW_HTML']; ?></th>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row2" align="center"><textarea class="post" style="font-family:'Courier New', monospace;font-size:9pt;line-height:125%;" cols="<?php echo $tplcols; ?>" rows="<?php echo $tplrows; ?>" name="tpldata"><?php echo htmlspecialchars($tpldata); ?></textarea></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="cat" align="center"><input class="btnlite" type="submit" name="update" value="<?php echo $user->lang['SUBMIT']; ?>" />  <input class="btnlite" type="reset" value="<?php echo $user->lang['RESET']; ?>" /></td>
 | |
| 			</tr>
 | |
| 		</table></td>
 | |
| 	</tr>
 | |
| </table></form>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| 				adm_page_footer();
 | |
| 				break;
 | |
| 
 | |
| 			case 'cache':
 | |
| 				$source = (!empty($_GET['source'])) ? htmlspecialchars($_GET['source']) : '';
 | |
| 				$file_ary = (!empty($_POST['delete'])) ? array_map('htmlspecialchars', $_POST['delete']) : '';
 | |
| 
 | |
| 				$sql = 'SELECT * 
 | |
| 					FROM ' . STYLES_TPL_TABLE . "
 | |
| 					WHERE template_id = $id";
 | |
| 				$result = $db->sql_query($sql);
 | |
| 
 | |
| 				if (!(extract($db->sql_fetchrow($result))))
 | |
| 				{
 | |
| 					trigger_error($user->lang['NO_TEMPLATE']);
 | |
| 				}
 | |
| 				$db->sql_freeresult($result);
 | |
| 
 | |
| 				$cache_prefix = "tpl_$template_path";
 | |
| 
 | |
| 				// User wants to delete one or more files ... 
 | |
| 				if ($_POST['update'] && $file_ary)
 | |
| 				{
 | |
| 					foreach ($file_ary as $file)
 | |
| 					{
 | |
| 						$file = "{$phpbb_root_path}cache/{$cache_prefix}_$file.html.$phpEx";
 | |
| 						if (file_exists($file) && is_file($file))
 | |
| 						{
 | |
| 							@unlink($file);
 | |
| 						}
 | |
| 					}
 | |
| 					unset($file_ary);
 | |
| 
 | |
| 					add_log('admin', 'LOG_CLEAR_TPLCACHE', $template_name);
 | |
| 					trigger_error($user->lang['TEMPLATE_CACHE_CLEARED']);
 | |
| 				}
 | |
| 
 | |
| 				// Someone wants to see the cached source ... so we'll highlight it, 
 | |
| 				// add line numbers and indent it appropriately. This could be nasty
 | |
| 				// on larger source files ...
 | |
| 				if ($source && file_exists("{$phpbb_root_path}cache/{$cache_prefix}_$source.html.$phpEx"))
 | |
| 				{
 | |
| 
 | |
| 					adm_page_header($user->lang['TEMPLATE_CACHE']);
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <h1><?php echo $_GET['source']; ?></h1>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| 					$marker = time();
 | |
| 					$code = implode("$marker", file("{$phpbb_root_path}cache/{$cache_prefix}_$source.html.$phpEx"));
 | |
| 
 | |
| 					$conf = array('highlight.bg', 'highlight.comment', 'highlight.default', 'highlight.html', 'highlight.keyword', 'highlight.string');
 | |
| 					foreach ($conf as $ini_var)
 | |
| 					{
 | |
| 						@ini_set($ini_var, str_replace('highlight.', 'syntax', $ini_var));
 | |
| 					}
 | |
| 
 | |
| 					ob_start();
 | |
| 					highlight_string($code);
 | |
| 					$code = ob_get_contents();
 | |
| 					ob_end_clean();
 | |
| 
 | |
| 					$str_from = array('<font color="syntax', '</font>', '<code>', '</code>','[', ']', '.');
 | |
| 					$str_to = array('<span class="syntax', '</span>', '', '', '[', ']', '.');
 | |
| 
 | |
| 					if ($remove_tags)
 | |
| 					{
 | |
| 						$str_from[] = '<span class="syntaxdefault"><?php </span>';
 | |
| 						$str_to[] = '';
 | |
| 						$str_from[] = '<span class="syntaxdefault"><?php ';
 | |
| 						$str_to[] = '<span class="syntaxdefault">';
 | |
| 						$str_from[] = '<span class="syntaxdefault">?></span>';
 | |
| 						$str_to[] = '';
 | |
| 					}
 | |
| 
 | |
| 					$code = str_replace($str_from, $str_to, $code);
 | |
| 					$code = preg_replace('#^(<span class="[a-z_]+">)\n?(.*?)\n?(</span>)$#is', '\1\2\3', $code);
 | |
| 					$code = explode("$marker", $code);
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <table width="95%" cellspacing="0" cellpadding="0" border="0" align="center">
 | |
| <?php 
 | |
| 	
 | |
| 					$i = $j = 1;
 | |
| 					$length = strlen(sizeof($code));
 | |
| 					$indent = str_repeat(' ', $length);
 | |
| 					foreach ($code as $key => $line)
 | |
| 					{
 | |
| 
 | |
| ?>
 | |
| 	<tr valign="top">
 | |
| 		<td class="sourcenum" align="right"><?php echo $i; ?>  </td>
 | |
| 		<td class="source"><?php
 | |
| 
 | |
| 						echo $indent . $line;
 | |
| 						$i++;
 | |
| 						if (strlen($i) > $j)
 | |
| 						{
 | |
| 							$indent = substr($indent, 0, -6);
 | |
| 							$j++;
 | |
| 						}
 | |
| 						unset($code[$key]);
 | |
| 
 | |
| ?></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 					}
 | |
| 
 | |
| ?>
 | |
| </table>
 | |
| 
 | |
| <br clear="all" />
 | |
| 
 | |
| <?php
 | |
| 
 | |
| 					adm_page_footer();
 | |
| 				}
 | |
| 
 | |
| 				if ($template_storedb)
 | |
| 				{
 | |
| 					$sql = 'SELECT template_filename, template_mtime 
 | |
| 						FROM ' . STYLES_TPLDATA_TABLE . " 
 | |
| 						WHERE template_id = $template_id";
 | |
| 					$result = $db->sql_query($sql);
 | |
| 
 | |
| 					$filemtime = array();
 | |
| 					while ($row = $db->sql_fetchrow($result))
 | |
| 					{
 | |
| 						$filemtime[$row['template_filename']] = $row['template_mtime'];
 | |
| 					}
 | |
| 					$db->sql_freeresult($result);
 | |
| 				}
 | |
| 
 | |
| 				// Open the cache directory and grab a list of the relevant cached templates.
 | |
| 				// We also grab some other details such as when the compiled template was
 | |
| 				// created, when the original template was modified and the cached filesize
 | |
| 				if (!($dp = @opendir("{$phpbb_root_path}cache")))
 | |
| 				{
 | |
| 					trigger_error($user->lang['ERR_TPLCACHE_READ']);
 | |
| 				}
 | |
| 
 | |
| 				$tplcache_ary = array();
 | |
| 				while ($file = readdir($dp))
 | |
| 				{
 | |
| 					if (is_file($phpbb_root_path . 'cache/' . $file) && strstr($file, $cache_prefix))
 | |
| 					{
 | |
| 						$filename = preg_replace('#^' . $cache_prefix . '_(.*?)\.html\.' . $phpEx . '$#i', '\1', $file);
 | |
| 						$tplcache_ary[$filename]['cache'] = filemtime("{$phpbb_root_path}cache/$file");
 | |
| 						$tplcache_ary[$filename]['size'] = filesize("{$phpbb_root_path}cache/$file");
 | |
| 						$tplcache_ary[$filename]['src'] = (!$template_storedb) ? filemtime("{$phpbb_root_path}styles/$template_path/template/$filename.html") : $filemtime[$filename . '.html'] ;
 | |
| 					}
 | |
| 				}
 | |
| 				closedir($dp);
 | |
| 
 | |
| 				// Output the page
 | |
| 				adm_page_header($user->lang['TEMPLATE_CACHE']);
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <script language="Javascript" type="text/javascript">
 | |
| <!--
 | |
| function marklist(match, status)
 | |
| {
 | |
| 	len = eval('document.' + match + '.length');
 | |
| 	for (i = 0; i < len; i++)
 | |
| 	{
 | |
| 		eval('document.' + match + '.elements[i].checked = ' + status);
 | |
| 	}
 | |
| }
 | |
| 
 | |
| function viewsource(url)
 | |
| {
 | |
| 	window.open(url, '_source', 'HEIGHT=550,resizable=yes,scrollbars=yes,WIDTH=750');
 | |
| 	return false;
 | |
| }
 | |
| 
 | |
| //-->
 | |
| </script>
 | |
| 
 | |
| <h1><?php echo $user->lang['TEMPLATE_CACHE']; ?></h1>
 | |
| 
 | |
| <p><?php echo $user->lang['TEMPLATE_CACHE_EXPLAIN']; ?></p>
 | |
| 
 | |
| <form name="tplcache" method="post" action="<?php echo "admin_styles.$phpEx$SID&mode=$mode&action=$action&id=$template_id"; ?>"><table class="bg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<th nowrap="nowrap"><?php echo $user->lang['CACHE_FILENAME']; ?></th>
 | |
| 		<th nowrap="nowrap"><?php echo $user->lang['CACHE_FILESIZE']; ?></th>
 | |
| 		<th nowrap="nowrap"><?php echo $user->lang['CACHE_CACHED']; ?></th>
 | |
| 		<th nowrap="nowrap"><?php echo $user->lang['CACHE_MODIFIED']; ?></th>
 | |
| 		<th width="1%"><?php echo $user->lang['MARK']; ?></th>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 				if (sizeof($tplcache_ary))
 | |
| 				{
 | |
| 					foreach ($tplcache_ary as $filename => $times_ary)
 | |
| 					{
 | |
| 						$row_class = ($row_class != 'row1') ? 'row1' : 'row2';
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="<?php echo $row_class; ?>" nowrap="nowrap"><a href="<?php echo "admin_styles.$phpEx$SID&mode=$mode&action=$action&id=$template_id&source=$filename"; ?>" onclick="viewsource('<?php echo "admin_styles.$phpEx$SID&mode=$mode&action=$action&id=$template_id&source=$filename"; ?>');return false"><?php echo $filename; ?></a></td>
 | |
| 		<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap"><?php echo sprintf('%.1f KB', $times_ary['size'] / 1024); ?></td>
 | |
| 		<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap"><?php echo $user->format_date($times_ary['cache']); ?></td>
 | |
| 		<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap"><?php echo $user->format_date($times_ary['src']); ?></td>
 | |
| 		<td class="<?php echo $row_class; ?>" width="1%" align="center"><input type="checkbox" name="delete[]" value="<?php echo $filename; ?>" /></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 					}
 | |
| 				}
 | |
| 				else
 | |
| 				{
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row1" colspan="5" align="center"><?php echo $user->lang['NO_CACHED_TPL_FILES']; ?></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 				}
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="cat" colspan="5" align="right"><input class="btnlite" type="submit" name="update" value="<?php echo $user->lang['DELETE_MARKED']; ?>" /></td>
 | |
| 	</tr>
 | |
| </table>
 | |
| 
 | |
| <table width="95%" cellspacing="1" cellpadding="1" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<td align="right"><b><span class="gensmall"><a href="javascript:marklist('tplcache', true);" class="gensmall"><?php echo $user->lang['MARK_ALL']; ?></a> :: <a href="javascript:marklist('tplcache', false);" class="gensmall"><?php echo $user->lang['UNMARK_ALL']; ?></a></span></b></td>
 | |
| 	</tr>
 | |
| </table></form>
 | |
| <?php
 | |
| 
 | |
| 				adm_page_footer();
 | |
| 				break;
 | |
| 
 | |
| 			case 'refresh':
 | |
| 				if ($id)
 | |
| 				{
 | |
| 					$sql = 'SELECT template_path, template_storedb
 | |
| 						FROM ' . STYLES_TPL_TABLE . " 
 | |
| 						WHERE template_id = $id";
 | |
| 					$result = $db->sql_query($sql);
 | |
| 
 | |
| 					if (!extract($db->sql_fetchrow($result)))
 | |
| 					{
 | |
| 						trigger_error($user->lang['NO_TEMPLATE']);
 | |
| 					}
 | |
| 					$db->sql_freeresult($result);
 | |
| 
 | |
| 					if ($template_storedb && file_exists("{$phpbb_root_path}styles/$template_path/template/"))
 | |
| 					{
 | |
| 						$filelist = array('/' => array());
 | |
| 
 | |
| 						$sql = 'SELECT template_filename, template_mtime 
 | |
| 							FROM ' . STYLES_TPLDATA_TABLE . "
 | |
| 							WHERE template_id = $id";
 | |
| 						$result = $db->sql_query($sql);
 | |
| 
 | |
| 						while ($row = $db->sql_fetchrow($result))
 | |
| 						{
 | |
| 							if (@filemtime("{$phpbb_root_path}styles/$template_path/template/" . $row['template_filename']) > $row['template_mtime'])
 | |
| 							{
 | |
| 								$filelist['/'][] = $row['template_filename'];
 | |
| 							}
 | |
| 						}
 | |
| 						$db->sql_freeresult($result);
 | |
| 
 | |
| 						store_templates('update', $id, $template_path, $filelist);
 | |
| 						unset($filelist);
 | |
| 					}
 | |
| 				}
 | |
| 				break;
 | |
| 		}
 | |
| 
 | |
| 		// Front page
 | |
| 		frontend('template', array('cache', 'details', 'refresh', 'export', 'delete'));
 | |
| 		break;
 | |
| 
 | |
| 
 | |
| 	// THEMES
 | |
| 	case 'theme':
 | |
| 		switch ($action)
 | |
| 		{
 | |
| 			case 'edit':
 | |
| 				// General parameters
 | |
| 				$class = (isset($_POST['classname'])) ? htmlspecialchars($_POST['classname']) : '';
 | |
| 				$customclass = (!empty($_POST['customclass'])) ? htmlspecialchars($_POST['customclass']) : '';
 | |
| 
 | |
| 				$txtcols = (isset($_POST['txtcols'])) ? max(20, intval($_POST['txtcols'])) : 76;
 | |
| 				$txtrows = (isset($_POST['txtrows'])) ? max(5, intval($_POST['txtrows'])) : 10;
 | |
| 				$showcss = (!empty($_POST['showcss'])) ? true : ((!empty($_POST['hidecss'])) ? false : ((!empty($_GET['showcss'])) ? true : false));
 | |
| 
 | |
| 				// List of default classes, categorised
 | |
| 				$base_classes = array(
 | |
| 					'text'	=> array(
 | |
| 						'body',  'p',  'h1',  'h2',  'h3',  '.tabletitle',  '.cattitle',  '.topictitle',  '.topicauthor',  '.topicdetails',  '.postdetails',  '.postbody',  '.posthilit', '.postauthor',  '.mainmenu', '.nav', '.genmed',  '.gensmall',  '.copyright',
 | |
| 					),
 | |
| 					'tables'	=> array(
 | |
| 						'table',  'th', '.cat',  '.catdiv',  'td',  '.row1',  '.row2',  '.row3',  '.spacer',  'hr', 
 | |
| 					),
 | |
| 					'forms'		=> array(
 | |
| 						'form',  'input',  'select',  'textarea',  '.post',  '.btnlite', '.btnmain', '.btnbbcode',
 | |
| 					), 
 | |
| 					'bbcode'	=> array(
 | |
| 						'.b', '.u', '.i', '.color', '.size', '.code', '.quote', '.flash', '.syntaxbg',  '.syntaxcomment', '.syntaxdefault', '.syntaxhtml', '.syntaxkeyword', '.syntaxstring',
 | |
| 					), 
 | |
| 					'custom'	=> array(),
 | |
| 				);
 | |
| 
 | |
| 				// We categorise the elements which comprise the css class so that we set 
 | |
| 				// any appropriate additional data, e.g. sizes require the scale type to be set, 
 | |
| 				// images require the relevant image be pulled and selected in the dropdown, etc.
 | |
| 				$match_elements = array(
 | |
| 					'colors'	=> array('background-color', 'color',),
 | |
| 					'sizes'		=> array('font-size', 'line-height',),
 | |
| 					'images'	=> array('background-image',),
 | |
| 					'repeat'	=> array('background-repeat',),
 | |
| 					'other'		=> array('font-weight', 'font-family', 'font-style', 'text-decoration',),
 | |
| 				);
 | |
| 
 | |
| 				// Used in an sprintf statement to generate appropriate output for rawcss mode
 | |
| 				$map_elements = array(
 | |
| 					'colors'	=> '%s',
 | |
| 					'sizes'		=> '%d%s',
 | |
| 					'images'	=> 'url(\'./%s\')',
 | |
| 					'repeat'	=> '%s',
 | |
| 					'other'		=> '%s',
 | |
| 				);
 | |
| 
 | |
| 				$s_hidden_fields = '';
 | |
| 
 | |
| 				// Do we want to edit an existing theme?
 | |
| 				if ($id)
 | |
| 				{
 | |
| 					$sql = 'SELECT * 
 | |
| 						FROM ' . STYLES_CSS_TABLE . "
 | |
| 						WHERE theme_id = $id";
 | |
| 					$result = $db->sql_query($sql);
 | |
| 
 | |
| 					if (!(extract($db->sql_fetchrow($result))))
 | |
| 					{
 | |
| 						trigger_error($user->lang['NO_THEME']);
 | |
| 					}
 | |
| 					$db->sql_freeresult($result);
 | |
| 					
 | |
| 
 | |
| 					// Where is the CSS stored?
 | |
| 					if (!$theme_storedb)
 | |
| 					{
 | |
| 						if (!($fp = fopen("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css", 'rb')))
 | |
| 						{
 | |
| 							trigger_error($user->lang['NO_THEME']);
 | |
| 						}
 | |
| 						$stylesheet = fread($fp, filesize("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css"));
 | |
| 						fclose($fp);
 | |
| 					}
 | |
| 					else
 | |
| 					{
 | |
| 						$stylesheet = &$theme_data;
 | |
| 					}
 | |
| 
 | |
| 					// Pull out list of "custom" tags
 | |
| 					$class_used = $test_ary = array();
 | |
| 					if (preg_match_all('/^([a-z0-9\.:#>]+?)[ \t]*?\{.*?\}/msi', $stylesheet, $matches))
 | |
| 					{
 | |
| 						foreach ($base_classes as $category => $class_ary)
 | |
| 						{
 | |
| 							$test_ary = array_merge($test_ary, $class_ary);
 | |
| 						}
 | |
| 
 | |
| 						foreach ($matches[1] as $value)
 | |
| 						{
 | |
| 							if (!in_array($value, $test_ary))
 | |
| 							{
 | |
| 								$base_classes['custom'][] = $value;
 | |
| 							}
 | |
| 							else
 | |
| 							{
 | |
| 								$class_used[] = $value;
 | |
| 							}
 | |
| 						}
 | |
| 						unset($matches);
 | |
| 						unset($test_ary);
 | |
| 					}				
 | |
| 				}
 | |
| 
 | |
| 				// Do we have a class set? If so, we need to extract and set the relevant data
 | |
| 				if (!empty($class))
 | |
| 				{
 | |
| 					// We must generate the relevant data ... what we need depends on whether
 | |
| 					// we are looking @ the rawcss or the simplified settings and whether we
 | |
| 					// have just selected a class. We must also cope with switching between 
 | |
| 					// simple and rawcss mode
 | |
| 					$css_element = array();
 | |
| 					if (!empty($_POST['rawcss']) && (!empty($_POST['hidecss']) || !empty($_POST['preview']) || $update))
 | |
| 					{
 | |
| 						$css_element = trim(stripslashes(htmlspecialchars(preg_replace("#;[\r\n]*#s", "\n", $_POST['rawcss']))));
 | |
| 						$css_element = explode("\n", $css_element);
 | |
| 					}
 | |
| 					else if (($showcss && !empty($_POST['showcss'])) || !empty($_POST['preview']) || $update)
 | |
| 					{
 | |
| 						if (!empty($_POST['cssother']))
 | |
| 						{
 | |
| 							$css_element = explode(';', stripslashes(htmlspecialchars(trim($_POST['cssother']))));
 | |
| 						}
 | |
| 
 | |
| 						foreach ($match_elements as $type => $match_ary)
 | |
| 						{
 | |
| 							foreach ($match_ary as $match)
 | |
| 							{
 | |
| 								$var = str_replace('-', '_', $match);
 | |
| 								if (!empty($_POST[$var]))
 | |
| 								{
 | |
| 									$css_element[] = str_replace('_', '-', $var) . ': ' . (($type == 'sizes') ? sprintf($map_elements[$type], stripslashes($_POST[$var]), $_POST[$var . '_units']) : sprintf($map_elements[$type], stripslashes($_POST[$var])));
 | |
| 								}
 | |
| 							}
 | |
| 						}
 | |
| 					}
 | |
| 					else if (preg_match('#^' . $class . '[ \t]*?\{(.*?)\}#ms', $stylesheet, $matches))
 | |
| 					{
 | |
| 						$css_element = explode(';', substr(trim($matches[1]), 0, -1));
 | |
| 					}
 | |
| 
 | |
| 					$css_element = preg_replace('#^\s*(.*?)\s*$#', '\1', $css_element);
 | |
| 
 | |
| 					// User wants to submit data ...
 | |
| 					if ($update || $customclass)
 | |
| 					{	
 | |
| 						if ($update)
 | |
| 						{
 | |
| 							$updated_element = trim(implode('; ', $css_element)) . ';';
 | |
| 							if (preg_match('#^' . $class . '[ \t]*?\{(.*?)\}#ms', $stylesheet))
 | |
| 							{
 | |
| 								$stylesheet = preg_replace('#^(' . $class . '[ \t]*?\{).*?(\})#m', '\1 ' . $updated_element . ' \2', $stylesheet);
 | |
| 							}
 | |
| 							$error[] = $user->lang['THEME_UPDATED'];
 | |
| 						}
 | |
| 						else
 | |
| 						{
 | |
| 							// Check custom class name is valid
 | |
| 							if (!preg_match('/^[a-z0-9#:\.]+$/i', $customclass))
 | |
| 							{
 | |
| 								$error[] = $user->lang['THEME_ERR_CLASS_CHARS'];
 | |
| 							}
 | |
| 							else
 | |
| 							{
 | |
| 								$stylesheet .= "\n$customclass { }";
 | |
| 								$base_classes['custom'][] = $customclass;
 | |
| 								$error[] = $user->lang['THEME_CLASS_ADDED'];
 | |
| 							}
 | |
| 						}
 | |
| 
 | |
| 						// Where is the CSS stored?
 | |
| 						if (!$storedb && is_writeable("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css"))
 | |
| 						{
 | |
| 							// Grab template data
 | |
| 							if (!($fp = fopen("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css", 'wb')))
 | |
| 							{
 | |
| 								trigger_error($user->lang['NO_THEME']);
 | |
| 							}
 | |
| 							$stylesheet = fwrite($fp, $stylesheet);
 | |
| 							fclose($fp);
 | |
| 						}
 | |
| 						else
 | |
| 						{
 | |
| 							// We change the path to one relative to the root rather than the theme folder
 | |
| 							$sql_ary = array(
 | |
| 								'theme_storedb'		=> 1,
 | |
| 								'theme_data'		=> str_replace('./', "styles/$theme_path/theme/", $stylesheet),
 | |
| 							);
 | |
| 							$sql = 'UPDATE ' . STYLES_CSS_TABLE . ' 
 | |
| 								SET ' . $db->sql_build_array('UPDATE', $sql_ary) . ' 
 | |
| 								WHERE theme_id = ' . $id;
 | |
| 							$db->sql_query($sql);
 | |
| 						}
 | |
| 
 | |
| 						$cache->destroy('sql', STYLES_CSS_TABLE);
 | |
| 						add_log('admin', 'LOG_EDIT_THEME', $theme_name);
 | |
| 					}
 | |
| 
 | |
| 					// I guess really this needs some basic examples, pulled from subSilver
 | |
| 					// to demonstrate the default classes. Other, custom classes can just use
 | |
| 					// the div/span and some text? This is gonna get nasty :(
 | |
| 					if (!empty($_POST['preview']))
 | |
| 					{
 | |
| 						// Temp, just to get this out of the way
 | |
| 						theme_preview($theme_path, $stylesheet, $class, $css_element);
 | |
| 						exit;
 | |
| 					}
 | |
| 
 | |
| 					// Here we pull out the appropriate class entry then proceed to pull it apart,
 | |
| 					// setting appropriate variables to their respective values. We only match
 | |
| 					// certain css elements, the rest are "hidden" and can be accessed by exposing
 | |
| 					// the raw css
 | |
| 					if (!$showcss)
 | |
| 					{
 | |
| 						foreach ($match_elements as $type => $match_ary)
 | |
| 						{
 | |
| 							foreach ($match_ary as $match)
 | |
| 							{
 | |
| 								$var = str_replace('-', '_', $match);
 | |
| 								$$var = '';
 | |
| 
 | |
| 								if (sizeof($css_element))
 | |
| 								{
 | |
| 									foreach ($css_element as $key => $element)
 | |
| 									{
 | |
| 										if (preg_match('#^' . preg_quote($match, '#') . ':[ \t]*?(.*?)$#', $element, $matches))
 | |
| 										{
 | |
| 											switch ($type)
 | |
| 											{
 | |
| 												case 'sizes':
 | |
| 													if (preg_match('#(.*?)(px|%|em|pt)#', $matches[1], $matches))
 | |
| 													{
 | |
| 														${$var . '_units'} = trim($matches[2]);
 | |
| 													}
 | |
| 													$$var = trim($matches[1]);
 | |
| 													break;
 | |
| 
 | |
| 												case 'images':
 | |
| 													if (preg_match('#url\(\'(.*?)\'\)#', $matches[1], $matches))
 | |
| 													{
 | |
| 														$$var = trim($matches[1]);
 | |
| 														$$var = str_replace('./', $theme_name . '/', $$var);
 | |
| 													}
 | |
| 													break;
 | |
| 
 | |
| 												default:
 | |
| 													$$var = trim($matches[1]);
 | |
| 											}
 | |
| 
 | |
| 											// Remove this element from array
 | |
| 											unset($css_element[$key]);
 | |
| 											break;
 | |
| 										}
 | |
| 									}
 | |
| 								}
 | |
| 							}
 | |
| 						}
 | |
| 
 | |
| 						// Any remaining elements must be custom data so we save that
 | |
| 						// in a hidden field
 | |
| 						if (sizeof($css_element))
 | |
| 						{
 | |
| 							$s_hidden_fields .= '<input type="hidden" name="cssother" value="' . addslashes(implode('; ', $css_element)) . '" />';
 | |
| 						}
 | |
| 					}
 | |
| 				}
 | |
| 				// End of class element variable setting
 | |
| 
 | |
| 				// Generate list of class options
 | |
| 				$class_options = '';
 | |
| 				foreach ($base_classes as $category => $class_ary)
 | |
| 				{
 | |
| 					$class_options .= '<option class="sep">' . $user->lang['CSS_CAT_' . strtoupper($category)] . '</option>';
 | |
| 					foreach ($class_ary as $class_name)
 | |
| 					{
 | |
| 						$used = (in_array($class_name, $class_used) || $category == 'custom') ? ' style="color:red"' : '';
 | |
| 						$selected = ($class_name == $class) ? ' selected="selected"' : '';
 | |
| 						$class_options .= '<option' . $used . ' value="' . $class_name . '"' . $selected . '>' . (($category == 'custom') ? $class_name : $user->lang['CSS_' . str_replace('.', '', strtoupper($class_name))]) . '</option>';
 | |
| 					}
 | |
| 				}
 | |
| 				unset($class_used);
 | |
| 
 | |
| 				// Grab list of potential images for class backgrounds
 | |
| 				$imglist = filelist("{$phpbb_root_path}styles/$theme_path/theme");
 | |
| 
 | |
| 				$bg_imglist = '';
 | |
| 				foreach ($imglist as $path => $img_ary)
 | |
| 				{
 | |
| 					foreach ($img_ary as $img)
 | |
| 					{
 | |
| 						$img = ((substr($path, 0, 1) == '/') ? substr($path, 1) : $path) . $img; 
 | |
| 
 | |
| 						$selected = (preg_match('#' . preg_quote($img) . '$#', $background_image)) ? ' selected="selected"' : '';
 | |
| 						$bg_imglist .= '<option value="' . htmlspecialchars($img) . '"' . $selected . '>' . $img . '</option>';
 | |
| 					}
 | |
| 				}
 | |
| 				$bg_imglist = '<option value=""' . (($edit_img == '') ? ' selected="selected"' : '') . '>' . $user->lang['NONE'] . '</option>' . $bg_imglist;
 | |
| 				unset($imglist);
 | |
| 
 | |
| 				// Output the page
 | |
| 				adm_page_header($user->lang['EDIT_THEME']);
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <script language="javascript" type="text/javascript">
 | |
| <!--
 | |
| 
 | |
| function swatch(field)
 | |
| {
 | |
| 	window.open('./swatch.<?php echo "$phpEx?form=style&name="; ?>' + field, '_swatch', 'HEIGHT=115,resizable=yes,scrollbars=no,WIDTH=636');
 | |
| 	return false;
 | |
| }
 | |
| 
 | |
| function csspreview()
 | |
| {
 | |
| 	if (document.myvar == 'preview')
 | |
| 	{
 | |
| 		window.open('', '_preview', 'HEIGHT=400,resizable=yes,scrollbars=yes,WIDTH=500');
 | |
| 		document.forms['style'].target =  '_preview';
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		document.forms['style'].target =  '_self';
 | |
| 	}
 | |
| 	document.myvar='';
 | |
| 
 | |
| 	return true;
 | |
| }
 | |
| 
 | |
| //-->
 | |
| </script>
 | |
| 
 | |
| <h1><?php echo $user->lang['EDIT_THEME']; ?></h1>
 | |
| 
 | |
| <p><?php echo $user->lang['EDIT_THEME_EXPLAIN']; ?></p>
 | |
| 
 | |
| <p><?php echo $user->lang['SELECTED_THEME'] . ": <b>$theme_name</b>"; ?></p>
 | |
| <?php 
 | |
| 
 | |
| 				if ($showcss)
 | |
| 				{
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <h3><?php echo $user->lang['SHOW_RAW_CSS_NOTE']; ?></h3>
 | |
| 
 | |
| <p><?php echo $user->lang['SHOW_RAW_CSS_EXPLAIN']; ?></p>
 | |
| <?php
 | |
| 
 | |
| 				}
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&mode=$mode&action=$action&id=$id&showcss=$showcss"; ?>" onsubmit="return csspreview()"><table width="95%" cellspacing="1" cellpadding="1" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<td align="right"><?php echo $user->lang['SELECT_CLASS']; ?>: <select name="classname" onchange="if (this.options[this.selectedIndex].value != ''){ csspreview(); this.form.submit(); }"><?php echo $class_options; ?></select>  <input class="btnlite" type="submit" value="<?php echo $user->lang['SELECT']; ?>" tabindex="100" /></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td><table class="bg" width="100%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| <?php
 | |
| 
 | |
| 				if ($showcss)
 | |
| 				{
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<th colspan="2"><?php echo $user->lang['RAW_CSS']; ?></th>
 | |
| 			</tr>
 | |
| <?php
 | |
| 
 | |
| 					if (sizeof($error) && ($update || $customclass))
 | |
| 					{
 | |
| 						echo '<tr><td class="row1" colspan="2" align="center"><span class="gen" style="color:green" align="center">' . implode('<br />', $error) . '</span></td></tr>';
 | |
| 					}
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<td class="row2" colspan="2" align="center"><textarea class="post" style="font-family:'Courier New', monospace;font-size:10pt;line-height:125%;" name="rawcss" rows="<?php echo $txtrows; ?>" cols="<?php echo $txtcols; ?>"><?php echo (sizeof($css_element)) ? implode(";\n", $css_element) . ';' : ''; ?></textarea></td>
 | |
| 			</tr>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| 				}
 | |
| 				else
 | |
| 				{
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<th><?php echo $user->lang['CSS_PARAMETER']; ?></th>
 | |
| 				<th><?php echo $user->lang['CSS_VALUE']; ?></th>
 | |
| 			</tr>
 | |
| <?php
 | |
| 
 | |
| 					if (sizeof($error) && ($update || $customclass))
 | |
| 					{
 | |
| 						echo '<tr><td class="row1" colspan="2" align="center"><span class="gen" style="color:green" align="center">' . implode('<br />', $error) . '</span></td></tr>';
 | |
| 					}
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<td class="row3" colspan="2"><b><?php echo $user->lang['BACKGROUND']; ?></b></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" width="40%"><b><?php echo $user->lang['BACKGROUND_COLOUR']; ?>:</b> <br /><span class="gensmall"><?php echo $user->lang['COLOUR_EXPLAIN']; ?></span></td>
 | |
| 				<td class="row2"><table cellspacing="0" cellpadding="0" border="0"><tr><td><input class="post" type="text" name="background_color" value="<?php echo $background_color; ?>" size="8" maxlength="14"  onchange="document.all.stylebgcolor.bgColor=this.form.background_color.value" /></td><td> </td><td bgcolor="<?php echo $background_color; ?>" id="stylebgcolor" style="border:solid 1px black;"><img src="../images/spacer.gif" width="45" height="15" alt="" /></td><td class="gensmall">   [ <a href="swatch.<?php echo $phpEx; ?>" onclick="swatch('background_color');return false" target="_swatch"><?php echo $user->lang['COLOUR_SWATCH']; ?></a> ]</td></tr></table></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1"><b><?php echo $user->lang['BACKGROUND_IMAGE']; ?>:</b></td>
 | |
| 				<td class="row2"><select name="background_image"><?php echo $bg_imglist ?></select></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1"><b><?php echo $user->lang['BACKGROUND_REPEAT']; ?>:</b></td>
 | |
| 				<td class="row2"><select name="background_repeat"><?php
 | |
| 
 | |
| 					foreach (array('' => '------', 'none' => $user->lang['REPEAT_NO'], 'repeat-x' => $user->lang['REPEAT_X'], 'repeat-y' => $user->lang['REPEAT_Y'], 'both' => $user->lang['REPEAT_ALL']) as $cssvalue => $cssrepeat)
 | |
| 					{
 | |
| 						echo '<option value="' . $cssvalue . '"' . (($background_repeat == $cssvalue) ? ' selected="selected"' : '') . '>' . $cssrepeat . '</option>';
 | |
| 					}
 | |
| 	
 | |
| ?></select></td>
 | |
| 			</tr>
 | |
| 
 | |
| 
 | |
| 			<tr>
 | |
| 				<td class="row3" colspan="2"><b><?php echo $user->lang['FOREGROUND']; ?></b></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" width="40%"><b><?php echo $user->lang['FONT_COLOUR']; ?>:</b> <br /><span class="gensmall"><?php echo $user->lang['COLOUR_EXPLAIN']; ?></span></td>
 | |
| 				<td class="row2"><table cellspacing="0" cellpadding="0" border="0"><tr><td><input class="post" type="text" name="color" value="<?php echo $color; ?>" size="8" maxlength="14" onchange="document.all.stylecolor.bgColor=this.form.color.value" /></td><td> </td><td bgcolor="<?php echo $color; ?>" id="stylecolor" style="border:solid 1px black;"><img src="../images/spacer.gif" width="45" height="15" alt="" /></td><td class="gensmall">   [ <a href="swatch.<?php echo $phpEx; ?>" onclick="swatch('color');return false" target="_swatch"><?php echo $user->lang['COLOUR_SWATCH']; ?></a> ]</td></tr></table></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" width="40%"><b><?php echo $user->lang['FONT_FACE']; ?>:</b> <br /><span class="gensmall"><?php echo $user->lang['FONT_FACE_EXPLAIN']; ?></span></td>
 | |
| 				<td class="row2"><input class="post" type="text" name="font_family" value="<?php echo $font_family; ?>" size="40" maxlength="255" /></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1"><b><?php echo $user->lang['FONT_SIZE']; ?>:</b></td>
 | |
| 				<td class="row2"><input class="post" type="text" name="font_size" value="<?php echo $font_size; ?>" size="3" maxlength="3" /> <select name="font_size_units"><?php
 | |
| 
 | |
| 					foreach (array('pt', 'px', 'em', '%') as $units)
 | |
| 					{
 | |
| 						echo '<option value="' . $units . '"' . (($font_size_units == $units) ? ' selected="selected"' : '') . '>' . $units . '</option>';
 | |
| 					}
 | |
| 	
 | |
| ?></select></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1"><b><?php echo $user->lang['BOLD']; ?>:</b></td>
 | |
| 				<td class="row2"><input type="radio" name="font_weight" value="bold"<?php echo (!empty($font_weight) && $font_weight == 'bold') ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['YES']; ?>   <input type="radio" name="font_weight" value="normal"<?php echo (!empty($font_weight) && $font_weight == 'normal') ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['NO']; ?>   <input type="radio" name="font_weight" value=""<?php echo (empty($font_weight)) ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['UNSET']; ?></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1"><b><?php echo $user->lang['ITALIC']; ?>:</b></td>
 | |
| 				<td class="row2"><input type="radio" name="font_style" value="italic"<?php echo (!empty($font_style) && $font_style == 'italic') ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['YES']; ?>   <input type="radio" name="font_style" value="normal"<?php echo (!empty($font_style) && $font_style == 'normal') ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['NO']; ?>   <input type="radio" name="font_style" value=""<?php echo (empty($font_style)) ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['UNSET']; ?></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1"><b><?php echo $user->lang['UNDERLINE']; ?>:</b></td>
 | |
| 				<td class="row2"><input type="radio" name="text_decoration" value="underline"<?php echo (!empty($text_decoration) && $text_decoration == 'underline') ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['YES']; ?>   <input type="radio" name="text_decoration" value="none"<?php echo (!empty($text_decoration) && $text_decoration == 'none') ? ' checked="checked"' : ''; ?>/> <?php echo $user->lang['NO']; ?>   <input type="radio" name="text_decoration" value=""<?php echo (empty($text_decoration)) ? ' checked="checked"' : ''; ?>/> <?php echo $user->lang['UNSET']; ?></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1"><b><?php echo $user->lang['LINE_SPACING']; ?>:</b></td>
 | |
| 				<td class="row2"><input class="post" type="text" name="line_height" value="<?php echo $line_height; ?>" size="3" maxlength="3" /> <select name="line_height_units"><?php
 | |
| 
 | |
| 					foreach (array('pt', 'px', 'em', '%') as $units)
 | |
| 					{
 | |
| 						echo '<option value="' . $units . '"' . (($line_height_units == $units) ? ' selected="selected"' : '') . '>' . $units . '</option>';
 | |
| 					}
 | |
| 	
 | |
| ?></select></td>
 | |
| 			</tr>
 | |
| <?php
 | |
| 
 | |
| 				}
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="update" value="<?php echo $user->lang['SUBMIT']; ?>"; />  <input class="btnlite" type="submit" name="preview" value="<?php echo $user->lang['PREVIEW']; ?>" onclick="document.myvar='preview';" />  <input class="btnlite" type="reset" value="<?php echo $user->lang['RESET']; ?>" />  <?php
 | |
| 									
 | |
| 				echo ($showcss) ? '<input class="btnlite" type="submit" name="hidecss" value="' . $user->lang['HIDE_RAW_CSS'] . '" />' : '<input class="btnlite" type="submit" name="showcss" value="' . $user->lang['SHOW_RAW_CSS'] . '" />';
 | |
| 				echo $s_hidden_fields; 
 | |
| 				
 | |
| ?></td>
 | |
| 			</tr>
 | |
| 		</table></td>
 | |
| 	</tr>
 | |
| </table>
 | |
| 
 | |
| <h1><?php echo $user->lang['CUSTOM_CLASS']; ?></h1>
 | |
| 
 | |
| <p><?php echo $user->lang['CUSTOM_CLASS_EXPLAIN']; ?></p>
 | |
| 
 | |
| <table width="95%" cellspacing="1" cellpadding="1" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<td><table class="bg" width="100%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 			<tr>
 | |
| 				<th colspan="2"><?php echo $user->lang['CUSTOM_CLASS']; ?></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" width="40%"><b><?php echo $user->lang['CSS_CLASS_NAME']; ?>:</b></td>
 | |
| 				<td class="row2"><input class="post" type="text" name="customclass" value="" maxlength="15" size="15" /></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="addclass" value="<?php echo $user->lang['SUBMIT']; ?>" />  <input class="btnlite" type="reset" value="<?php echo $user->lang['RESET']; ?>" /></td>
 | |
| 			</tr>
 | |
| 		</table>
 | |
| 	
 | |
| 		</td>
 | |
| 	</tr>
 | |
| </table></form>
 | |
| <?php
 | |
| 
 | |
| 				adm_page_footer();
 | |
| 				break;
 | |
| 		}
 | |
| 
 | |
| 		// Front page
 | |
| 		frontend('theme', array('details', 'refresh', 'export', 'delete'));
 | |
| 		break;
 | |
| 
 | |
| 
 | |
| 	// IMAGESETS
 | |
| 	case 'imageset':
 | |
| 		$imglist = array(
 | |
| 			'buttons'	=> array(
 | |
| 				'btn_post', 'btn_reply', 'btn_locked', 'btn_quote', 'btn_edit', 'btn_delete', 'btn_report', 'btn_post_pm', 'btn_reply_pm', 'btn_profile', 'btn_pm', 'btn_ip', 'btn_search', 'btn_email', 'btn_www', 'btn_icq', 'btn_aim', 'btn_yim', 'btn_msnm', 'btn_jabber', 'btn_online', 'btn_offline',
 | |
| 			),
 | |
| 			'icons'		=> array(
 | |
| 				'icon_unapproved', 'icon_reported', 'icon_attach', 'icon_post', 'icon_post_new', 'icon_post_latest', 'icon_post_newest',),
 | |
| 			'forums'		=> array(
 | |
| 				'forum', 'forum_new', 'forum_locked', 'forum_link', 'sub_forum', 'sub_forum_new',),
 | |
| 			'folders'	=> array(
 | |
| 				'folder', 'folder_posted', 'folder_new', 'folder_new_posted', 'folder_hot', 'folder_hot_posted', 'folder_hot_new', 'folder_hot_new_posted', 'folder_locked', 'folder_locked_posted', 'folder_locked_new', 'folder_locked_new_posted', 'folder_sticky', 'folder_sticky_posted', 'folder_sticky_new', 'folder_sticky_new_posted', 'folder_announce', 'folder_announce_posted', 'folder_announce_new', 'folder_announce_new_posted',),
 | |
| 			'polls'		=> array(
 | |
| 				'poll_left', 'poll_center', 'poll_right',), 
 | |
| 		);
 | |
| 
 | |
| 		switch ($action)
 | |
| 		{
 | |
| 			case 'edit':
 | |
| 				$imgname = (!empty($_POST['imgname'])) ? htmlspecialchars($_POST['imgname']) : '';
 | |
| 				$imgpath = (isset($_POST['imgpath'])) ? htmlspecialchars($_POST['imgpath']) : '';
 | |
| 				$imgsize = (!empty($_POST['imgsize'])) ? true : false;
 | |
| 				$imgwidth = (isset($_POST['imgwidth'])) ? intval($_POST['imgwidth']) : '';
 | |
| 
 | |
| 				if ($id)
 | |
| 				{
 | |
| 					$sql_select = ($imgname) ? ", $imgname" : '';
 | |
| 					$sql = "SELECT imageset_path, imageset_name, imageset_copyright$sql_select
 | |
| 						FROM " . STYLES_IMAGE_TABLE . "
 | |
| 						WHERE imageset_id = $id";
 | |
| 					$result = $db->sql_query($sql);
 | |
| 
 | |
| 					if (!extract($db->sql_fetchrow($result)))
 | |
| 					{
 | |
| 						trigger_error($user->lang['NO_IMAGESET']);
 | |
| 					}
 | |
| 					$db->sql_freeresult($result);
 | |
| 
 | |
| 					// Check to see whether the selected image exists in the table
 | |
| 					$valid_name = false;
 | |
| 					foreach ($imglist as $category => $img_ary)
 | |
| 					{
 | |
| 						if (in_array($imgname, $img_ary))
 | |
| 						{
 | |
| 							$valid_name = true;
 | |
| 							break;
 | |
| 						}
 | |
| 					}
 | |
| 
 | |
| 					if (!$valid_name)
 | |
| 					{
 | |
| 						$error[] = $user->lang['NO_IMAGE'];
 | |
| 					}
 | |
| 
 | |
| 					if ($update && $imgpath)
 | |
| 					{
 | |
| 						if (!sizeof($error))
 | |
| 						{
 | |
| 							// If imgwidth and imgheight are non-zero grab the actual size
 | |
| 							// from the image itself ... we ignore width settings for the poll center
 | |
| 							// image
 | |
| 							$imgwidth = $imgheight = '';
 | |
| 							if ($imgsize)
 | |
| 							{
 | |
| 								list($imgwidth, $imgheight) = getimagesize("{$phpbb_root_path}styles/$imageset_path/imageset/$imgpath");
 | |
| 								$imgwidth = ($imgname != 'poll_center') ? " width=\"$imgwidth\"" : '';
 | |
| 								$imgheight = " height=\"$imgheight\"";
 | |
| 							}
 | |
| 
 | |
| 							$imgpath = '"styles/' . $imageset_path . '/imageset/' . preg_replace('#^(.*?)/(.*?)$#', '{LANG}/\2', $imgpath)  . '" border="0"' . $imgwidth . $imgheight;
 | |
| 
 | |
| 							$sql = 'UPDATE ' . STYLES_IMAGE_TABLE . "
 | |
| 								SET $imgname = '$imgpath'
 | |
| 								WHERE imageset_id = $id";
 | |
| 							$db->sql_query($sql);
 | |
| 
 | |
| 							$cache->destroy('sql', STYLES_IMAGE_TABLE);
 | |
| 
 | |
| 							add_log('admin', 'LOG_EDIT_IMAGESET', $imageset_name);
 | |
| 							$error[] = $user->lang['IMAGESET_UPDATED'];
 | |
| 
 | |
| 							$$imgname = $imgpath;
 | |
| 						}
 | |
| 					}
 | |
| 
 | |
| 					$test_ary = array();
 | |
| 					foreach ($imglist as $category => $img_ary)
 | |
| 					{
 | |
| 						foreach ($img_ary as $img)
 | |
| 						{
 | |
| 							if (!empty($$img))
 | |
| 							{
 | |
| 								$test_ary[] = preg_replace('#^"styles/' . $imageset_path . '/imageset/(\{LANG\}/)?(.*?)".*$#', '\2', $$img);
 | |
| 							}
 | |
| 						}
 | |
| 					}
 | |
| 					unset($test_ary);
 | |
| 				}
 | |
| 
 | |
| 				// Generate list of image options
 | |
| 				$img_options = '';
 | |
| 				foreach ($imglist as $category => $img_ary)
 | |
| 				{
 | |
| 					$img_options .= (sizeof($img_ary)) ? '<option class="sep" value="">' . $user->lang['IMG_CAT_' . strtoupper($category)] . '</option>' : '';
 | |
| 					foreach ($img_ary as $img)
 | |
| 					{
 | |
| 						$selected = ($img == $imgname) ? ' selected="selected"' : '';
 | |
| 						$img_options .= '<option value="' . $img . '"' . $selected . '>' . (($category == 'custom') ? $img : $user->lang['IMG_' . strtoupper($img)]) . '</option>';
 | |
| 					}
 | |
| 				}
 | |
| 
 | |
| 				// TODO
 | |
| 				// Check whether localised buttons exist in admins language first
 | |
| 				// Clean up this code
 | |
| 				$imglang = '';
 | |
| 				$imagesetlist = array('nolang' => array(), 'lang' => array());
 | |
| 				$dp = opendir("{$phpbb_root_path}styles/$imageset_path/imageset");
 | |
| 				while ($file = readdir($dp))
 | |
| 				{
 | |
| 					if (!is_file($file) && !is_link($file) && $file{0} != '.' && strtoupper($file) != 'CVS' && !sizeof($imagesetlist['lang']))
 | |
| 					{
 | |
| 						$dp2 = opendir("{$phpbb_root_path}styles/$imageset_path/imageset/$file");
 | |
| 						while ($file2 = readdir($dp2))
 | |
| 						{
 | |
| 							$imglang = $file;
 | |
| 							if (preg_match('#\.(gif|jpg|png)$#', $file2))
 | |
| 							{
 | |
| 								$imagesetlist['lang'][] = "$file/$file2";
 | |
| 							}
 | |
| 						}
 | |
| 						closedir($dp2);
 | |
| 					}
 | |
| 					else if (preg_match('#\.(gif|jpg|png)$#', $file))
 | |
| 					{
 | |
| 						$imagesetlist['nolang'][] = $file;
 | |
| 					}
 | |
| 				}
 | |
| 				closedir($dp);
 | |
| 
 | |
| 				$imagesetlist_options = '';
 | |
| 				foreach ($imagesetlist as $type => $img_ary)
 | |
| 				{
 | |
| 					$imagesetlist_options .= ($type == 'lang') ? '<option class="sep" value="">' . $user->lang['LOCALISED_IMAGES'] . '</option>' : '<option class="sep" value="">' . $user->lang['GLOBAL_IMAGES'] . '</option>';
 | |
| 					foreach ($img_ary as $img)
 | |
| 					{
 | |
| 						$imgvalue = preg_replace('#^.*?/(.*?)$#', '\1', $img);
 | |
| 						$selected = (strstr($$imgname, $imgvalue)) ? ' selected="selected"' : '';
 | |
| 
 | |
| 						$imagesetlist_options .= '<option value="' . htmlspecialchars($img) . '"' . $selected . '>' . $imgvalue . '</option>';
 | |
| 					}
 | |
| 				}
 | |
| 				$imagesetlist_options = '<option value=""' . (($edit_img == '') ? ' selected="selected"' : '') . '>' . $user->lang['NONE'] . '</option>' . $imagesetlist_options;
 | |
| 				unset($imagesetlist);
 | |
| 
 | |
| 				$imgsize_no = $imgsize_yes = '';
 | |
| 				if ($imgsize || preg_match('# height="[0-9]+?#', $$imgname))
 | |
| 				{
 | |
| 					$imgsize_yes = ' checked="checked"';
 | |
| 				}
 | |
| 				else
 | |
| 				{
 | |
| 					$imgsize_no = ' checked="checked"';
 | |
| 				}
 | |
| 
 | |
| 				adm_page_header($user->lang['EDIT_IMAGESET']);
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <script language="javascript" type="text/javascript" defer="defer">
 | |
| <!--
 | |
| 
 | |
| function update_image(newimage)
 | |
| {
 | |
| 	document.newimg.src = (newimage) ? "<?php echo "{$phpbb_root_path}styles/$imageset_path/imageset/"; ?>" + newimage : "images/no_image.png";
 | |
| }
 | |
| //-->
 | |
| </script>
 | |
| 
 | |
| <h1><?php echo $user->lang['EDIT_IMAGESET']; ?></h1>
 | |
| 
 | |
| <p><?php echo $user->lang['EDIT_IMAGESET_EXPLAIN']; ?></p>
 | |
| 
 | |
| <p><?php echo $user->lang['SELECTED_IMAGESET'] . ": <b>$imageset_name</b>"; ?></p>
 | |
| 
 | |
| <form method="post" action="<?php echo "admin_styles.$phpEx$SID&mode=$mode&id=$id&action=$action"; ?>"><table width="95%" cellspacing="1" cellpadding="1" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<td align="right"><?php echo $user->lang['SELECT_IMAGE']; ?>: <select name="imgname" onchange="this.form.submit(); "><?php echo $img_options; ?></select>  <input class="btnlite" type="submit" value="<?php echo $user->lang['SELECT']; ?>" tabindex="100" /></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td><table class="bg" width="100%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 			<tr>
 | |
| 				<th colspan="2"><?php echo $user->lang['EDIT_IMAGESET']; ?></th>
 | |
| 			</tr>
 | |
| <?php
 | |
| 
 | |
| 				if (sizeof($error))
 | |
| 				{
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<td class="row1" colspan="2" align="center"><?php echo ($update) ? '<span style="color:green">' . implode('<br />', $error) . '</span>' : implode('<br />', $error); ?></td>
 | |
| 			</tr>
 | |
| <?php
 | |
| 
 | |
| 				}
 | |
| 
 | |
| ?>
 | |
| 			<tr>
 | |
| 				<td class="row1" colspan="2" align="center"><table width="100%" cellspacing="2" cellpadding="2" border="0">
 | |
| 					<tr>
 | |
| 						<td width="50%" align="center"><img src="<?php 
 | |
| 	
 | |
| 					echo (!empty($$imgname)) ? str_replace('"styles/', '../styles/', str_replace('{LANG}', $imglang, $$imgname)) : 'images/no_image.png'; 
 | |
| 					
 | |
| ?>" /></td>
 | |
| 						<td width="50%" align="center"><img src="<?php 
 | |
| 	
 | |
| 					echo (!empty($$imgname)) ? preg_replace('#(width|height)="[0-9]+?"#', '', str_replace('"styles/', '../styles/', str_replace('{LANG}', $imglang, $$imgname))) : 'images/no_image.png'; 
 | |
| 					
 | |
| ?>" name="newimg" /></td>
 | |
| 					</tr>
 | |
| 					<tr>
 | |
| 						<td class="gensmall" align="center"><?php echo $user->lang['CURRENT_IMAGE']; ?></td>
 | |
| 						<td class="gensmall" align="center"><?php echo $user->lang['SELECTED_IMAGE']; ?></td>
 | |
| 					</tr>
 | |
| 				</table></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<th width="40%"><?php echo $user->lang['IMAGE_PARAMETER']; ?></th>
 | |
| 				<th><?php echo $user->lang['IMAGE_VALUE']; ?></th>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" width="40%"><b><?php echo $user->lang['IMAGE']; ?>: </b></td>
 | |
| 				<td class="row2"><select name="imgpath" onchange="update_image(this.options[selectedIndex].value);"><?php echo $imagesetlist_options; ?></select></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="row1" width="40%"><b><?php echo $user->lang['DIMENSIONS']; ?>: </b><br /><span class="gensmall"><?php echo $user->lang['DIMENSIONS_EXPLAIN']; ?></span></td>
 | |
| 				<td class="row2"><input type="radio" name="imgsize" value="1"<?php echo $imgsize_yes; ?> /> <?php echo $user->lang['YES']; ?>  <input type="radio" name="imgsize" value="0"<?php echo $imgsize_no; ?> /> <?php echo $user->lang['NO']; ?></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="update" value="<?php echo $user->lang['SUBMIT']; ?>" />  <input class="btnmain" type="reset" value="<?php echo $user->lang['RESET']; ?>" /></td>
 | |
| 			</tr>
 | |
| 		</table></td>
 | |
| 	</tr>
 | |
| </table></form>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| 				adm_page_footer();
 | |
| 				break;
 | |
| 		}
 | |
| 
 | |
| 		// Front page
 | |
| 		frontend('imageset', array('details', 'delete', 'export'));
 | |
| 		break;
 | |
| }
 | |
| 
 | |
| exit;
 | |
| 
 | |
| 
 | |
| // ---------
 | |
| // FUNCTIONS
 | |
| //
 | |
| function frontend($type, $options)
 | |
| {
 | |
| 	global $phpbb_root_path, $phpEx, $SID, $config, $db, $user, $mode;
 | |
| 
 | |
| 	switch ($type)
 | |
| 	{
 | |
| 		case 'style':
 | |
| 			$sql_from = STYLES_TABLE;
 | |
| 			break;
 | |
| 		case 'template':
 | |
| 			$sql_from = STYLES_TPL_TABLE;
 | |
| 			break;
 | |
| 		case 'theme':
 | |
| 			$sql_from = STYLES_CSS_TABLE;
 | |
| 			break;
 | |
| 		case 'imageset':
 | |
| 			$sql_from = STYLES_IMAGE_TABLE;
 | |
| 			break;
 | |
| 	}
 | |
| 
 | |
| 	$l_prefix = strtoupper($type);
 | |
| 	$thspan = ($type != 'style') ? sizeof($options) + 1: sizeof($options) + 2;
 | |
| 	$tdspan = ($type != 'style') ? $thspan + 2 : $thspan + 3;
 | |
| 
 | |
| 	// Output list of themes
 | |
| 	adm_page_header($user->lang[$l_prefix . 'S']);
 | |
| 
 | |
| ?>
 | |
| <h1><?php echo $user->lang[$l_prefix . 'S']; ?></h1>
 | |
| 
 | |
| <p><?php echo $user->lang[$l_prefix . 'S_EXPLAIN']; ?></p>
 | |
| 
 | |
| <form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&mode=$mode"; ?>"><table class="bg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<th nowrap="nowrap"><?php echo $user->lang[$l_prefix . '_NAME']; ?></th>
 | |
| <?php
 | |
| 
 | |
| 	if ($type == 'style')
 | |
| 	{
 | |
| ?>
 | |
| 		<th nowrap="nowrap"><?php echo $user->lang['STYLE_USED_BY']; ?></th>
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 
 | |
| ?>
 | |
| 		<th colspan="<?php echo $thspan; ?>" nowrap="nowrap"><?php echo $user->lang['OPTIONS']; ?></th>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row3" colspan="<?php echo $tdspan; ?>"><b><?php echo $user->lang['INSTALLED_' . $l_prefix]; ?></b></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 	if ($type == 'style')
 | |
| 	{
 | |
| 		$sql = 'SELECT user_style, COUNT(user_style) AS style_count
 | |
| 			FROM ' . USERS_TABLE . ' 
 | |
| 			GROUP BY user_style';
 | |
| 		$result = $db->sql_query($sql);
 | |
| 
 | |
| 		while ($row = $db->sql_fetchrow($result))
 | |
| 		{
 | |
| 			$style_count[$row['user_style']] = $row['style_count'];
 | |
| 		}
 | |
| 		$db->sql_freeresult($result);
 | |
| 	}
 | |
| 
 | |
| 	$sql = "SELECT *  
 | |
| 		FROM $sql_from";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	$installed = array();
 | |
| 	$basis_options = '<option class="sep" value="">' . $user->lang['OPTIONAL_BASIS'] . '</option>';
 | |
| 	while ($row = $db->sql_fetchrow($result))
 | |
| 	{
 | |
| 		$installed[] = $row[$type . '_name'];
 | |
| 		$basis_options .= '<option value="' . $row[$type . '_id'] . '">' . $row[$type . '_name'] . '</option>';
 | |
| 
 | |
| 		$row_class = ($row_class != 'row1') ? 'row1' : 'row2';
 | |
| 
 | |
| 		$tagstyle = ($type == 'style' && $row['style_id'] == $config['default_style']) ? '*' : '';
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="<?php echo $row_class; ?>" width="100%"><a href="<?php echo "admin_styles.$phpEx$SID&mode=$mode&action=" . (($type == 'style') ? 'details' : 'edit') . "&id=" . $row[$type . '_id']; ?>"><?php echo $row[$type . '_name']; ?></a> <?php echo $tagstyle; ?></td>
 | |
| <?php
 | |
| 
 | |
| 		if ($type == 'style')
 | |
| 		{
 | |
| 			$stylevis = (!$row['style_active']) ? 'activate' : 'deactivate';
 | |
| 
 | |
| ?>
 | |
| 		<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap"><?php echo (!empty($style_count[$row['style_id']])) ? $style_count[$row['style_id']] : '0'; ?></td>
 | |
| 		<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap"> <a href="<?php echo "admin_styles.$phpEx$SID&mode=$mode&action=$stylevis&id=" . $row['style_id']; ?>"><?php echo $user->lang['STYLE_' . strtoupper($stylevis)]; ?></a> </td>
 | |
| <?php
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		foreach ($options as $option)
 | |
| 		{
 | |
| 
 | |
| ?>
 | |
| 		<td class="<?php echo $row_class; ?>" nowrap="nowrap"> <a href="<?php echo "admin_styles.$phpEx$SID&mode=$mode&action=$option&id=" . $row[$type . '_id']; ?>"><?php echo $user->lang[strtoupper($option)]; ?></a> </td>
 | |
| <?php
 | |
| 
 | |
| 		}
 | |
| 
 | |
| ?>
 | |
| 		<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap"> <a href="<?php echo "{$phpbb_root_path}index.$phpEx$SID&$type=" . $row[$type . '_id']; ?>" target="_preview"><?php echo $user->lang['PREVIEW']; ?></a> </td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 	$db->sql_freeresult($result);
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row3" colspan="<?php echo $tdspan; ?>"><b><?php echo $user->lang['UNINSTALLED_' . $l_prefix]; ?></b></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 	$new_ary = $cfg = array();
 | |
| 	$dp = opendir("{$phpbb_root_path}styles");
 | |
| 	while ($file = readdir($dp))
 | |
| 	{
 | |
| 		$subpath = ($type != 'style') ? "$type/" : '';
 | |
| 		if ($file{0} != '.' && file_exists("{$phpbb_root_path}styles/$file/$subpath$type.cfg"))
 | |
| 		{
 | |
| 			if ($cfg = file("{$phpbb_root_path}styles/$file/$subpath$type.cfg"))
 | |
| 			{
 | |
| 				$name = trim($cfg[0]);
 | |
| 				if (!in_array($name, $installed))
 | |
| 				{
 | |
| 					$new_ary[$i]['path'] = $file;
 | |
| 					$new_ary[$i]['name'] = $name;
 | |
| 					$i++;
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	unset($installed);
 | |
| 	@closedir($dp);
 | |
| 
 | |
| 	if (sizeof($new_ary))
 | |
| 	{
 | |
| 		foreach ($new_ary as $key => $cfg)
 | |
| 		{
 | |
| 			$row_class = ($row_class != 'row1') ? 'row1' : 'row2';
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="<?php echo $row_class; ?>"><?php echo $cfg['name']; ?></td>
 | |
| 		<td class="<?php echo $row_class; ?>" colspan="<?php echo ($type != 'style') ? $thspan : $thspan + 1 ?>" align="center"><a href="<?php echo "admin_styles.$phpEx$SID&mode=$mode&action=install&path=" . urlencode($cfg['path']); ?>"><?php echo $user->lang['INSTALL']; ?></a></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 		}
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row1" colspan="<?php echo $tdspan; ?>" align="center"><?php echo $user->lang['NO_UNINSTALLED_' . $l_prefix]; ?></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 	unset($new_ary);
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="cat" colspan="<?php echo $tdspan; ?>" align="right"><?php echo $user->lang['CREATE_' . $l_prefix]; ?>: <input class="post" type="text" name="name" value="" maxlength="30" size="25" /> <?php echo $user->lang['FROM']; ?> <select name="basis"><?php echo $basis_options; ?></select> <input class="btnmain" type="submit" name="add" value="<?php echo $user->lang['SUBMIT']; ?>" /></td>
 | |
| 	</tr>
 | |
| </table></form>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| 	adm_page_footer();
 | |
| 
 | |
| }
 | |
| 
 | |
| function remove($type, $id)
 | |
| {
 | |
| 	global $phpbb_root_path, $phpEx, $SID, $config, $db, $cache, $user, $mode, $action;
 | |
| 
 | |
| 	$new_id = (!empty($_POST['newid'])) ? intval($_POST['newid']) : false;
 | |
| 	$deletefs = (!empty($_POST['deletefs'])) ? true : false;
 | |
| 	$update = (isset($_POST['update'])) ? true : false;
 | |
| 
 | |
| 	switch ($type)
 | |
| 	{
 | |
| 		case 'style':
 | |
| 			$sql_from = STYLES_TABLE;
 | |
| 			$sql_select = 'style_name';
 | |
| 			break;
 | |
| 		case 'template':
 | |
| 			$sql_from = STYLES_TPL_TABLE;
 | |
| 			$sql_select = 'template_name, template_path, template_storedb';
 | |
| 			break;
 | |
| 		case 'theme':
 | |
| 			$sql_from = STYLES_CSS_TABLE;
 | |
| 			$sql_select = 'theme_name, theme_path, theme_storedb';
 | |
| 			break;
 | |
| 		case 'imageset':
 | |
| 			$sql_from = STYLES_IMAGE_TABLE;
 | |
| 			$sql_select = 'imageset_name, imageset_path';
 | |
| 			break;
 | |
| 	}
 | |
| 
 | |
| 	$l_prefix = strtoupper($type);
 | |
| 
 | |
| 	$sql = "SELECT $sql_select
 | |
| 		FROM $sql_from 
 | |
| 		WHERE {$type}_id = $id";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	if (!extract($db->sql_fetchrow($result)))
 | |
| 	{
 | |
| 		trigger_error($user->lang['NO_' . $l_prefix]);
 | |
| 	}
 | |
| 
 | |
| 	$path = ($type != 'style') ? ${$type . '_path'} : '';
 | |
| 	$storedb = (isset(${$type . '_storedb'})) ? ${$type . '_storedb'} : false;
 | |
| 
 | |
| 	$sql = "SELECT {$type}_id, {$type}_name 
 | |
| 		FROM $sql_from  
 | |
| 		WHERE {$type}_id <> $id 
 | |
| 		ORDER BY {$type}_id";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	$options = '';
 | |
| 	if (!($row = $db->sql_fetchrow($result)))
 | |
| 	{
 | |
| 		trigger_error($user->lang['ONLY_' . $l_prefix]);
 | |
| 	}
 | |
| 
 | |
| 	do
 | |
| 	{
 | |
| 		$options .= '<option value="' . $row[$type . '_id'] . '">' . $row[$type . '_name'] . '</option>';
 | |
| 	}
 | |
| 	while ($row = $db->sql_fetchrow($result));
 | |
| 
 | |
| 	if ($update)
 | |
| 	{
 | |
| 		$sql = "DELETE FROM $sql_from 
 | |
| 			WHERE {$type}_id = $id";
 | |
| 		$db->sql_query($sql);
 | |
| 
 | |
| 		$onfs = 0;
 | |
| 		if ($type == 'style')
 | |
| 		{
 | |
| 			$sql = 'UPDATE ' . USERS_TABLE . " 
 | |
| 				SET user_style = $new_id
 | |
| 				WHERE user_style = $id";
 | |
| 			$db->sql_query($sql);
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			$sql = 'UPDATE ' . STYLES_TABLE . " 
 | |
| 				SET {$type}_id = $new_id 
 | |
| 				WHERE {$type}_id = $id";
 | |
| 			$db->sql_query($sql);
 | |
| 
 | |
| 			if ($deletefs && is_writeable("{$phpbb_root_path}styles/$path/{$type}"))
 | |
| 			{
 | |
| 				$filelist = filelist("{$phpbb_root_path}styles/$path/{$type}", '', '*');
 | |
| 				krsort($filelist);
 | |
| 
 | |
| 				foreach ($filelist as $subpath => $file_ary)
 | |
| 				{
 | |
| 					$subpath = "{$phpbb_root_path}styles/$path/{$type}$subpath";
 | |
| 					foreach ($file_ary as $file)
 | |
| 					{
 | |
| /*						if (!@unlink("$subpath$file"))
 | |
| 						{
 | |
| 							$onfs = 1;
 | |
| 						}
 | |
| */					}
 | |
| 
 | |
| /*					if (!@rmdir($subpath))
 | |
| 					{
 | |
| 						$onfs = 1;
 | |
| 					}
 | |
| */				}
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				$onfs = (file_exists("{$phpbb_root_path}styles/$path/{$type}")) ? 1 : 0;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		$cache->destroy('sql', STYLES_TABLE);
 | |
| 
 | |
| 		add_log('admin', 'LOG_DELETE_' . $l_prefix, ${$type . '_name'});
 | |
| 		$message = ($onfs) ? $l_prefix . '_DELETED_FS' : $l_prefix . '_DELETED';
 | |
| 		trigger_error($user->lang[$message]);
 | |
| 	}
 | |
| 
 | |
| 	// Output list of themes
 | |
| 	adm_page_header($user->lang['DELETE_' . $l_prefix]);
 | |
| 
 | |
| ?>
 | |
| <h1><?php echo $user->lang['DELETE_' . $l_prefix]; ?></h1>
 | |
| 
 | |
| <p><?php echo $user->lang['DELETE_' . $l_prefix . '_EXPLAIN']; ?></p>
 | |
| 
 | |
| <form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&mode=$type&action=delete&id=$id"; ?>"><table class="bg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<th colspan="2"><?php echo $user->lang['DELETE_' . $l_prefix]; ?></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row1" width="40%"><b><?php echo $user->lang[$l_prefix . '_NAME']; ?>:</b></td>
 | |
| 		<td class="row2"><b><?php echo ${$type . '_name'}; ?></b></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 	if ($type != 'style' && !$storedb && is_writeable("{$phpbb_root_path}styles/$path/$type"))
 | |
| 	{
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row1" width="40%"><b><?php echo $user->lang['DELETE_FROM_FS']; ?>: </b></td>
 | |
| 		<td class="row2"><input type="radio" name="deletefs" value="1" /> <?php echo $user->lang['YES']; ?>  <input type="radio" name="deletefs" value="0" checked="checked" /> <?php echo $user->lang['NO']; ?></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row1" width="40%"><b><?php echo $user->lang['REPLACE_' . $l_prefix]; ?>:</b><br /><span class="gensmall"><?php echo $user->lang['REPLACE_' . $l_prefix . '_EXPLAIN']; ?></span></td>
 | |
| 		<td class="row2"><select name="newid"><?php echo $options; ?></select></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="update" value="<?php echo $user->lang['DELETE']; ?>"; />  <input class="btnlite" type="submit" name="cancel" value="<?php echo $user->lang['CANCEL']; ?>"; /></td>
 | |
| 	</tr>
 | |
| </table></form>
 | |
| <?php
 | |
| 
 | |
| 	adm_page_footer();
 | |
| 
 | |
| }
 | |
| 
 | |
| // Export style or style elements
 | |
| function export($mode, $id)
 | |
| {
 | |
| 	global $phpbb_root_path, $phpEx, $SID, $config, $db, $user;
 | |
| 
 | |
| 	$update = (isset($_POST['update'])) ? true : false;
 | |
| 
 | |
| 	$inc_template = (!empty($_POST['inc_template'])) ? true : false;
 | |
| 	$inc_theme = (!empty($_POST['inc_theme'])) ? true : false;
 | |
| 	$inc_imageset = (!empty($_POST['inc_imageset'])) ? true : false;
 | |
| 	$format = (isset($_POST['format'])) ? htmlspecialchars($_POST['format']) : '';
 | |
| 	$store = (!empty($_POST['store'])) ? true : false;
 | |
| 
 | |
| 	switch ($mode)
 | |
| 	{
 | |
| 		case 'style':
 | |
| 			if ($update && $inc_template + $inc_theme + $inc_imageset < 1)
 | |
| 			{
 | |
| 				$error[] = $user->lang['STYLE_ERR_MORE_ELEMENTS'];
 | |
| 			}
 | |
| 
 | |
| 			$style_id = &$id;
 | |
| 			$name = 'style_name';
 | |
| 
 | |
| 			$sql_select = 's.style_id, s.style_name, s.style_copyright';
 | |
| 			$sql_select .= ($inc_template) ? ', t.*' : ', t.template_name';
 | |
| 			$sql_select .= ($inc_theme) ? ', c.*' : ', c.theme_name';
 | |
| 			$sql_select .= ($inc_imageset) ? ', i.*' : ', i.imageset_name';
 | |
| 			$sql_from = STYLES_TABLE . ' s, ' . STYLES_TPL_TABLE . ' t, ' . STYLES_CSS_TABLE . ' c, ' . STYLES_IMAGE_TABLE . ' i';
 | |
| 			$sql_where = "s.style_id = $id AND t.template_id = s.template_id AND c.theme_id = s.theme_id AND i.imageset_id = s.imageset_id";
 | |
| 
 | |
| 			$l_prefix = 'STYLE';
 | |
| 			break;
 | |
| 
 | |
| 		case 'template':
 | |
| 			$template_id = &$id;
 | |
| 			$name = 'template_name';
 | |
| 
 | |
| 			$sql_select = '*';
 | |
| 			$sql_from = STYLES_TPL_TABLE;
 | |
| 			$sql_where = "template_id = $id";
 | |
| 
 | |
| 			$l_prefix = 'TEMPLATE';
 | |
| 			break;
 | |
| 
 | |
| 		case 'theme':
 | |
| 			$theme_id = &$id;
 | |
| 			$name = 'theme_name';
 | |
| 
 | |
| 			$sql_select = '*';
 | |
| 			$sql_from = STYLES_CSS_TABLE;
 | |
| 			$sql_where = "theme_id = $id";
 | |
| 
 | |
| 			$l_prefix = 'THEME';
 | |
| 			break;
 | |
| 
 | |
| 		case 'imageset':
 | |
| 			$imageset_id = &$id;
 | |
| 			$name = 'imageset_name';
 | |
| 
 | |
| 			$sql_select = '*';
 | |
| 			$sql_from = STYLES_IMAGE_TABLE;
 | |
| 			$sql_where = "imageset_id = $id";
 | |
| 
 | |
| 			$l_prefix = 'IMAGESET';
 | |
| 			break;
 | |
| 	}
 | |
| 
 | |
| 	// Lets do a merry dance ... either that or generate the archive
 | |
| 	if ($update && !sizeof($error))
 | |
| 	{
 | |
| 		$sql = "SELECT $sql_select 
 | |
| 			FROM $sql_from 
 | |
| 			WHERE $sql_where";
 | |
| 		$result = $db->sql_query($sql);
 | |
| 
 | |
| 		if (!($style_row = ($db->sql_fetchrow($result))))
 | |
| 		{
 | |
| 			trigger_error($user->lang['NO_' . $l_prefix]);
 | |
| 		}
 | |
| 		$db->sql_freeresult($result);
 | |
| 
 | |
| 		$var_ary = array('style_id', 'style_name', 'style_copyright', 'template_id', 'template_name', 'template_path', 'template_copyright', 'template_storedb', 'bbcode_bitfield', 'theme_id', 'theme_name', 'theme_path', 'theme_copyright', 'theme_storedb', 'theme_mtime', 'theme_data', 'imageset_id', 'imageset_name', 'imageset_path', 'imageset_copyright');
 | |
| 		foreach ($var_ary as $var)
 | |
| 		{
 | |
| 			$$var = (!empty($style_row[$var])) ? $style_row[$var] : '';
 | |
| 			unset($style_row[$var]);
 | |
| 		}
 | |
| 		
 | |
| 		$files = $data = array();
 | |
| 
 | |
| 		if ($mode == 'style')
 | |
| 		{
 | |
| 			$style_cfg  = addslashes($style_name) . "\n";
 | |
| 			$style_cfg .= addslashes($style_copyright) . "\n";
 | |
| 			$style_cfg .= addslashes($config['version']) . "\n";
 | |
| 			$style_cfg .= ((!$inc_template) ? addslashes($template_name) : '') . "\n";
 | |
| 			$style_cfg .= ((!$inc_theme) ? addslashes($theme_name) : '') . "\n";
 | |
| 			$style_cfg .= ((!$inc_imageset) ? addslashes($imageset_name) : '');
 | |
| 
 | |
| 			$data[] = array(
 | |
| 				'src'		=> $style_cfg, 
 | |
| 				'prefix'	=> 'style.cfg'
 | |
| 			);
 | |
| 			unset($style_cfg);
 | |
| 		}
 | |
| 
 | |
| 		// Export template core code
 | |
| 		if ($mode == 'template' || $inc_template)
 | |
| 		{
 | |
| 			$template_cfg  = addslashes($template_name) . "\n";
 | |
| 			$template_cfg .= addslashes($template_copyright) . "\n";
 | |
| 			$template_cfg .= addslashes($config['version']) . "\n";
 | |
| 			$template_cfg .= addslashes($bbcode_bitfield);
 | |
| 
 | |
| 			$data[] = array(
 | |
| 				'src'		=> $template_cfg, 
 | |
| 				'prefix'	=> 'template/template.cfg'
 | |
| 			);
 | |
| 
 | |
| 			// This is potentially nasty memory-wise ...
 | |
| 			if (!$template_storedb)
 | |
| 			{
 | |
| 				$files[] = array(
 | |
| 					'src'		=> "styles/$template_path/template/", 
 | |
| 					'prefix-'	=> "styles/$template_path/", 
 | |
| 					'prefix+'	=> false, 
 | |
| 					'exclude'	=> 'template.cfg'
 | |
| 				);
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				$sql = 'SELECT template_filename, template_data  
 | |
| 					FROM ' . STYLES_TPLDATA_TABLE . " 
 | |
| 					WHERE template_id = $template_id";
 | |
| 				$result = $db->sql_query($sql);
 | |
| 
 | |
| 				while ($row = $db->sql_fetchrow($result))
 | |
| 				{
 | |
| 					$data[] = array(
 | |
| 						'src' => $row['template_data'], 
 | |
| 						'prefix' => 'template/' . $row['template_filename']
 | |
| 					);
 | |
| 				}
 | |
| 				$db->sql_freeresult($result);
 | |
| 			}
 | |
| 			unset($template_cfg);
 | |
| 		}
 | |
| 
 | |
| 		// Export theme core code
 | |
| 		if ($mode == 'theme' || $inc_theme)
 | |
| 		{
 | |
| 			$theme_cfg  = addslashes($theme_name) . "\n";
 | |
| 			$theme_cfg .= addslashes($theme_copyright) . "\n";
 | |
| 			$theme_cfg .= addslashes($config['version']);
 | |
| 
 | |
| 			$files[] = array(
 | |
| 				'src'		=> "styles/$theme_path/theme/", 
 | |
| 				'prefix-'	=> "styles/$theme_path/", 
 | |
| 				'prefix+'	=> false, 
 | |
| 				'exclude'	=> ($theme_storedb) ? 'stylesheet.css,theme.cfg' : 'theme.cfg' 
 | |
| 			);
 | |
| 
 | |
| 			$data[] = array(
 | |
| 				'src'		=> $theme_cfg, 
 | |
| 				'prefix'	=> 'theme/theme.cfg'
 | |
| 			);
 | |
| 
 | |
| 			if ($theme_storedb)
 | |
| 			{
 | |
| 				$data[] = array(
 | |
| 					'src'		=> $theme_data, 
 | |
| 					'prefix'	=> 'theme/stylesheet.css'
 | |
| 				);
 | |
| 			}
 | |
| 			unset($theme_data);
 | |
| 			unset($theme_cfg);
 | |
| 		}
 | |
| 
 | |
| 		// Export imageset core code
 | |
| 		if ($mode == 'imageset' || $inc_imageset)
 | |
| 		{
 | |
| 			$imageset_cfg  = addslashes($imageset_name) . "\n";
 | |
| 			$imageset_cfg .= addslashes($imageset_copyright) . "\n";
 | |
| 			$imageset_cfg .= addslashes($config['version']) . "\n";
 | |
| 			
 | |
| 			foreach (array_keys($style_row) as $key)
 | |
| 			{
 | |
| 				$imageset_cfg .= $key . '||' . str_replace("styles/$imageset_path/imageset/", '{PATH}', $style_row[$key]) . "\n";
 | |
| 				unset($style_row[$key]);
 | |
| 			}
 | |
| 			$imageset_cfg = rtrim($imageset_cfg);
 | |
| 
 | |
| 			$files[] = array(
 | |
| 				'src'		=> "styles/$imageset_path/imageset/", 
 | |
| 				'prefix-'	=> "styles/$imageset_path/", 
 | |
| 				'prefix+'	=> false, 
 | |
| 				'exclude'	=> 'imageset.cfg'
 | |
| 			);
 | |
| 
 | |
| 			$data[] = array(
 | |
| 				'src'		=> trim($imageset_cfg), 
 | |
| 				'prefix'	=> 'imageset/imageset.cfg'
 | |
| 			);
 | |
| 			unset($imageset_cfg);
 | |
| 		}
 | |
| 
 | |
| 		switch ($format)
 | |
| 		{
 | |
| 			case 'tar':
 | |
| 				$ext = 'tar';
 | |
| 				$mimetype = 'x-tar';
 | |
| 				$compress = 'compress_tar';
 | |
| 				break;
 | |
| 
 | |
| 			case 'zip':
 | |
| 				if (!extension_loaded('zlib'))
 | |
| 				{
 | |
| 					trigger_error($user->lang['NO_SUPPORT_ZIP']);
 | |
| 				}
 | |
| 				$ext = 'zip';
 | |
| 				$mimetype = 'zip';
 | |
| 				$compress = 'compress_zip';
 | |
| 				break;
 | |
| 
 | |
| 			case 'tar.gz':
 | |
| 				if (!extension_loaded('zlib'))
 | |
| 				{
 | |
| 					trigger_error($user->lang['NO_SUPPORT_GZ']);
 | |
| 				}
 | |
| 				$ext = 'tar.gz';
 | |
| 				$mimetype = 'x-gzip';
 | |
| 				$compress = 'compress_tar';
 | |
| 				break;
 | |
| 
 | |
| 			case 'tar.bz2':
 | |
| 				if (!extension_loaded('bz2'))
 | |
| 				{
 | |
| 					trigger_error($user->lang['NO_SUPPORT_BZ2']);
 | |
| 				}
 | |
| 				$ext = 'tar.bz2';
 | |
| 				$mimetype = 'x-bzip2';
 | |
| 				$compress = 'compress_tar';
 | |
| 				break;
 | |
| 
 | |
| 			default:
 | |
| 				$error[] = $user->lang[$l_prefix . '_ERR_ARCHIVE'];
 | |
| 		}
 | |
| 
 | |
| 		if (!sizeof($error))
 | |
| 		{
 | |
| 			include($phpbb_root_path . 'includes/functions_compress.'.$phpEx);
 | |
| 
 | |
| 			$path = str_replace(' ', '_', $$name);
 | |
| 
 | |
| 			if (!($zip = new $compress('w', "{$phpbb_root_path}store/$path.$ext")))
 | |
| 			{
 | |
| 				trigger_error($user->lang['STORE_UNWRITEABLE']);
 | |
| 			}
 | |
| 
 | |
| 			if ($files)
 | |
| 			{
 | |
| 				foreach ($files as $file_ary)
 | |
| 				{
 | |
| 					$zip->add_file($file_ary['src'], $file_ary['prefix-'], $file_ary['prefix+'], $file_ary['exclude']);
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			if ($data)
 | |
| 			{
 | |
| 				foreach ($data as $data_ary)
 | |
| 				{
 | |
| 					$zip->add_data($data_ary['src'], $data_ary['prefix']);
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			$zip->close();
 | |
| 
 | |
| 			add_log('admin', 'LOG_EXPORT_' . $l_prefix, $$name);
 | |
| 
 | |
| 			if (!$store)
 | |
| 			{
 | |
| 				header('Pragma: no-cache');
 | |
| 				header("Content-Type: application/$mimetype; name=\"$path.$ext\"");
 | |
| 				header("Content-disposition: attachment; filename=$path.$ext");
 | |
| 
 | |
| 				$fp = fopen("{$phpbb_root_path}store/$path.$ext", 'rb');
 | |
| 				while ($buffer = fread($fp, 1024))
 | |
| 				{
 | |
| 					echo $buffer;
 | |
| 				}
 | |
| 				fclose($fp);
 | |
| 				@unlink("{$phpbb_root_path}store/$path.$ext");
 | |
| 				exit;
 | |
| 			}
 | |
| 
 | |
| 			trigger_error(sprintf($user->lang[$l_prefix . '_EXPORTED'], "store/$path.$ext"));
 | |
| 		}
 | |
| 	}
 | |
| 	else 
 | |
| 	{
 | |
| 		$sql = "SELECT {$mode}_id, {$mode}_name 
 | |
| 			FROM " . (($mode == 'style') ? STYLES_TABLE : $sql_from) . "
 | |
| 			WHERE {$mode}_id = $id";
 | |
| 		$result = $db->sql_query($sql);
 | |
| 
 | |
| 		if (!extract($db->sql_fetchrow($result)))
 | |
| 		{
 | |
| 			trigger_error($user->lang['NO_' . $l_prefix]);
 | |
| 		}
 | |
| 		$db->sql_freeresult($result);
 | |
| 	}
 | |
| 
 | |
| 	// Output list
 | |
| 	adm_page_header($user->lang[$l_prefix . '_EXPORT']);
 | |
| 
 | |
| ?>
 | |
| <h1><?php echo $user->lang[$l_prefix . '_EXPORT']; ?></h1>
 | |
| 
 | |
| <p><?php echo $user->lang[$l_prefix . '_EXPORT_EXPLAIN']; ?></p>
 | |
| 
 | |
| <form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&mode=$mode&action=export&id=$id"; ?>"><table class="bg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| <tr>
 | |
| 	<th colspan="2"><?php echo $user->lang[$l_prefix . '_EXPORT']; ?></td>
 | |
| </tr>
 | |
| <?php
 | |
| 
 | |
| 	if (sizeof($error))
 | |
| 	{
 | |
| 
 | |
| ?>
 | |
| <tr>
 | |
| 	<td colspan="2" class="row3" align="center"><span style="color:red"><?php echo implode('<br />', $error); ?></span></td>
 | |
| </tr>
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 
 | |
| ?>
 | |
| <tr>
 | |
| 	<td class="row1" width="40%"><b><?php echo $user->lang[$l_prefix . '_NAME']; ?>:</b></td>
 | |
| 	<td class="row2"><b><?php echo ${$mode . '_name'}; ?></b></td>
 | |
| </tr>
 | |
| <?php
 | |
| 
 | |
| 	if ($mode == 'style')
 | |
| 	{
 | |
| 
 | |
| ?>
 | |
| <tr>
 | |
| 	<td class="row1" width="40%"><b><?php echo $user->lang['INCLUDE_TEMPLATE']; ?>:</b></td>
 | |
| 	<td class="row2"><input type="radio" name="inc_template" value="1" checked="checked" /> <?php echo $user->lang['YES']; ?>   <input type="radio" name="inc_template" value="0" /> <?php echo $user->lang['NO']; ?> </td>
 | |
| </tr>
 | |
| <tr>
 | |
| 	<td class="row1" width="40%"><b><?php echo $user->lang['INCLUDE_THEME']; ?>:</b></td>
 | |
| 	<td class="row2"><input type="radio" name="inc_theme" value="1" checked="checked" /> <?php echo $user->lang['YES']; ?>   <input type="radio" name="inc_theme" value="0" /> <?php echo $user->lang['NO']; ?> </td>
 | |
| </tr>
 | |
| <tr>
 | |
| 	<td class="row1" width="40%"><b><?php echo $user->lang['INCLUDE_IMAGESET']; ?>:</b></td>
 | |
| 	<td class="row2"><input type="radio" name="inc_imageset" value="1" checked="checked" /> <?php echo $user->lang['YES']; ?>   <input type="radio" name="inc_imageset" value="0" /> <?php echo $user->lang['NO']; ?> </td>
 | |
| </tr>
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 
 | |
| ?>
 | |
| <tr>
 | |
| 	<td class="row1" width="40%"><b><?php echo $user->lang['DOWNLOAD_STORE']; ?>:</b><br /><span class="gensmall"><?php echo $user->lang['DOWNLOAD_STORE_EXPLAIN']; ?></span></td>
 | |
| 	<td class="row2"><input type="radio" name="store" value="1" checked="checked" /> <?php echo $user->lang['EXPORT_STORE']; ?>   <input type="radio" name="store" value="0" /> <?php echo $user->lang['EXPORT_DOWNLOAD']; ?> </td>
 | |
| </tr>
 | |
| <tr>
 | |
| 	<td class="row1" width="40%"><b><?php echo $user->lang['ARCHIVE_FORMAT']; ?>:</b></td>
 | |
| 	<td class="row2"><input type="radio" name="format" value="tar" /> .tar  <?php
 | |
| 
 | |
| 	$compress_types = array('tar.gz' => 'zlib', 'tar.bz2' => 'bz2', 'zip' => 'zlib');
 | |
| 
 | |
| 	foreach ($compress_types as $type => $module)
 | |
| 	{
 | |
| 		if (!extension_loaded($module))
 | |
| 		{
 | |
| 			continue;
 | |
| 		}
 | |
| 		echo '<input type="radio" name="format" value="' . $type . '" /> .' . $type . '  ';
 | |
| 	}
 | |
| 
 | |
| ?></td>
 | |
| </tr>
 | |
| <tr>
 | |
| 	<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="update" value="<?php echo $user->lang['SUBMIT']; ?>"; />  <input class="btnlite" type="submit" name="cancel" value="<?php echo $user->lang['CANCEL']; ?>"; /></td>
 | |
| </tr>
 | |
| </table></form>
 | |
| <?php
 | |
| 
 | |
| 	adm_page_footer();
 | |
| 
 | |
| }
 | |
| 
 | |
| function store_templates($mode, $id, $path, $filelist)
 | |
| {
 | |
| 	global $phpbb_root_path, $phpEx, $db;
 | |
| 
 | |
| 	$includes = array();
 | |
| 	foreach ($filelist as $pathfile => $file_ary)
 | |
| 	{
 | |
| 		foreach ($file_ary as $file)
 | |
| 		{
 | |
| 			if (!($fp = fopen("{$phpbb_root_path}styles/$path$pathfile/$file", 'r')))
 | |
| 			{
 | |
| 				trigger_error("Could not open {$phpbb_root_path}styles/$path/$pathfile/$file");
 | |
| 			}
 | |
| 			$template_data = fread($fp, filesize("{$phpbb_root_path}styles/$path$pathfile/$file"));
 | |
| 			fclose($fp);
 | |
| 
 | |
| 			if (preg_match_all('#<!-- INCLUDE (.*?\.html) -->#is', $template_data, $matches))
 | |
| 			{
 | |
| 				foreach ($matches[1] as $match)
 | |
| 				{
 | |
| 					$includes[trim($match)][] = $file;
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	foreach ($filelist as $pathfile => $file_ary)
 | |
| 	{
 | |
| 		foreach ($file_ary as $file)
 | |
| 		{
 | |
| 			// Skip index.
 | |
| 			if (strpos($file, 'index.') === 0)
 | |
| 			{
 | |
| 				continue;
 | |
| 			}
 | |
| 
 | |
| 			// We could do this using extended inserts ... but that could be one
 | |
| 			// heck of a lot of data ...
 | |
| 			$sql_ary = array(
 | |
| 				'template_id'		=> $id,
 | |
| 				'template_filename'	=> $file,
 | |
| 				'template_included'	=> (!empty($includes[$file])) ? implode(':', $includes[$file]) . ':' : '',
 | |
| 				'template_mtime'	=> filemtime("{$phpbb_root_path}styles/$path$pathfile/$file"),
 | |
| 				'template_data'		=> implode('', file("{$phpbb_root_path}styles/$path$pathfile/$file")),
 | |
| 			);
 | |
| 
 | |
| 			$sql = ($mode == 'insert') ? 'INSERT INTO ' . STYLES_TPLDATA_TABLE . ' ' . $db->sql_build_array('INSERT', $sql_ary) : 'UPDATE ' . STYLES_TPLDATA_TABLE . ' ' . $db->sql_build_array('INSERT', $sql_ary) . " WHERE template_id = $id AND template_filename = '" . $db->sql_escape($file) . "'";
 | |
| 			$db->sql_query($sql);
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Does what it says in the function title ... give it a src location, array of files
 | |
| // and destination
 | |
| function copy_files($src, $filelist, $dst)
 | |
| {
 | |
| 	global $phpbb_root_path;
 | |
| 	
 | |
| 	if (!(is_writable("{$phpbb_root_path}styles")))
 | |
| 	{
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	umask(0);
 | |
| 	if (!file_exists("{$phpbb_root_path}styles/$dst"))
 | |
| 	{
 | |
| 		@mkdir("{$phpbb_root_path}styles/$dst", 0777);
 | |
| 		chmod("{$phpbb_root_path}styles/$dst", 0777);
 | |
| 	}
 | |
| 
 | |
| 	@ksort($filelist);
 | |
| 	foreach ($filelist as $filepath => $file_ary)
 | |
| 	{
 | |
| 		$filepath = (substr($filepath, 0, 1) != '/') ? "/$filepath" : $filepath;
 | |
| 
 | |
| 		if ($filepath && !file_exists("{$phpbb_root_path}styles/$dst$filepath"))
 | |
| 		{
 | |
| 			@mkdir("{$phpbb_root_path}styles/$dst$filepath", 0777);
 | |
| 			chmod("{$phpbb_root_path}styles/$dst$filepath", 0777);
 | |
| 		}
 | |
| 
 | |
| 		foreach ($file_ary as $file)
 | |
| 		{
 | |
| 			if (!file_exists("{$phpbb_root_path}styles/$dst$filepath$file"))
 | |
| 			{
 | |
| 				@copy("$src$filepath$file", "{$phpbb_root_path}styles/$dst$filepath$file");
 | |
| 				@chmod("{$phpbb_root_path}styles/$dst$filepath$file", 0777);
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // You can guess what this does ... just give it a path
 | |
| function cleanup_folder($path)
 | |
| {
 | |
| 	$filelist = filelist($path, '', '*');
 | |
| 
 | |
| 	krsort($filelist);
 | |
| 	foreach ($filelist as $filepath => $file_ary)
 | |
| 	{
 | |
| 		foreach ($file_ary as $file)
 | |
| 		{
 | |
| 			@unlink("$path$filepath$file");
 | |
| 		}
 | |
| 
 | |
| 		if (file_exists("$path$filepath"))
 | |
| 		{
 | |
| 			@rmdir("$path$filepath");
 | |
| 		}
 | |
| 	}
 | |
| 	@rmdir("$path");
 | |
| }
 | |
| 
 | |
| // Is this element installed? If not, grab its cfg details
 | |
| function test_installed($element, &$error, $root_path, $reqd_name, &$id, &$name, &$copyright)
 | |
| {
 | |
| 	global $db, $user;
 | |
| 
 | |
| 	switch ($element)
 | |
| 	{
 | |
| 		case 'template':
 | |
| 			$sql_from = STYLES_TPL_TABLE;
 | |
| 			break;
 | |
| 		case 'theme':
 | |
| 			$sql_from = STYLES_CSS_TABLE;
 | |
| 			break;
 | |
| 		case 'imageset':
 | |
| 			$sql_from = STYLES_IMAGE_TABLE;
 | |
| 			break;
 | |
| 	}
 | |
| 
 | |
| 	$l_element = strtoupper($element);
 | |
| 
 | |
| 	$chk_name = ($reqd_name) ? $reqd_name : $name;
 | |
| 
 | |
| 	$sql = "SELECT {$element}_id, {$element}_name  
 | |
| 		FROM $sql_from
 | |
| 		WHERE {$element}_name = '" . $db->sql_escape($chk_name) . "'";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	if ($row = $db->sql_fetchrow($result))
 | |
| 	{
 | |
| 		$name = $row[$element . '_name'];
 | |
| 		$id = $row[$element . '_id'];
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		if (!($cfg = @file("$root_path$element/$element.cfg")))
 | |
| 		{
 | |
| 			$error[] = sprintf($user->lang['REQUIRES_' . $l_element], $reqd_name);
 | |
| 			return false;
 | |
| 		}
 | |
| 
 | |
| 		$name = trim($cfg[0]);
 | |
| 		$copyright = trim($cfg[1]);
 | |
| 		$id = 0;
 | |
| 		unset($cfg);
 | |
| 	}
 | |
| 	$db->sql_freeresult($result);
 | |
| }
 | |
| 
 | |
| // Install an element, doing various checks as we go
 | |
| function install_element($type, &$error, $action, $root_path, &$id, $name, $copyright, $storedb = 0)
 | |
| {
 | |
| 	global $phpbb_root_path, $db, $user;
 | |
| 
 | |
| 	switch ($type)
 | |
| 	{
 | |
| 		case 'template':
 | |
| 			$sql_from = STYLES_TPL_TABLE;
 | |
| 			break;
 | |
| 		case 'theme':
 | |
| 			$sql_from = STYLES_CSS_TABLE;
 | |
| 			break;
 | |
| 		case 'imageset':
 | |
| 			$sql_from = STYLES_IMAGE_TABLE;
 | |
| 			break;
 | |
| 	}
 | |
| 
 | |
| 	$l_type = strtoupper($type);
 | |
| 	$path = str_replace(' ', '_', $name);
 | |
| 
 | |
| 	if (empty($name))
 | |
| 	{
 | |
| 		$error[] = $user->lang[$l_type . '_ERR_STYLE_NAME'];
 | |
| 	}
 | |
| 
 | |
| 	if (strlen($name) > 30)
 | |
| 	{
 | |
| 		$error[] = $user->lang[$l_type . '_ERR_NAME_LONG'];
 | |
| 	}
 | |
| 
 | |
| 	if (!preg_match('#^[a-z0-9_\-\+\. ]+$#i', $name))
 | |
| 	{
 | |
| 		$error[] = $user->lang[$l_type . '_ERR_NAME_CHARS'];
 | |
| 	}
 | |
| 
 | |
| 	if (strlen($copyright) > 60)
 | |
| 	{
 | |
| 		$error[] = $user->lang[$l_type . '_ERR_COPY_LONG'];
 | |
| 	}
 | |
| 
 | |
| 	$sql = "SELECT {$type}_name 
 | |
| 		FROM $sql_from 
 | |
| 		WHERE {$type}_name = '" . $db->sql_escape($name) . "'";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	if (extract($db->sql_fetchrow($result)))
 | |
| 	{
 | |
| 		$error[] = $user->lang[$l_type . '_ERR_NAME_EXIST'];
 | |
| 	}
 | |
| 	$db->sql_freeresult($result);
 | |
| 
 | |
| 	if (sizeof($error))
 | |
| 	{
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	if ($action != 'install')
 | |
| 	{
 | |
| 		@mkdir("{$phpbb_root_path}styles/$path", 0777);
 | |
| 		@chmod("{$phpbb_root_path}styles/$path", 0777);
 | |
| 		if ($root_path)
 | |
| 		{
 | |
| 			copy_files("$root_path$type", filelist("$root_path$type", '', '*'), "$path/$type");
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	$sql_ary = array(
 | |
| 		$type . '_name'		=> $name,
 | |
| 		$type . '_copyright'=> $copyright, 
 | |
| 		$type . '_path'		=> $path,
 | |
| 	);
 | |
| 	if ($type != 'imageset')
 | |
| 	{
 | |
| 		switch ($type)
 | |
| 		{
 | |
| 			case 'template':
 | |
| 				$sql_ary += array(
 | |
| 					$type . '_storedb'	=> (!is_writeable("{$phpbb_root_path}styles/$path/$type")) ? 1 : 0
 | |
| 				);
 | |
| 				break;
 | |
| 
 | |
| 			case 'theme':
 | |
| 				$sql_ary += array(
 | |
| 					'theme_storedb'	=> (!is_writeable("{$phpbb_root_path}styles/$path/theme/stylesheet.css")) ? 1 : $storedb, 
 | |
| 					'theme_data'	=> ($storedb) ? (($root_path) ? str_replace('./', "styles/$path/theme/", implode('', file("$root_path/$type/stylesheet.css"))) : '') : '', 
 | |
| 					'theme_mtime'	=> ($storedb) ? filemtime("{$phpbb_root_path}styles/$path/theme/stylesheet.css") : 0
 | |
| 				);
 | |
| 				break;
 | |
| 		}
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		$cfg = file("$root_path$type/imageset.cfg");
 | |
| 
 | |
| 		for ($i = 3; $i < sizeof($cfg); $i++)
 | |
| 		{
 | |
| 			$tmp = explode('||', $cfg[$i]);
 | |
| 			$sql_ary[$tmp[0]] = str_replace('{PATH}', "styles/$path/imageset/", trim($tmp[1]));
 | |
| 		}
 | |
| 		unset($cfg);
 | |
| 	}
 | |
| 
 | |
| 	$db->sql_transaction('begin');
 | |
| 
 | |
| 	$sql = "INSERT INTO $sql_from 
 | |
| 		" . $db->sql_build_array('INSERT', $sql_ary);
 | |
| 	$db->sql_query($sql);
 | |
| 
 | |
| 	$id = $db->sql_nextid();
 | |
| 
 | |
| 	if ($type == 'template' && $storedb) 
 | |
| 	{
 | |
| 		$filelist = filelist("{$root_path}template", '', 'html');
 | |
| 		store_templates('insert', $id, $path, $filelist);
 | |
| 	}
 | |
| 
 | |
| 	$db->sql_transaction('commit');
 | |
| 
 | |
| 	$log = ($storedb) ? 'LOG_ADD_' . $l_type . '_FS' : 'LOG_ADD_' . $l_type . '_DB';
 | |
| 	add_log('admin', $log, $name);
 | |
| }
 | |
| 
 | |
| function install_style($action, &$error, $name, $copyright, $active, $default, $root_path, &$template_id, &$template_name, &$template_copyright, &$theme_id, &$theme_name, &$theme_copyright, &$imageset_id, &$imageset_name, &$imageset_copyright)
 | |
| {
 | |
| 	global $config, $db, $user;
 | |
| 
 | |
| 	$element_ary = array('template', 'theme', 'imageset');
 | |
| 
 | |
| 	if (empty($name))
 | |
| 	{
 | |
| 		$error[] = $user->lang['STYLE_ERR_STYLE_NAME'];
 | |
| 	}
 | |
| 
 | |
| 	if (strlen($name) > 30)
 | |
| 	{
 | |
| 		$error[] = $user->lang['STYLE_ERR_NAME_LONG'];
 | |
| 	}
 | |
| 
 | |
| 	if (!preg_match('#^[a-z0-9_\-\+\. ]+$#i', $name))
 | |
| 	{
 | |
| 		$error[] = $user->lang['STYLE_ERR_NAME_CHARS'];
 | |
| 	}
 | |
| 
 | |
| 	if (strlen($copyright) > 60)
 | |
| 	{
 | |
| 		$error[] = $user->lang['STYLE_ERR_COPY_LONG'];
 | |
| 	}
 | |
| 
 | |
| 	$sql = 'SELECT style_name 
 | |
| 		FROM ' . STYLES_TABLE . " 
 | |
| 		WHERE style_name = '" . $db->sql_escape($name) . "'";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	if (extract($db->sql_fetchrow($result)))
 | |
| 	{
 | |
| 		$error[] = $user->lang['STYLE_ERR_NAME_EXIST'];
 | |
| 	}
 | |
| 	$db->sql_freeresult($result);
 | |
| 
 | |
| 	foreach ($element_ary as $element)
 | |
| 	{
 | |
| 		// Zero id value ... need to install element ... run usual checks
 | |
| 		// and do the install if necessary
 | |
| 		if (!${$element . '_id'})
 | |
| 		{
 | |
| 			$error = install_element($element, $action, $root_path, ${$element . '_id'}, ${$element . '_name'}, ${$element . '_copyright'});
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if (!$template_id || !$theme_id || !$imageset_id)
 | |
| 	{
 | |
| 		$error[] = $user->lang['STYLE_ERR_NO_IDS'];
 | |
| 	}
 | |
| 
 | |
| 	if (sizeof($error))
 | |
| 	{
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	$db->sql_transaction('begin');
 | |
| 
 | |
| 	$sql_ary = array(
 | |
| 		'style_name'		=> $name, 
 | |
| 		'style_copyright'	=> $copyright, 
 | |
| 		'style_active'		=> $active, 
 | |
| 		'template_id'		=> $template_id, 
 | |
| 		'theme_id'			=> $theme_id, 
 | |
| 		'imageset_id'		=> $imageset_id, 
 | |
| 	);
 | |
| 
 | |
| 	$sql = 'INSERT INTO ' . STYLES_TABLE . ' 
 | |
| 		' .  $db->sql_build_array('INSERT', $sql_ary);
 | |
| 	$db->sql_query($sql);
 | |
| 
 | |
| 	$id = $db->sql_nextid();
 | |
| 
 | |
| 	if ($default)
 | |
| 	{
 | |
| 		$sql = 'UPDATE ' . USERS_TABLE . " 
 | |
| 			SET user_style = $id 
 | |
| 			WHERE user_style = " . $config['default_style'];
 | |
| 		$db->sql_query($sql);
 | |
| 
 | |
| 		set_config('default_style', $id);
 | |
| 	}
 | |
| 
 | |
| 	$db->sql_transaction('commit');
 | |
| 
 | |
| 	add_log('admin', 'LOG_ADD_STYLE', $name);
 | |
| }
 | |
| 
 | |
| // Commented inline
 | |
| function install($type, $action, $id)
 | |
| {
 | |
| 	global $phpbb_root_path, $phpEx, $SID, $config, $db, $cache, $user;
 | |
| 	global $safe_mode, $file_uploads, $archive_preg;
 | |
| 
 | |
| 	$install_path = (isset($_REQUEST['path'])) ? htmlspecialchars($_REQUEST['path']) : '';
 | |
| 	$update = (isset($_POST['update'])) ? true : false;
 | |
| 
 | |
| 	$installcfg = $error = array();
 | |
| 	$template_storedb = $theme_storedb = $basis = false;
 | |
| 	$root_path = $tmp_path = $theme_data = $s_hidden_fields = '';
 | |
| 	$template_id = $template_name = $template_copyright =$theme_id = $theme_name = $theme_copyright = $imageset_id = $imageset_name = $imageset_copyright = '';
 | |
| 
 | |
| 	$l_type = strtoupper($type);
 | |
| 	$l_prefix = ($action == 'add') ? 'ADD' : (($action == 'details') ? 'EDIT_DETAILS' : 'INSTALL');
 | |
| 
 | |
| 	$element_ary = array('template' => STYLES_TPL_TABLE, 'theme' => STYLES_CSS_TABLE, 'imageset' => STYLES_IMAGE_TABLE);
 | |
| 	$phpbbversion = preg_replace('#^2\.([0-9]+?)\.([0-9]+?).*?$#', '\1.\2', $config['version']);
 | |
| 
 | |
| 	switch ($type)
 | |
| 	{
 | |
| 		case 'style':
 | |
| 			$sql_from = STYLES_TABLE;
 | |
| 			break;
 | |
| 		case 'template':
 | |
| 			$sql_from = STYLES_TPL_TABLE;
 | |
| 			break;
 | |
| 		case 'theme':
 | |
| 			$sql_from = STYLES_CSS_TABLE;
 | |
| 			break;
 | |
| 		case 'imageset':
 | |
| 			$sql_from = STYLES_IMAGE_TABLE;
 | |
| 			break;
 | |
| 	}
 | |
| 
 | |
| 	// Importing/uploading then check data and extract archive
 | |
| 	if (!empty($_FILES['upload_file']['name']) || !empty($_POST['import_file']))
 | |
| 	{
 | |
| 		if (!empty($_FILES['upload_file']['name']))
 | |
| 		{
 | |
| 			$realname = htmlspecialchars($_FILES['upload_file']['name']);
 | |
| 			$filename = htmlspecialchars($_FILES['upload_file']['tmp_name']);
 | |
| 
 | |
| 			if (!is_uploaded_file($filename))
 | |
| 			{
 | |
| 				trigger_error("$filename was not uploaded");
 | |
| 			}
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			$realname = htmlspecialchars($_POST['import_file']);
 | |
| 			$filename = "{$phpbb_root_path}store/$realname";
 | |
| 		}
 | |
| 
 | |
| 		if (!preg_match('#(' . $archive_preg . ')$#i', $realname, $match))
 | |
| 		{
 | |
| 			$error[] = sprintf($user->lang['UPLOAD_WRONG_TYPE'], $archive_types);
 | |
| 		}
 | |
| 		$path = preg_replace('#^(.*?)' . preg_quote($match[0]) . '$#', '\1', $realname);
 | |
| 
 | |
| 		// Attempt to extract the files to a temporary directory in store
 | |
| 		$tmp_path = $phpbb_root_path . 'store/tmp_' . substr(uniqid(''), 0, 10) . '/';
 | |
| 		if (!@mkdir($tmp_path))
 | |
| 		{
 | |
| 			trigger_error("Cannot create $tmp_path", E_USER_ERROR);
 | |
| 		}
 | |
| 
 | |
| 		include($phpbb_root_path . 'includes/functions_compress.'.$phpEx);
 | |
| 
 | |
| 		switch ($match[0])
 | |
| 		{
 | |
| 			case '.zip':
 | |
| 				$zip = new compress_zip('r', $filename);
 | |
| 				break;
 | |
| 			default:
 | |
| 				$zip = new compress_tar('r', $filename, $match[0]);
 | |
| 		}
 | |
| 		$zip->extract($tmp_path);
 | |
| 		$zip->close();
 | |
| 
 | |
| 		unset($cfg);
 | |
| 	}
 | |
| 
 | |
| 	// Installing, importing/uploading then obtain the style cfg information
 | |
| 	if (($action == 'install' && $install_path) || (!empty($_FILES['upload_file']['name']) || !empty($_POST['import_file'])))
 | |
| 	{
 | |
| 		$root_path = ($action == 'install') ? "{$phpbb_root_path}styles/$install_path/" : "$tmp_path";
 | |
| 		$cfg_path = ($type == 'style') ? "$root_path$type.cfg" : "$root_path$type/$type.cfg";
 | |
| 
 | |
| 		if (!($fp = @fopen($cfg_path, 'rb')))
 | |
| 		{
 | |
| 			$error[] = $user->lang[$l_type . '_ERR_NOT_' . $l_type];
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			$installcfg = explode("\n", fread($fp, filesize($cfg_path)));
 | |
| 		}
 | |
| 		fclose($fp);
 | |
| 	}
 | |
| 
 | |
| 	// Installing, importing/uploading then grab the element info else grab the 
 | |
| 	// submitted params ... stylecfg will be set if this is true (see above)
 | |
| 	if (sizeof($installcfg))
 | |
| 	{
 | |
| 		$name		= trim($installcfg[0]);
 | |
| 		$copyright	= trim($installcfg[1]);
 | |
| 		$version	= preg_replace('#^2\.([0-9]+?)\.([0-9]+?).*?$#', '\1.\2', trim($installcfg[2]));
 | |
| 
 | |
| 		switch ($type)
 | |
| 		{
 | |
| 			case 'style':
 | |
| 				$reqd_template		= trim($installcfg[3]);
 | |
| 				$reqd_theme			= trim($installcfg[4]);
 | |
| 				$reqd_imageset		= trim($installcfg[5]);
 | |
| 
 | |
| 				// Check to see if each element is already installed, if it is grab the id
 | |
| 				foreach ($element_ary as $element => $table)
 | |
| 				{
 | |
| 					${$element . '_id'} = ${$element . '_name'} = ${$element . '_copyright'} = '';
 | |
| 
 | |
| 		 			test_installed($element, $error, $root_path, ${'reqd_' . $element}, ${$element . '_id'}, ${$element . '_name'}, ${$element . '_copyright'});
 | |
| 				}
 | |
| 				break;
 | |
| 
 | |
| 			case 'template':
 | |
| 				test_installed('template', $error, $root_path, false, $template_id, $template_name, $template_copyright);
 | |
| 				break;
 | |
| 
 | |
| 			case 'theme':
 | |
| 				test_installed('theme', $error, $root_path, false, $theme_id, $theme_name, $theme_copyright);
 | |
| 				break;
 | |
| 
 | |
| 			case 'imageset':
 | |
| 				test_installed('imageset', $error, $root_path, false, $imageset_id, $imageset_name, $imageset_copyright);
 | |
| 				break;
 | |
| 		}
 | |
| 
 | |
| 		$s_hidden_fields = '<input type="hidden" name="path" value="' . $install_path . '" />';
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		// NOTE: Data here is stripslashed! Ensure it's escaped when entering the DB
 | |
| 		$name		 = (!empty($_POST['name'])) ? stripslashes(htmlspecialchars($_POST['name'])) : '';
 | |
| 		$copyright	 = (!empty($_POST['copyright'])) ? stripslashes(htmlspecialchars($_POST['copyright'])) : '';
 | |
| 
 | |
| 		$template_id = (!empty($_POST['template_id'])) ? intval($_POST['template_id']) : 0;
 | |
| 		$theme_id	 = (!empty($_POST['theme_id'])) ? intval($_POST['theme_id']) : 0;
 | |
| 		$imageset_id = (!empty($_POST['imageset_id'])) ? intval($_POST['imageset_id']) : 0;
 | |
| 		$basis		 = (isset($_POST['basis'])) ? intval($_POST['basis']) : 0;
 | |
| 
 | |
| 		// If we have a basis  or we're editing we want some additional info ... else
 | |
| 		// we need nothing 
 | |
| 		if ($basis || ($update && $action != 'add'))
 | |
| 		{
 | |
| 			switch ($type)
 | |
| 			{
 | |
| 				case 'style':
 | |
| 					$sql_select = ($action != 'details') ? 'style_name, template_id, theme_id, imageset_id' : 'style_name';
 | |
| 					break;
 | |
| 				case 'template':
 | |
| 					$sql_select = 'template_id, template_name, template_path, template_storedb';
 | |
| 					break;
 | |
| 				case 'theme':
 | |
| 					$sql_select = 'theme_id, theme_name, theme_path, theme_data, theme_storedb';
 | |
| 					break;
 | |
| 				case 'imageset':
 | |
| 					$sql_select = 'imageset_id, imageset_name, imageset_path';
 | |
| 					break;
 | |
| 			}
 | |
| 
 | |
| 			$sql = "SELECT $sql_select  
 | |
| 				FROM $sql_from  
 | |
| 				WHERE {$type}_id = " . (($basis) ? $basis : $id);
 | |
| 			$result = $db->sql_query($sql);
 | |
| 
 | |
| 			if (!extract($db->sql_fetchrow($result))) 
 | |
| 			{
 | |
| 				$error[] = $user->lang['NO_' . $l_type];
 | |
| 			}
 | |
| 			$db->sql_freeresult($result);
 | |
| 
 | |
| 			$s_hidden_fields .= '<input type="hidden" name="basis" value="' . $basis . '" />';
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	$storedb		= (!empty($_POST['storedb'])) ? 1 : 0;
 | |
| 	$style_active	= (isset($_POST['style_active'])) ? ((!empty($_POST['style_active'])) ? 1 : 0) : 1;
 | |
| 	$style_default	= (isset($_POST['style_default'])) ? ((!empty($_POST['style_default'])) ? 1 : 0) : (($config['default_style'] == $id) ? 1 : 0);
 | |
| 
 | |
| 	// User has submitted form and no errors have occured
 | |
| 	if ($update && !sizeof($error))
 | |
| 	{
 | |
| 		$sql_ary = array();
 | |
| 
 | |
| 		// We're installing/uploading/importing
 | |
| 		if ($action == 'install')
 | |
| 		{
 | |
| 			switch ($type)
 | |
| 			{
 | |
| 				case 'style':
 | |
| 					install_style($action, $error, $name, $copyright, $style_active, $style_default, $root_path, $template_id, $template_name, $template_copyright, $theme_id, $theme_name, $theme_copyright, $imageset_id, $imageset_name, $imageset_copyright);
 | |
| 					break;
 | |
| 
 | |
| 				case 'template':
 | |
| 					install_element('template', $error, $action, $root_path, $id, $name, $copyright);
 | |
| 					break;
 | |
| 
 | |
| 				case 'theme':
 | |
| 					install_element('theme', $error, $action, $root_path, $id, $name, $copyright);
 | |
| 					break;
 | |
| 
 | |
| 				case 'imageset':
 | |
| 					install_element('imageset', $error, $action, $root_path, $id, $name, $copyright);
 | |
| 					break;
 | |
| 			}
 | |
| 
 | |
| 			if ($tmp_path)
 | |
| 			{
 | |
| 				cleanup_folder($tmp_path);
 | |
| 			}
 | |
| 
 | |
| 			if (!sizeof($error))
 | |
| 			{
 | |
| 				$cache->destroy('sql', STYLES_TABLE);
 | |
| 
 | |
| 				$message = ($storedb) ? '_ADDED_DB' : '_ADDED';
 | |
| 				trigger_error($user->lang[$l_type . $message]);
 | |
| 			}
 | |
| 		}
 | |
| 		else if ($action == 'add') 
 | |
| 		{
 | |
| 			if ($type == 'style')
 | |
| 			{
 | |
| 				install_style($action, $error, $name, $copyright, $style_active, $style_default, $root_path, $template_id, $template_name, $template_copyright, $theme_id, $theme_name, $theme_copyright, $imageset_id, $imageset_name, $imageset_copyright);
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				// Create path if it doesn't exist
 | |
| 				$storedb = 1;
 | |
| 
 | |
| 				umask(0);
 | |
| 				if (file_exists("{$phpbb_root_path}styles/$path") || @mkdir("{$phpbb_root_path}styles/$path", 0777))
 | |
| 				{
 | |
| 					if (@chmod("{$phpbb_root_path}styles/$path", 0777))
 | |
| 					{
 | |
| 						$storedb = 0;
 | |
| 					}
 | |
| 				}
 | |
| 
 | |
| 				if ($basis && ($template_storedb || $theme_storedb))
 | |
| 				{
 | |
| 					$tmp_path = $phpbb_root_path . 'store/tmp_' . substr(uniqid(''), 0, 10) . '/';
 | |
| 					if (!@mkdir($tmp_path, 0777))
 | |
| 					{
 | |
| 						trigger_error("Cannot create $tmp_path", E_USER_ERROR);
 | |
| 					}
 | |
| 					@chmod($tmp_path, 0777);
 | |
| 
 | |
| 					if (!@mkdir("$tmp_path$type", 0777))
 | |
| 					{
 | |
| 						trigger_error("Cannot create $tmp_path$type", E_USER_ERROR);
 | |
| 					}
 | |
| 					@chmod("$tmp_path$type", 0777);
 | |
| 
 | |
| 					switch ($type)
 | |
| 					{
 | |
| 						case 'theme':
 | |
| 							copyfiles("{$phpbb_root_path}styles/$path/theme/", filelist("{$phpbb_root_path}styles/$path/theme/", '', '*'), "$tmp_path$type/");
 | |
| 
 | |
| 							$fp = fopen("$tmp_path$type/stylesheet.css", 'wb');
 | |
| 							fwrite($fp, $theme_data);
 | |
| 							fclose($theme_data);
 | |
| 							break;
 | |
| 
 | |
| 						case 'template':
 | |
| 							copyfiles("{$phpbb_root_path}styles/$path/$type/", filelist("{$phpbb_root_path}styles/$path/$type/", '', '*'), "$tmp_path$type/");
 | |
| 						
 | |
| 							$sql = 'SELECT template_filename, template_mtime, template_data 
 | |
| 								FROM ' . STYLES_TPLDATA_TABLE . "
 | |
| 								WHERE template_id = $basis";
 | |
| 							$result = $db->sql_fetchrow($result);
 | |
| 
 | |
| 							while ($row = $db->sql_fetchrow($result))
 | |
| 							{
 | |
| 								$fp = fopen("$tmp_path$type/" . $row['template_filename'], 'wb');
 | |
| 								fwrite($fp, $row['template_data']);
 | |
| 								fclose($fp);
 | |
| 							}
 | |
| 							$db->sql_freeresult($result);
 | |
| 							break;
 | |
| 					}
 | |
| 				}
 | |
| 
 | |
| 				$root_path = ($tmp_path) ? $tmp_path : (($basis) ? $phpbb_root_path . 'styles/' . ${$type . '_path'} . '/' : '');
 | |
| 
 | |
| 				install_element($type, $error, $action, $root_path, $id, $name, $copyright, $storedb);
 | |
| 			}
 | |
| 
 | |
| 			if ($tmp_path)
 | |
| 			{
 | |
| 				cleanup_folder($tmp_path);
 | |
| 			}
 | |
| 
 | |
| 			if (!sizeof($error))
 | |
| 			{
 | |
| 				$cache->destroy('sql', STYLES_TABLE);
 | |
| 
 | |
| 				$message = ($storedb) ? '_ADDED_DB' : '_ADDED';
 | |
| 				trigger_error($user->lang["$l_type$message"]);
 | |
| 			}
 | |
| 		}
 | |
| 		else if ($action == 'details')
 | |
| 		{
 | |
| 			if ($type == 'style')
 | |
| 			{
 | |
| 				$sql_ary = array(
 | |
| 					'template_id'		=> $template_id, 
 | |
| 					'theme_id'			=> $theme_id, 
 | |
| 					'imageset_id'		=> $imageset_id, 
 | |
| 					'style_active'		=> $style_active, 
 | |
| 				);
 | |
| 			}
 | |
| 			else if ($type != 'imageset')
 | |
| 			{
 | |
| 				switch ($type)
 | |
| 				{
 | |
| 					case 'theme':
 | |
| 						if ($theme_storedb != $storedb)
 | |
| 						{
 | |
| 							$theme_data = implode('', file("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css"));
 | |
| 							if (!$storedb && !$safe_mode && is_writeable("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css"))
 | |
| 							{
 | |
| 								$storedb = 1;
 | |
| 								if ($fp = @fopen("{$phpbb_root_path}styles/$theme_path/$type/stylesheet.css", 'wb'))
 | |
| 								{
 | |
| 									$storedb = (@fwrite($fp, str_replace("styles/$theme_path/theme/", './', $theme_data))) ? 0 : 1;
 | |
| 								}
 | |
| 								fclose($fp);
 | |
| 							}
 | |
| 							$theme_data = str_replace('./', "styles/$theme_path/theme/", $theme_data);
 | |
| 
 | |
| 							$sql_ary = array(
 | |
| 								'theme_mtime'	=> ($storedb) ? filemtime("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css") : 0, 
 | |
| 								'theme_storedb'	=> $storedb, 
 | |
| 								'theme_data'	=> ($storedb) ? $theme_data : '',
 | |
| 							);
 | |
| 						}
 | |
| 						break;
 | |
| 					
 | |
| 					case 'template':
 | |
| 						if ($theme_storedb != $storedb)
 | |
| 						{
 | |
| 							$filelist = filelist("{$phpbb_root_path}styles/$template_path/template", '', 'html');
 | |
| 
 | |
| 							if (!$storedb && !$safe_mode && is_writeable("{$phpbb_root_path}styles/$template_path/template"))
 | |
| 							{
 | |
| 								$sql = 'SELECT * 
 | |
| 									FROM ' . STYLES_TPLDATA_TABLE . " 
 | |
| 									WHERE template_id = $id";
 | |
| 								$result = $db->sql_query($sql);
 | |
| 
 | |
| 								while ($row = $db->sql_fetchrow($result))
 | |
| 								{
 | |
| 									if (!($fp = @fopen("{$phpbb_root_path}styles/$template_path/template/" . $row['template_filename'], 'wb')))
 | |
| 									{
 | |
| 										$storedb = 1;
 | |
| 										break;
 | |
| 									}
 | |
| 
 | |
| 									fwrite($fp, $row['template_data']);
 | |
| 									fclose($fp);
 | |
| 								}
 | |
| 								$db->sql_freeresult($result);
 | |
| 
 | |
| 								if (!$storedb)
 | |
| 								{
 | |
| 									$sql = 'DELETE FROM ' . STYLES_TPLDATA_TABLE . " 
 | |
| 										WHERE template_id = $id";
 | |
| 									$db->sql_query($sql);
 | |
| 								}
 | |
| 							}
 | |
| 
 | |
| 							$sql_ary = array(
 | |
| 								'template_storedb'	=> $storedb, 
 | |
| 							);
 | |
| 						}
 | |
| 						break;
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			if ($type != 'imageset' && sizeof($sql_ary))
 | |
| 			{
 | |
| 				$sql = "UPDATE $sql_from 
 | |
| 					SET " . $db->sql_build_array('UPDATE', $sql_ary) . " 
 | |
| 					WHERE {$type}_id = $id";
 | |
| 				$db->sql_query($sql);
 | |
| 
 | |
| 				if ($type == 'style' && $style_default)
 | |
| 				{
 | |
| 					set_config('default_style', $id);
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			$cache->destroy('sql', STYLES_TABLE);
 | |
| 
 | |
| 			add_log('admin', 'LOG_EDIT_' . $l_type, $name);
 | |
| 			trigger_error($user->lang[$l_type . '_EDITED']);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// Something went wrong ... so we'll clean up any decompressed uploaded/imported archives.
 | |
| 	if ($tmp_path)
 | |
| 	{
 | |
| 		cleanup_folder($tmp_path);
 | |
| 	}
 | |
| 
 | |
| 	// Either an error occured or the user has just entered the form
 | |
| 	if (!sizeof($error) && !$update && $id)
 | |
| 	{
 | |
| 		$sql = "SELECT * 
 | |
| 			FROM $sql_from
 | |
| 			WHERE {$type}_id = $id";
 | |
| 		$result = $db->sql_query($sql);
 | |
| 
 | |
| 		if (!extract($db->sql_fetchrow($result)))
 | |
| 		{
 | |
| 			trigger_error($user->lang['NO_' . $l_type]);
 | |
| 		}
 | |
| 		$db->sql_freeresult($result);
 | |
| 
 | |
| 		$style_default = ($type == 'style' && $config['default_style'] == $id) ? 1 : 0;
 | |
| 		$storedb = (!empty(${$type . '_storedb'})) ? true : false; // Fudged because we use $storedb when submitting data
 | |
| 	}
 | |
| 
 | |
| 	if ($type == 'style' && $action != 'install')
 | |
| 	{
 | |
| 		$style_options = array();
 | |
| 		foreach ($element_ary as $element => $table)
 | |
| 		{
 | |
| 			$sql = "SELECT {$element}_id, {$element}_name
 | |
| 				FROM $table 
 | |
| 				ORDER BY {$element}_id ASC";
 | |
| 			$result = $db->sql_query($sql);
 | |
| 
 | |
| 			while ($row = $db->sql_fetchrow($result))
 | |
| 			{
 | |
| 				$selected = ($row[$element . '_id'] == ${$element . '_id'}) ? ' selected="selected"' : '';
 | |
| 				${$element . '_options'} .= '<option value="' . $row[$element . '_id'] . '"' . $selected . '>' . $row[$element . '_name'] . '</option>';
 | |
| 			}
 | |
| 			$db->sql_freeresult($result);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// Output the page
 | |
| 	adm_page_header($user->lang[$l_prefix . '_' . $l_type]);
 | |
| 
 | |
| ?>
 | |
| 
 | |
| <h1><?php echo $user->lang[$l_prefix . '_' . $l_type]; ?></h1>
 | |
| 
 | |
| <p><?php echo $user->lang[$l_prefix . '_' . $l_type . '_EXPLAIN']; ?></p>
 | |
| 
 | |
| <form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&mode=$type&action=$action&id=$id"; ?>"<?php echo (!$safe_mode && $file_uploads && is_writeable("{$phpbb_root_path}styles")) ? ' enctype="multipart/form-data"' : ''; ?>><table class="bg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<th colspan="2"><?php echo $user->lang[$l_prefix . '_' . $l_type]; ?></th>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 	if (sizeof($error))
 | |
| 	{
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td colspan="2" class="row3" align="center"><span style="color:red"><?php echo implode('<br />', $error); ?></span></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row1" width="40%"><b><?php echo $user->lang[$l_type . '_NAME']; ?>:</b></td>
 | |
| 		<td class="row2"><?php
 | |
| 	
 | |
| 	echo ($action == 'add') ? '<input class="post" type="text" name="name" maxlength="30" size="30" value="' . $name . '" />' : '<b>' . ${$type . '_name'} . '</b>';
 | |
| 
 | |
| ?></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row1"><b><?php echo $user->lang['COPYRIGHT']; ?>:</b></td>
 | |
| 		<td class="row2"><?php
 | |
| 	
 | |
| 	echo ($action == 'add') ? '<input class="post" type="text" name="copyright" maxlength="60" size="30" value="' . $copyright . '" />' : '<b>' . ${$type . '_copyright'} . '</b>';
 | |
| 
 | |
| ?></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 	if ($type == 'style' && !$basis)
 | |
| 	{
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row1"><b><?php echo $user->lang['STYLE_TEMPLATE']; ?>:</b></td>
 | |
| 		<td class="row2"><?php
 | |
| 	
 | |
| 		echo ($action == 'install') ? "<b>$template_name</b>" : '<select name="template_id">' . $template_options . '</select>';
 | |
| 
 | |
| ?></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row1"><b><?php echo $user->lang['STYLE_THEME']; ?>:</b></td>
 | |
| 		<td class="row2"><?php
 | |
| 	
 | |
| 		echo ($action == 'install') ? "<b>$theme_name</b>" : '<select name="theme_id">' . $theme_options . '</select>';
 | |
| 
 | |
| ?></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row1"><b><?php echo $user->lang['STYLE_IMAGESET']; ?>:</b></td>
 | |
| 		<td class="row2"><?php
 | |
| 	
 | |
| 		echo ($action == 'install') ? "<b>$imageset_name</b>" : '<select name="imageset_id">' . $imageset_options . '</select>';
 | |
| 
 | |
| ?></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 	}
 | |
| 
 | |
| 	if ($type == 'template' || $type == 'theme')
 | |
| 	{
 | |
| 		$storedb_no = (!$storedb) ? ' checked="checked"' : '';
 | |
| 		$storedb_yes = ($storedb) ? ' checked="checked"' : '';
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row1" width="40%"><b><?php echo $user->lang[$l_type . '_LOCATION']; ?>:</b><br /><span class="gensmall"><?php echo $user->lang[$l_type . '_LOCATION_EXPLAIN']; ?></span></td>
 | |
| 		<td class="row2"><input type="radio" name="storedb" value="0"<?php echo $storedb_no; ?> /> <?php echo $user->lang['STORE_FILESYSTEM']; ?>  <input type="radio" name="storedb" value="1"<?php echo $storedb_yes; ?> /> <?php echo $user->lang['STORE_DATABASE']; ?></td>
 | |
| 	</tr>
 | |
| <?php 
 | |
| 
 | |
| 	}
 | |
| 
 | |
| 	// Import, upload and basis options
 | |
| 	if ($action == 'add' && !$safe_mode && is_writeable("{$phpbb_root_path}styles"))
 | |
| 	{
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<th colspan="2"><?php echo $user->lang['OPTIONS']; ?></th>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 		if (!$basis)
 | |
| 		{
 | |
| 			$store_options = '';
 | |
| 			$dp = @opendir("{$phpbb_root_path}store");
 | |
| 			while ($file = readdir($dp))
 | |
| 			{
 | |
| 				if ($file{0} != '.' && preg_match('#(' . $archive_preg . ')$#i', $file))
 | |
| 				{
 | |
| 					$store_options .= "<option value=\"$file\">$file</option>";
 | |
| 				}
 | |
| 			}
 | |
| 			closedir($dp);
 | |
| 
 | |
| 			$store_options = '<option value="">' . $user->lang['NO_IMPORT'] . '</option>' . $store_options;
 | |
| 
 | |
| 			if ($file_uploads)
 | |
| 			{
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row1" width="40%"><b><?php echo $user->lang[$l_type . '_UPLOAD_BASIS']; ?>:</b><br /><span class="gensmall"><?php echo $user->lang['ALLOWED_FILETYPES']; ?>: <?php echo $archive_types; ?></span></td>
 | |
| 		<td class="row2"><input class="post" type="file" name="upload_file" /><input type="hidden" name="MAX_FILE_SIZE" value="1048576" /></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 			}
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row1" width="40%"><b><?php echo $user->lang[$l_type . '_IMPORT_BASIS']; ?>:</b></td>
 | |
| 		<td class="row2"><select name="import_file"><?php echo $store_options; ?></select></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 		}	
 | |
| 		else if ($basis)
 | |
| 		{
 | |
| 	
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row1" width="40%"><b><?php echo $user->lang[$l_type . '_BASIS']; ?>: </b></td>
 | |
| 		<td class="row2"><b><?php echo ${$type . '_name'}; ?></b></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if ($type == 'style')
 | |
| 	{
 | |
| 		$active_yes = ($style_active) ? ' checked="checked"' : '';
 | |
| 		$active_no = (!$style_active) ? ' checked="checked"' : '';
 | |
| 		$style_default_yes = ($style_default) ? ' checked="checked"' : '';
 | |
| 		$style_default_no = (!$style_default) ? ' checked="checked"' : '';
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<th colspan="2"> </th>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row1"><b><?php echo $user->lang['STYLE_ACTIVE']; ?>:</b></td>
 | |
| 		<td class="row2"><input type="radio" name="style_active" value="1"<?php echo $active_yes; ?> /> <?php echo $user->lang['YES']; ?>   <input type="radio" name="style_active" value="0"<?php echo $active_no; ?> /> <?php echo $user->lang['NO']; ?></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 		if ($id != $config['default_style'])
 | |
| 		{
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="row1"><b><?php echo $user->lang['STYLE_DEFAULT']; ?>:</b></td>
 | |
| 		<td class="row2"><input type="radio" name="style_default" value="1"<?php echo $style_default_yes; ?> /> <?php echo $user->lang['YES']; ?>   <input type="radio" name="style_default" value="0"<?php echo $style_default_no; ?> /> <?php echo $user->lang['NO']; ?></td>
 | |
| 	</tr>
 | |
| <?php
 | |
| 
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| ?>
 | |
| 	<tr>
 | |
| 		<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="update" value="<?php echo $user->lang['SUBMIT']; ?>" />  <input class="btnlite" type="reset" value="<?php echo $user->lang['RESET']; ?>" /><?php echo $s_hidden_fields; ?></td>
 | |
| 	</tr>
 | |
| </table></form>
 | |
| <?php
 | |
| 
 | |
| 	adm_page_footer();
 | |
| 
 | |
| }
 | |
| 
 | |
| 
 | |
| // Hopefully temporary
 | |
| function theme_preview(&$path, &$stylesheet, &$class, &$css_element)
 | |
| {
 | |
| 	global $config, $user;
 | |
| 
 | |
| ?>
 | |
| <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
 | |
| <html dir="<?php echo $user->lang['LTR']; ?>">
 | |
| <head>
 | |
| <meta http-equiv="Content-Type" content="text/html; charset=<?php echo $user->lang['ENCODING']; ?>">
 | |
| <meta http-equiv="Content-Style-Type" content="text/css">
 | |
| <style type="text/css">
 | |
| <!--
 | |
| <?php
 | |
| 
 | |
| 
 | |
| 	$updated_element = implode('; ', $css_element) . ';';
 | |
| 
 | |
| 	if (preg_match('#^' . $class . ' {(.*?)}#m', $stylesheet))
 | |
| 	{
 | |
| 		$stylesheet = preg_replace('#^(' . $class . ' {).*?(})#m', '\1 ' . $updated_element . ' \2', $stylesheet);
 | |
| 	}
 | |
| 
 | |
| 	echo str_replace('styles/', '../styles/', str_replace('./', "styles/$path/theme/", $stylesheet));
 | |
| 
 | |
| ?>
 | |
| //-->
 | |
| </style>
 | |
| </head>
 | |
| <body>
 | |
| 
 | |
| <table width="100%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 	<tr align="center" valign="middle">
 | |
| 		<td height="100" width="33%"><h1>h1</h1></td>
 | |
| 		<td height="100" width="33%"><h2>h2</h2></td>
 | |
| 		<td height="100" width="33%"><h3>h3</h3></td>
 | |
| 	</tr>
 | |
| 	<tr align="center">
 | |
| 		<td colspan="3" height="30"><a class="mainmenu" href="">mainmenu</a></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td colspan="3" height="50"> </td>
 | |
| 	</tr>
 | |
| </table>
 | |
| 
 | |
| <table width="95%" cellspacing="2" cellpadding="2" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<td align="left" valign="bottom"><a class="titles" href="">titles</a>
 | |
| 	</tr>
 | |
| </table>
 | |
| 
 | |
| <table width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<td class="nav" width="10" align="left" valign="middle"><a href="">navlink</a></td>
 | |
| 	</tr>
 | |
| </table>
 | |
| 
 | |
| <table class="tablebg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<th colspan="3">th</th>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="cat" width="40%"><span class="cattitle">cattitle / cat</span></td>
 | |
| 		<td class="catdiv" colspan="2">catdiv</td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row1" width="40%"><a class="topictitle" href="">topictitle / row1</a></td>
 | |
| 		<td class="row2"><span class="topicauthor">topicauthor / row2</span></td>
 | |
| 		<td class="row1"><span class="topicdetails">topicdetails / row1</span></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row3" colspan="3">row3</td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="spacer" colspan="3">spacer</td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row1"><span class="postauthor">postauthor / row1</span></td>
 | |
| 		<td class="row2"><span class="postdetails">postdetails / row2</span></td>
 | |
| 		<td class="row1"><span class="postbody">postbody / row1 <span class="posthilit">posthilit</span></span></td>
 | |
| 	</tr>
 | |
| </table>
 | |
| 
 | |
| <br /><hr width="95%" />
 | |
| 
 | |
| <table width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 	<tr align="center">
 | |
| 		<td><span class="gen">gen</span></td>
 | |
| 		<td><span class="genmed">genmed</span></td>
 | |
| 		<td><span class="gensmall">gensmall</span></td>
 | |
| 	</tr>
 | |
| 	<tr align="center">
 | |
| 		<td colspan="3"><span class="copyright">copyright <a href="">phpBB</a></span></td>
 | |
| 	</tr>
 | |
| </table>
 | |
| 
 | |
| <hr width="95%" /><br />
 | |
| 
 | |
| <form><table width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 	<tr align="center">
 | |
| 		<td><input class="btnmain" type="submit" value="input / btnmain" /></td>
 | |
| 		<td><input class="btnlite" type="submit" value="input / btnlite" /></td>
 | |
| 		<td><input class="btnbbcode" type="submit" value="input / btnbbcode" /></td>
 | |
| 	</tr>
 | |
| 	<tr align="center">
 | |
| 		<td colspan="3"><input class="post" type="text" value="input / post" /></td>
 | |
| 	</tr>
 | |
| 	<tr align="center">
 | |
| 		<td colspan="3"><select class="post"><option>select</option></select></td>
 | |
| 	</tr>
 | |
| 	<tr align="center">
 | |
| 		<td colspan="3"><textarea class="post">textarea / post</textarea></td>
 | |
| 	</tr>
 | |
| </table></form>
 | |
| 
 | |
| <hr width="95%" /><br />
 | |
| 
 | |
| <table class="tablebg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
 | |
| 	<tr>
 | |
| 		<td class="row2" align="center"><span class="postbody">postbody / <b>bold</b> <i>italic</i> <u>underline</u></span></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row2"><table width="90%" cellspacing="1" cellpadding="3" border="0" align="center">
 | |
| 			<tr>
 | |
| 				<td class="quote"><b>A_N_Other wrote:</b><hr />quote</td>
 | |
| 			</tr>
 | |
| 		</table></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row2"><table width="90%" cellspacing="1" cellpadding="3" border="0" align="center">
 | |
| 			<tr> 
 | |
| 				<td><b class="genmed">Code:</b></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="code">10 Print "hello"<br />20 Goto 10</td>
 | |
| 			</tr>
 | |
| 		</table></td>
 | |
| 	</tr>
 | |
| 	<tr>
 | |
| 		<td class="row2"><table width="90%" cellspacing="1" cellpadding="3" border="0" align="center">
 | |
| 			<tr> 
 | |
| 				<td><b class="genmed">PHP:</b></td>
 | |
| 			</tr>
 | |
| 			<tr>
 | |
| 				<td class="code"><span class="syntaxbg"><span class="syntaxcomment">// syntaxcomment</span><br /><span class="syntaxdefault">?></span><br /><<span class="syntaxhtml">HTML</span>><br /><span class="syntaxdefault"><?php</span><br /><span class="syntaxkeyword">echo </span> <span class="syntaxdefault">$this = </span><span class="syntaxstring">"HELLO"</span><span class="syntaxdefault">;</span></span></td>
 | |
| 			</tr>
 | |
| 		</table></td>
 | |
| 	</tr>
 | |
| </table>
 | |
| 
 | |
| <br clear="all" />
 | |
| 
 | |
| </body>
 | |
| </html>
 | |
| <?php
 | |
| 	
 | |
| }
 | |
| //
 | |
| // FUNCTIONS
 | |
| // ---------
 | |
| 
 | |
| ?>
 |