Different stylesheets in one theme

Started by Gary, July 30, 2006, 10:26:20 PM

Previous topic - Next topic

bloc

No. But when you searched for code..was it 100% the same? If not, that might happen.

If you could show the index.template you are working on, maybe I can spot the error.

Red-Omni

<?php
// Version: 1.1 RC2; index

/* This template is, perhaps, the most important template in the theme. It
contains the main template layer that displays the header and footer of
the forum, namely with main_above and main_below. It also contains the
menu sub template, which appropriately displays the menu; the init sub
template, which is there to set the theme up; (init can be missing.) and
the linktree sub template, which sorts out the link tree.

The init sub template should load any data and set any hardcoded options.

The main_above sub template is what is shown above the main content, and
should contain anything that should be shown up there.

The main_below sub template, conversely, is shown after the main content.
It should probably contain the copyright statement and some other things.

The linktree sub template should display the link tree, using the data
in the $context['linktree'] variable.

The menu sub template should display all the relevant buttons the user
wants and or needs.

For more information on the templating system, please see the site at:
http://www.simplemachines.org/
*/

// Initialize the template... mainly little settings.
function template_init()
{
global $context$settings$options$txt;
if(!$context['user']['is_guest'] && isset($_POST['options']['theme_color']))
{
   include_once(
$GLOBALS['sourcedir'] . '/Profile.php');
   
makeThemeChanges($context['user']['id'], $settings['theme_id']);
   
$options['theme_color'] = $_POST['options']['theme_color'];

/* Use images from default theme when using templates from the default theme?
if this is 'always', images from the default theme will be used.
if this is 'defaults', images from the default theme will only be used with default templates.
if this is 'never' or isn't set at all, images from the default theme will not be used. */
$settings['use_default_images'] = 'never';

/* What document type definition is being used? (for font size and other issues.)
'xhtml' for an XHTML 1.0 document type definition.
'html' for an HTML 4.01 document type definition. */
$settings['doctype'] = 'xhtml';

/* The version this template/theme is for.
This should probably be the version of SMF it was created for. */
$settings['theme_version'] = '1.1 RC2';

/* Set a setting that tells the theme that it can render the tabs. */
$settings['use_tabs'] = true;

/* Use plain buttons - as oppossed to text buttons? */
$settings['use_buttons'] = true;

/* Show sticky and lock status seperate from topic icons? */
$settings['seperate_sticky_lock'] = true;
}

// The main sub template above the content.
function template_main_above()
{
global $context$settings$options$scripturl$txt$modSettings;
if (isset($options['theme_color']))
   
$mycolor $options['theme_color'];
else{
   
// Defaults.
   
$options['theme_color'] = isset($settings['default_theme_color']) ? $settings['default_theme_color'] : 'red';
   
$mycolor=$options['theme_color'];
}

// Show right to left and the character set for ease of translating.
echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"'
$context['right_to_left'] ? ' dir="rtl"' '''><head>
<meta http-equiv="Content-Type" content="text/html; charset='
$context['character_set'], '" />
<meta name="description" content="'
$context['page_title'], '" />
<meta name="keywords" content="Ford , ford ranger , ford explorer , ford f-150 , ford f-250 , ford f-350 , forums , ford forums" />
<script language="JavaScript" type="text/javascript" src="'
$settings['default_theme_url'], '/script.js?rc2p"></script>
<script language="JavaScript" type="text/javascript"><!-- // --><![CDATA[
var smf_theme_url = "'
$settings['theme_url'], '";
var smf_images_url = "'
$settings['images_url'], '";
var smf_scripturl = "'
$scripturl'";
// ]]></script>
<title>'
$context['page_title'], '</title>';

// The ?rc2 part of this link is just here to make sure browsers don't cache it wrongly.
echo '
<link rel="stylesheet" type="text/css" href="'
$settings['theme_url'], '/'.$mycolor.'_style.css?rc2" />
<link rel="stylesheet" type="text/css" href="'
$settings['default_theme_url'], '/print.css?rc2" media="print" />';

/* Internet Explorer 4/5 and Opera 6 just don't do font sizes properly. (they are big...)
Thus, in Internet Explorer 4, 5, and Opera 6 this will show fonts one size smaller than usual.
Note that this is affected by whether IE 6 is in standards compliance mode.. if not, it will also be big.
Standards compliance mode happens when you use xhtml... */
if ($context['browser']['needs_size_fix'])
echo '
<link rel="stylesheet" type="text/css" href="'
$settings['default_theme_url'], '/fonts-compat.css" />';

// Show all the relative links, such as help, search, contents, and the like.
echo '
<link rel="help" href="'
$scripturl'?action=help" target="_blank" />
<link rel="search" href="' 
$scripturl '?action=search" />
<link rel="contents" href="'
$scripturl'" />';

// If RSS feeds are enabled, advertise the presence of one.
if (!empty($modSettings['xmlnews_enable']))
echo '
<link rel="alternate" type="application/rss+xml" title="'
$context['forum_name'], ' - RSS" href="'$scripturl'?type=rss;action=.xml" />';

// If we're viewing a topic, these should be the previous and next topics, respectively.
if (!empty($context['current_topic']))
echo '
<link rel="prev" href="'
$scripturl'?topic='$context['current_topic'], '.0;prev_next=prev" />
<link rel="next" href="'
$scripturl'?topic='$context['current_topic'], '.0;prev_next=next" />';

// If we're in a board, or a topic for that matter, the index will be the board's index.
if (!empty($context['current_board']))
echo '
<link rel="index" href="' 
$scripturl '?board=' $context['current_board'] . '.0" />';

// We'll have to use the cookie to remember the header...
if ($context['user']['is_guest'])
$options['collapse_header'] = !empty($_COOKIE['upshrink']);

// Output any remaining HTML headers. (from mods, maybe?)
echo $context['html_headers'], '
<script language="JavaScript" type="text/javascript"><!-- // --><![CDATA[
var current_header_sb = '
, empty($options['collapse_header_sb']) ? 'false' 'true'';

function shrinkHeaderSB(mode)
{'
;

if ($context['user']['is_guest'])
echo '
document.cookie = "upshrinkSB=" + (mode ? 1 : 0);'
;
else
echo '
smf_setThemeOption("collapse_header_sb", mode ? 1 : 0, null, "'
$context['session_id'], '");';

echo '
document.getElementById("upshrink_sb").src = smf_images_url + (mode ? "/expand.gif" : "/collapse.gif");

document.getElementById("upshrinkHeaderSB").style.display = mode ? "none" : "";

current_header_sb = mode;
}
// ]]></script>


<script language="JavaScript" type="text/javascript"><!-- // --><![CDATA[
var current_header = '
, empty($options['collapse_header']) ? 'false' 'true'';

function shrinkHeader(mode)
{'
;

// Guests don't have theme options!!
if ($context['user']['is_guest'])
echo '
document.cookie = "upshrink=" + (mode ? 1 : 0);'
;
else
echo '
smf_setThemeOption("collapse_header", mode ? 1 : 0, null, "'
$context['session_id'], '");';

echo '
document.getElementById("upshrink").src = smf_images_url + (mode ? "/upshrink2.gif" : "/upshrink.gif");

document.getElementById("upshrinkHeader").style.display = mode ? "none" : "";
document.getElementById("upshrinkHeader2").style.display = mode ? "none" : "";

current_header = mode;
}
// ]]></script>'
;

// the routine for the info center upshrink
echo '
<script language="JavaScript" type="text/javascript"><!-- // --><![CDATA[
var current_header_ic = '
, empty($options['collapse_header_ic']) ? 'false' 'true'';

function shrinkHeaderIC(mode)
{'
;

if ($context['user']['is_guest'])
echo '
document.cookie = "upshrinkIC=" + (mode ? 1 : 0);'
;
else
echo '
smf_setThemeOption("collapse_header_ic", mode ? 1 : 0, null, "'
$context['session_id'], '");';

echo '
document.getElementById("upshrink_ic").src = smf_images_url + (mode ? "/expand.gif" : "/collapse.gif");

document.getElementById("upshrinkHeaderIC").style.display = mode ? "none" : "";

current_header_ic = mode;
}
// ]]></script>
</head>
<body>'
;

echo '
<div class="tborder" '
$context['browser']['needs_size_fix'] && !$context['browser']['is_ie6'] ? ' style="width: 100%;"' '''>
<table width="100%" cellpadding="0" cellspacing="0" border="0">
<tr>
<td align="center" class="catbg" height="32">'
;

if (empty($settings['header_logo_url']))
echo '
<span style="font-family: Verdana, sans-serif; font-size: 140%; ">'
$context['forum_name'], '</span>';
else
echo '
<img src="'
$settings['header_logo_url'], '" style="margin: 0px;" alt="'$context['forum_name'], '" />';

echo '
</td>

</td>
</tr>
</table>'
;

// display user name
echo '
<table width="100%" cellpadding="0" cellspacing="0" border="0" >
<tr>'
;

if($context['user']['is_logged'])
echo '
<td class="titlebg2" height="32">
<span style="font-size: 100%;"> '
$txt['hello_member_ndt'], ' <b>'$context['user']['name'] ,
 '</b></span>
 </td>'
;

// display the time
echo '
<td class="titlebg2" height="32" align="right">
<span class="smalltext">' 
,$context['current_time'], '</span>';

// this is the upshrink button for the user info section
echo '
<a href="#" onclick="shrinkHeader(!current_header); return false;"><img id="upshrink" src="'
$settings['images_url'], '/', empty($options['collapse_header']) ? 'upshrink.gif' 'upshrink2.gif''" alt="*" title="'$txt['upshrink_description'], '" align="bottom" style="margin: 0 1ex;" /></a>
</td>
</tr>
<tr id="upshrinkHeader"'
, empty($options['collapse_header']) ? '' ' style="display: none;"''>
<td valign="top" colspan="2">
<table width="100%" class="bordercolor" cellpadding="8" cellspacing="1" border="0" style="margin-top: 1px;">
<tr>'
;

if (!empty($context['user']['avatar']))
echo '
<td class="windowbg" valign="middle">'
$context['user']['avatar']['image'], '</td>';

echo '
<td colspan="2" width="100%" valign="top" class="windowbg2"><span class="middletext">'
;

// If the user is logged in, display stuff like their name, new messages, etc.
if ($context['user']['is_logged'])
{
echo ' <br><br><br><br>
<strong><a href="'
$scripturl'?action=unread">'$txt['unread_since_visit'], '</a></strong> |
<strong><a href="'
$scripturl'?action=unreadreplies">'$txt['show_unread_replies'], '</a></strong><br />';

}
// Otherwise they're a guest - send them a lovely greating...
else
echo $txt['welcome_guest'];

// Now, onto our second set of info, are they logged in again?
if ($context['user']['is_logged'])
{
// Is the forum in maintenance mode?
if ($context['in_maintenance'] && $context['user']['is_admin'])
echo '
<b>'
$txt[616], '</b><br />';
if (isset($context['user']['awaiting_mod']))
echo '<a href="'$scripturl'?action=warnpmman">'$context['user']['awaiting_mod'], '</a><br /> <br />';

// Are there any members waiting for approval?
if (!empty($context['unapproved_members']))
echo '
'
$context['unapproved_members'] == $txt['approve_thereis'] : $txt['approve_thereare'], ' <a href="'$scripturl'?action=viewmembers;sa=browse;type=approve">'$context['unapproved_members'] == $txt['approve_member'] : $context['unapproved_members'] . ' ' $txt['approve_members'], '</a> '$txt['approve_members_waiting'], '<br />';

echo ' </span>';
}
// Otherwise they're a guest - this time ask them to either register or login - lazy bums...
else
{
echo '
<script language="JavaScript" type="text/javascript" src="'
$settings['default_theme_url'], '/sha1.js"></script>

<form action="'
$scripturl'?action=login2" method="post" class="middletext" style="margin: 3px 1ex 1px 0;"', empty($context['disable_login_hashing']) ? ' onsubmit="hashLoginPassword(this, \'' $context['session_id'] . '\');"' '''>
<input type="text" name="user" size="10" /> <input type="password" name="passwrd" size="10" />
<select name="cookielength">
<option value="60">'
$txt['smf53'], '</option>
<option value="1440">'
$txt['smf47'], '</option>
<option value="10080">'
$txt['smf48'], '</option>
<option value="302400">'
$txt['smf49'], '</option>
<option value="-1" selected="selected">'
$txt['smf50'], '</option>
</select>
<input type="submit" value="'
$txt[34], '" /><br />
<span class="middletext">'
$txt['smf52'], '</span>
<input type="hidden" name="hash_passwrd" value="" />
</form>'
;
}

echo '
</td>
</tr>
</table>
</td>
</tr>
</table>'
;

echo '
<table id="upshrinkHeader2"'
, empty($options['collapse_header']) ? '' ' style="display: none;"'' width="100%" cellpadding="4" cellspacing="0" border="0">
<tr>'
;

// Show a random news item? (or you could pick one from news_lines...)
if (!empty($settings['enable_news']))
echo '
<td class="titlebg2" align="left" nowrap="nowrap" valign="top">
<span class="mediumtext"><b>'
$txt[102], '</b>: '$context['random_news_line'], '</span>
</td>'
;

echo '
<td class="titlebg2" align="right" nowrap="nowrap" valign="top">
<form action="'
$scripturl'?action=search2" method="post" style="margin: 0;">
<a href="'
$scripturl'?action=search;advanced"><img src="'.$settings['images_url'].'/filter.gif" align="middle" style="margin: 0 1ex;" alt="" /></a>
<input type="text" name="search" value="" style="width: 190px;" />&nbsp;
<input type="submit" name="submit" value="'
$txt[182], '" style="width: 11ex;" />
<input type="hidden" name="advanced" value="0" />'
;

// Search within current topic?
if (!empty($context['current_topic']))
echo '
<input type="hidden" name="topic" value="'
$context['current_topic'], '" />';

// If we're on a certain board, limit it to this board ;).
elseif (!empty($context['current_board']))
echo '
<input type="hidden" name="brd['
$context['current_board'], ']" value="'$context['current_board'], '" />';

echo '
</form>
</td>
</tr>
</table>
</div>'
;

// Show the menu here, according to the menu sub template.


//Ad management code to display ads on top of the menubar

if ($modSettings['ad_management_index_above'] && allowedTo('ad_manageperm'))
echo '<div align="',$modSettings['ad_management_align'],'">',$modSettings['ad_management_content'],'</div>';

template_menu();

//Ad management code to display ads on the bottom of the memubar

if ($modSettings['ad_management_index_below'] && allowedTo('ad_manageperm'))
echo '<div align="',$modSettings['ad_management_align'],'">',$modSettings['ad_management_content'],'</div>';






//If the user is below the minimum required posts, then show the annoying message.
global $user_info;

if (($context['user']['is_logged']) && ($user_info['posts'] < $modSettings['MinReqPostCount']))
echo '
<table align="center" style="width: 100%; padding: 20px; text-align: left; vertical-align: middle; margin: 2ex 1ex 2ex 1ex; border: 2px dashed '
$modSettings['PostCountWarningBorderColor'],'; background-color: '$modSettings['PostCountWarningBackgroundColor'],';">
<tr>
<td width="64">
<img style="vertical-align: middle;" src="'
.$settings['images_url'].'/pcWarn.gif" alt="Attention!" />
</td>
<td style="color: '
$modSettings['PostCountWarningTextColor'],';">
<strong>'
$modSettings['PostCountWarningMessageTitle'], '</strong><br />'$modSettings['PostCountWarningMessage'], '
</td>
</tr>
</table>
'
;


// The main content should go here.
echo '
<div id="bodyarea" style="padding: 1ex 0px 2ex 0px;">'
;
}

function 
template_main_below()
{
global $context$settings$options$scripturl$txt;

//Ad management code to display your ads

global $modSettings;

if (
$modSettings['ad_management_bot_index'] && allowedTo('ad_manageperm'))
echo '<div align="',$modSettings['ad_management_align'],'">',$modSettings['ad_management_content'],'</div>';

echo '
</div>'
;

// Show the "Powered by" and "Valid" logos, as well as the copyright. Remember, the copyright must be somewhere!
echo '

<div id="footerarea" style="text-align: center; padding-bottom: 1ex;'
$context['browser']['needs_size_fix'] && !$context['browser']['is_ie6'] ? ' width: 100%;' '''">
<script language="JavaScript" type="text/javascript"><!-- // --><![CDATA[
function smfFooterHighlight(element, value)
{
element.src = smf_images_url + "/" + (value ? "h_" : "") + element.id + ".gif";
}
// ]]></script>
<table cellspacing="0" cellpadding="3" border="0" align="center" width="100%">
<tr>
<td valign="middle" align="center" style="white-space: nowrap;">
'
theme_copyright(), '
</td>
</tr>
</table>'
;

// Show the load time?
if ($context['show_load_time'])
echo '
<span class="smalltext">'
$txt['smf301'], $context['load_time'], $txt['smf302'], $context['load_queries'], $txt['smf302b'], '</span>';

// This is an interesting bug in Internet Explorer AND Safari. Rather annoying, it makes overflows just not tall enough.
if (($context['browser']['is_ie'] && !$context['browser']['is_ie4']) || $context['browser']['is_mac_ie'] || $context['browser']['is_safari'])
{
// The purpose of this code is to fix the height of overflow: auto div blocks, because IE can't figure it out for itself.
echo '
<script language="JavaScript" type="text/javascript"><!-- // --><![CDATA['
;

// Unfortunately, Safari does not have a "getComputedStyle" implementation yet, so we have to just do it to code...
if ($context['browser']['is_safari'])
echo '
window.addEventListener("load", smf_codeFix, false);

function smf_codeFix()
{
var codeFix = document.getElementsByTagName ? document.getElementsByTagName("div") : document.all.tags("div");

for (var i = 0; i < codeFix.length; i++)
{
if ((codeFix[i].className == "code" || codeFix[i].className == "post" || codeFix[i].className == "signature") && codeFix[i].offsetHeight < 20)
codeFix[i].style.height = (codeFix[i].offsetHeight + 20) + "px";
}
}'
;
else
echo '
var window_oldOnload = window.onload;
window.onload = smf_codeFix;

function smf_codeFix()
{
var codeFix = document.getElementsByTagName ? document.getElementsByTagName("div") : document.all.tags("div");

for (var i = codeFix.length - 1; i > 0; i--)
{
if (codeFix[i].currentStyle.overflow == "auto" && (codeFix[i].currentStyle.height == "" || codeFix[i].currentStyle.height == "auto") && (codeFix[i].scrollWidth > codeFix[i].clientWidth || codeFix[i].clientWidth == 0) && (codeFix[i].offsetHeight != 0 || codeFix[i].className == "code"))
codeFix[i].style.height = (codeFix[i].offsetHeight + 36) + "px";
}

if (window_oldOnload)
{
window_oldOnload();
window_oldOnload = null;
}
}'
;

echo '
// ]]></script>'
;
}

echo '
</div>
</body></html>'
;
}

// Show a linktree. This is that thing that shows "My Community | General Category | General Discussion"..
function theme_linktree()
{
global $context$settings$options;

echo '<div class="nav" style="font-size: smaller; margin-bottom: 2ex; margin-top: 2ex;">';

// Each tree item has a URL and name. Some may have extra_before and extra_after.
foreach ($context['linktree'] as $link_num => $tree)
{
// Show something before the link?
if (isset($tree['extra_before']))
echo $tree['extra_before'];

// Show the link, including a URL if it should have one.
echo '<b>'$settings['linktree_link'] && isset($tree['url']) ? '<a href="' $tree['url'] . '" class="nav">' $tree['name'] . '</a>' $tree['name'], '</b>';

// Show something after the link...?
if (isset($tree['extra_after']))
echo $tree['extra_after'];

// Don't show a separator for the last one.
if ($link_num != count($context['linktree']) - 1)
echo '&nbsp;>&nbsp;';
}

echo '</div>';
}

// Show the menu up top. Something like [home] [help] [profile] [logout]...
function template_menu()
{
global $context$settings$options$scripturl$txt;

// Work out where we currently are.
$current_action 'home';
if (in_array($context['current_action'], array('admin''ban''boardrecount''cleanperms''detailedversion''dumpdb''featuresettings''featuresettings2''findmember''maintain''manageattachments''manageboards''managecalendar''managesearch''membergroups''modlog''news''optimizetables''packageget''packages''permissions''pgdownload''postsettings''regcenter''repairboards''reports''serversettings''serversettings2''smileys''viewErrorLog''viewmembers')))
$current_action 'admin';
if (in_array($context['current_action'], array('contact','staff','links','search''admin''calendar''profile''mlist''register''login''help''pm','arcade')))
$current_action $context['current_action'];
if ($context['current_action'] == 'search2')
$current_action 'search';
if ($context['current_action'] == 'theme')
$current_action = isset($_REQUEST['sa']) && $_REQUEST['sa'] == 'pick' 'profile' 'admin';

// Are we using right-to-left orientation?
if ($context['right_to_left'])
{
$first 'last';
$last 'first';
}
else
{
$first 'first';
$last 'last';
}

// Show the start of the tab section.
echo '
<table cellpadding="0" cellspacing="0" border="0" style="margin-left: 10px;">
<tr>
<td class="maintab_' 
$first '">&nbsp;</td>';

// Show the [home] button.
echo ($current_action=='home' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'home' 'active_back' 'back' '">
<a href="'
$scripturl'">' $txt[103] , '</a>
</td>' 
$current_action == 'home' '<td class="maintab_active_' $last '">&nbsp;</td>' '';

// Show the [help] button.
echo ($current_action == 'help' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'help' 'active_back' 'back' '">
<a href="'
$scripturl'?action=help">' $txt[119] , '</a>
</td>' 
$current_action == 'help' '<td class="maintab_active_' $last '">&nbsp;</td>' '';

// How about the [search] button?
if ($context['allow_search'])
echo ($current_action == 'search' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'search' 'active_back' 'back' '">
<a href="'
$scripturl'?action=search">' $txt[182] , '</a>
</td>' 
$current_action == 'search' '<td class="maintab_active_' $last '">&nbsp;</td>' '';

// Is the user allowed to administrate at all? ([admin])
if ($context['allow_admin'])
echo ($current_action == 'admin' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'admin' 'active_back' 'back' '">
<a href="'
$scripturl'?action=admin">' $txt[2] , '</a>
</td>' 
$current_action == 'admin' '<td class="maintab_active_' $last '">&nbsp;</td>' '';

// Edit Profile... [profile]
if ($context['allow_edit_profile'])
echo ($current_action == 'profile' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'profile' 'active_back' 'back' '">
<a href="'
$scripturl'?action=profile">' $txt[79] , '</a>
</td>' 
$current_action == 'profile' '<td class="maintab_active_' $last '">&nbsp;</td>' '';

// The [member map]
echo ($current_action == 'mm' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'mm' 'active_back' 'back' '">
<a href="'
$scripturl'?action=mm">' $txt['mm_mm'] , '</a>
</td>' 
$current_action == 'mm' '<td class="maintab_active_' $last '">&nbsp;</td>' '';

// Go to PM center... [pm]
if ($context['user']['is_logged'] && $context['allow_pm'])
echo ($current_action == 'pm' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'pm' 'active_back' 'back' '">
<a href="'
$scripturl'?action=pm">' $txt['pm_short'] , ' '$context['user']['unread_messages'] > '[<strong>'$context['user']['unread_messages'] . '</strong>]&nbsp;&nbsp;<img src="' $settings['images_url'] . '/msg.gif" border="0" />' '' '</a>


</td>' 
$current_action == 'pm' '<td class="maintab_active_' $last '">&nbsp;</td>' '';

// The [calendar]!
if ($context['allow_calendar'])
echo ($current_action == 'calendar' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'calendar' 'active_back' 'back' '">
<a href="'
$scripturl'?action=calendar">' $txt['calendar24'] , '</a>
</td>' 
$current_action == 'calendar' '<td class="maintab_active_' $last '">&nbsp;</td>' '';
        
// The [arcade]!
        
if ($context['allow_arcade'])
                echo (
$current_action == 'arcade' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
                                <td valign="top" class="maintab_' 
$current_action == 'arcade' 'active_back' 'back' '">
                                        <a href="'
$scripturl'?action=arcade">' $txt['permissiongroup_arcade'] , '</a>
                                </td>' 
$current_action == 'arcade' '<td class="maintab_active_' $last '">&nbsp;</td>' '';


// the [member] list button
if ($context['allow_memberlist'])
echo ($current_action == 'mlist' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'mlist' 'active_back' 'back' '">
<a href="'
$scripturl'?action=mlist">' $txt[331] , '</a>
</td>' 
$current_action == 'mlist' '<td class="maintab_active_' $last '">&nbsp;</td>' '';

// the [contact] button
if ($context['allow_view_contact'])
echo ($current_action == 'contact' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'contact' 'active_back' 'back' '">
<a href="'
$scripturl'?action=contact">' $txt['smfcontact_contact']  , '</a>
</td>' 
$current_action == 'contact' '<td class="maintab_active_' $last '">&nbsp;</td>' '';


// the [staff list] button
if ($context['allow_view_stafflist'])
echo ($current_action == 'staff' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'staff' 'active_back' 'back' '">
<a href="'
$scripturl'?action=staff">' $txt['smfstaff_stafflist']  , '</a>
</td>' 
$current_action == 'staff' '<td class="maintab_active_' $last '">&nbsp;</td>' '';


// the [links] button
if ($context['allow_view_smflinks'])
echo ($current_action == 'links' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'links' 'active_back' 'back' '">
<a href="'
$scripturl'?action=links">' $txt['smflinks_menu']  , '</a>
</td>' 
$current_action == 'links' '<td class="maintab_active_' $last '">&nbsp;</td>' '';



// If the user is a guest, show [login] button.
if ($context['user']['is_guest'])
echo ($current_action == 'login' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'login' 'active_back' 'back' '">
<a href="'
$scripturl'?action=login">' $txt[34] , '</a>
</td>' 
$current_action == 'login' '<td class="maintab_active_' $last '">&nbsp;</td>' '';


// If the user is a guest, also show [register] button.
if ($context['user']['is_guest'])
echo ($current_action == 'register' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'register' 'active_back' 'back' '">
<a href="'
$scripturl'?action=register">' $txt[97] , '</a>
</td>' 
$current_action == 'register' '<td class="maintab_active_' $last '">&nbsp;</td>' '';


// Otherwise, they might want to [logout]...
if ($context['user']['is_logged'])
echo ($current_action == 'logout' || $context['browser']['is_ie4']) ? '<td class="maintab_active_' $first '">&nbsp;</td>' '' '
<td valign="top" class="maintab_' 
$current_action == 'logout' 'active_back' 'back' '">
<a href="'
$scripturl'?action=logout;sesc='$context['session_id'], '">' $txt[108] , '</a>
</td>' 
$current_action == 'logout' '<td class="maintab_active_' $last '">&nbsp;</td>' '';

// The end of tab section.
echo '
<td class="maintab_' 
$last '">&nbsp;</td>
</tr>
</table>'
;

}

// Generate a strip of buttons.
function template_button_strip($button_strip$direction 'top'$force_reset false$custom_td '')
{
global $settings$buttons$context$txt$scripturl;

// Create the buttons...
foreach ($button_strip as $key => $value)
{
if (isset($value['test']) && empty($context[$value['test']]))
{
unset($button_strip[$key]);
continue;
}
elseif (!isset($buttons[$key]) || $force_reset)
$buttons[$key] = '<a href="' $value['url'] . '" ' .( isset($value['custom']) ? $value['custom'] : '') . '>' $txt[$value['text']] . '</a>';

$button_strip[$key] = $buttons[$key];
}

if (empty($button_strip))
return '<td>&nbsp;</td>';

echo '
<td class="'
$direction == 'top' 'main' 'mirror''tab_' $context['right_to_left'] ? 'last' 'first' '">&nbsp;</td>
<td class="'
$direction == 'top' 'main' 'mirror''tab_back">'implode(' &nbsp;|&nbsp; '$button_strip) , '</td>
<td class="'
$direction == 'top' 'main' 'mirror''tab_' $context['right_to_left'] ? 'first' 'last' '">&nbsp;</td>';
}
if(
$context['user']['is_logged'])
      echo 
'
      <form action="'
$scripturl'" style="margin: 0px; margin-top: 10px;" method="post" class="smalltext"><select name="options[theme_color]" onchange="this.form.submit();">
        <option selected="selected" value="'
$options['theme_color'], '">Use default</option>
        <option value="red">Red</option>
        <option value="blue">Blue</option>
        <option value="green">Green</option>
        </select><br /><input alt="submit" type="submit" value="Change" /></form>'
;
?>



here is the copy of the index.templete.php file .

thanks for helping me bloc !

bloc

This code bit...   include_once($GLOBALS['sourcedir'] . '/Profile.php');
   makeThemeChanges($context['user']['id'], $settings['theme_id']);
   $options['theme_color'] = $_POST['options']['theme_color'];


need to have a bracket at the end, like this:   include_once($GLOBALS['sourcedir'] . '/Profile.php');
   makeThemeChanges($context['user']['id'], $settings['theme_id']);
   $options['theme_color'] = $_POST['options']['theme_color'];
}

Red-Omni

ok that fixed the problem .. thanks a TON , bloc !!!

also can you help me , can you tell me how to add additional styles to the option ?

farhaddad

Quote from: Bloc on August 05, 2006, 03:52:24 PM
I almost forgot this one. :)

The way you can do this - Sitra theme used a variation of it I think - is the following:

- open Settings.template and find:
function template_settings()
{
global $context, $settings, $options, $scripturl, $txt;

        $context['theme_settings'] = array(


- add under that this:
                array(
                        'id' => 'default_theme_color',
                        'label' => 'This is the default color if member haven\'t chosen anything',
                        'options' => array(
                                'blue' => 'Blue',
                                'red' => 'Red',
                                'green' => 'Green',
                        ),
                ),


Add more colors to this part

                array(
                        'id' => 'default_theme_color',
                        'label' => 'This is the default color if member haven\'t chosen anything',
                        'options' => array(
                                'blue' => 'Blue',
                                'red' => 'Red',
                                'green' => 'Green',
                                'purple' => 'Purple',
                                'gold' => 'Gold',
                                'black' => 'Black',
                        ),
                ),


Quote from: Bloc on August 05, 2006, 03:52:24 PM

Remember to name all you stylesheets on the form xxxx_style.css where xxx is color or name you choose.

Next up is finally to add the actual chooser code. it can be anywhere you like and it looks like this:
    if($context['user']['is_logged'])
      echo '
      <form action="', $scripturl, '" style="margin: 0px; margin-top: 10px;" method="post" class="smalltext"><select name="options[theme_color]" onchange="this.form.submit();">
        <option selected="selected" value="', $options['theme_color'], '">Use default</option>
        <option value="red">Red</option>
        <option value="blue">Blue</option>
        <option value="green">Green</option>
        </select><br /><input alt="submit" type="submit" value="Change" /></form>';



Add more options to the drop down menu

    if($context['user']['is_logged'])
      echo '
      <form action="', $scripturl, '" style="margin: 0px; margin-top: 10px;" method="post" class="smalltext"><select name="options[theme_color]" onchange="this.form.submit();">
        <option selected="selected" value="', $options['theme_color'], '">Use default</option>
        <option value="red">Red</option>
        <option value="blue">Blue</option>
        <option value="green">Green</option>
        <option value="purple">Purple</option>
        <option value="gold">Gold</option>
        <option value="black">Black</option>
        </select><br /><input alt="submit" type="submit" value="Change" /></form>';





Gary

#25
^ I did sorta know that, but still it is a good tip.

Maybe this is something for the tips & tricks board.

-AwwLilMaggie
Gary M. Gadsdon
Do NOT PM me unless I say so
War of the Simpsons
Bongo Comics Fan Forum
Youtube Let's Plays

^ YT is changing monetisation policy, help reach 1000 sub threshold.

farhaddad

QuoteWarning: this topic has not been posted in for at least 120 days.
Unless you're sure you want to reply, please consider starting a new topic.

Sorry for this but I think it's better to post my question here

well this mod defines a default style for guests I'm trying to add an action to this, like I want it to have the default style in certain actions let's say "calendar"

I tried adding it to


if(!$context['user']['is_guest'] && isset($_POST['options']['theme_width']))
{
   include_once($GLOBALS['sourcedir'] . '/Profile.php');
   makeThemeChanges($context['user']['id'], $settings['theme_id']);
   $options['theme_width'] = $_POST['options']['theme_width'];
}


but it didn't work

merging these i guess !

if ($context['current_action'] == 'calendar')

if(!$context['user']['is_guest'] && isset($_POST['options']['theme_width']))

Thank you


bloc

To have a certain style in just some actions you need to check the $_GET['action'] + if theya re a guest and use that IF to either import another styesheet, or set a inline style in index.template.php.

Is the guest style a whole stylesheet or just a few defined classes/ids?

farhaddad

#28
hi thanks for the quick reply  :)

it's a whole stylesheet

edit: I'm using a whole stylesheet but the only thing i change in it, is the main width (fixed & extended) because I didn't know how to do it in a different way

so I'm just using your code for the color styles red, black etc... but i changed the name to theme_width all is working but i need to define the default stylesheet to the calendar action

bloc

k. You might then be better off just including that width inside index.template.php instead and removing it from style.css. Something like..

if(isset($_GET['action']) && $_GET['action']=='calendar' && $context['user']['is_guest'])
{
  echo '<style type="text/css"><!--
your style
{
width: 800px;
}
--></style>';
}
else
{
  echo '<style type="text/css"><!--
your style
{
width: 100%;
}
--></style>';
}


Put it after the call to style.css in index.template.php: then you don't need to remove it even, it will override style.css.

farhaddad

this didn't work don't know why

but here what i did

if(isset($_GET['action']) && $_GET['action']=='calendar')
{
   include_once($GLOBALS['sourcedir'] . '/Profile.php');
   makeThemeChanges($context['user']['id'], $settings['theme_id']);
   $options['theme_width'] = $_POST['options']['theme_width'];
}
if(!$context['user']['is_guest'] && isset($_POST['options']['theme_width']))
{
   include_once($GLOBALS['sourcedir'] . '/Profile.php');
   makeThemeChanges($context['user']['id'], $settings['theme_id']);
   $options['theme_width'] = $_POST['options']['theme_width'];
}


i repeated this code with the action thing and it worked

is there any way i can mix them ?

if(!$context['user']['is_guest'] && isset($_POST['options']['theme_width']))

and

if(isset($_GET['action']) && $_GET['action']=='calendar')

bloc

I think you will run into trouble here...the width option can't be saved for just calendar, and  something else for other parts of the forum.

I am a bit confused as to what you want to achieve though. Without looking at code - what exactly is your goal?

farhaddad

#32
sorry, here's what I have

added to Settings.template


                array(
                        'id' => 'default_theme_width',
                        'label' => 'This is the default width if member haven\'t chosen anything',
                        'options' => array(
                                'fixed' => 'Fixed',
                                'extended' => 'Extended',
                        ),
                ),


added to index.template.php


if(!$context['user']['is_guest'] && isset($_POST['options']['theme_width']))
{
   include_once($GLOBALS['sourcedir'] . '/Profile.php');
   makeThemeChanges($context['user']['id'], $settings['theme_id']);
   $options['theme_width'] = $_POST['options']['theme_width'];
}


and


if (isset($options['theme_width']))
   $mywidth = $options['theme_width'];
else{
   // Defaults.
   $options['theme_width'] = isset($settings['default_theme_width']) ? $settings['default_theme_width'] : 'fixed';
   $mywidth=$options['theme_width'];
}


replaced


<link rel="stylesheet" type="text/css" href="', $settings['theme_url'], '/'.$mywidth.'_style.css" />


added


<form action="', $scripturl, '?'.$_SERVER['QUERY_STRING'].'" class="button" method="post">';

if($mywidth == 'fixed')
  echo '
<input type="image" src="images/extended.gif" value="extended" title="extended" class="button" name="options[theme_width]" /></form>';
else
  echo '
<input type="image" src="images/fixed.gif" value="fixed" title="fixed" class="button" name="options[theme_width]" /></form>';


and I have 2 stylesheets fixed_style.css and extended_style.css and the only difference between them is the width class.

now what I want is to exclude calendar and make it always fixed no matter what the member's settings are

so I added this


if(isset($_GET['action']) && $_GET['action']=='calendar')
{
   include_once($GLOBALS['sourcedir'] . '/Profile.php');
   makeThemeChanges($context['user']['id'], $settings['theme_id']);
   $options['theme_width'] = $_POST['options']['theme_width'];
}


okay got you, silly me :P

// The ?fin11 part of this link is just here to make sure browsers don't cache it wrongly.

if(isset($_GET['action']) && $_GET['action']=='calendar')
echo '
<link rel="stylesheet" type="text/css" href="', $settings['theme_url'], '/fixed_style.css?fin11" />';
else
echo '
<link rel="stylesheet" type="text/css" href="', $settings['theme_url'], '/'.$mywidth.'_style.css?fin11" />';
echo '
<link rel="stylesheet" type="text/css" href="', $settings['default_theme_url'], '/print.css?fin11" media="print" />';


is this okay?

farhaddad

Quote from: Bloc on August 12, 2006, 07:34:42 PM
Its possible without javascript. Simply render one button, but check first the color, then change the button accordingly. Like:

if($mycolor == 'brown')
  echo ' <input type="submit" value="blue" name="options[theme_color]">';
else
  echo ' <input type="submit" value="brown" name="options[theme_color]">';


Hi I'm using this for a while now and just today noticed that

if($mycolor == 'brown')

doesn't work on IE, it's okay on firefox ... any idea?

bloc

The php won't be different..but the html might need some changes. I had trouble with IE..but don't recall exactly wat that was lol. :) How does your <form> code look like?

Deaks

weird I just made RGB Multi using this and I tested it with IE7 as well as FF and it worked fine
~~~~
Former SMF Project Manager
Former SMF Customizer

"For as lang as hunner o us is in life, in nae wey
will we thole the Soothron tae owergang us. In truth it isna for glory, or wealth, or
honours that we fecht, but for freedom alane, that nae honest cheil gies up but wi life
itsel."

farhaddad

Quote from: Bloc on February 08, 2007, 07:52:56 AM
The php won't be different..but the html might need some changes. I had trouble with IE..but don't recall exactly wat that was lol. :) How does your <form> code look like?

thank you :-)

here's my code


if ($context['current_action'] == 'calendar')
    echo '
                <td><a href="index.php" onmouseout="MM_swapImgRestore()" onmouseover="MM_swapImage(\'forum\',\'\',\'images/forum_2.gif\',1)"><img src="images/forum_1.gif" alt="Forum"  name="forum" width="84" height="27" border="0" id="forum" title="Forum: Fans\' Community" /></a></td>
                <td width="46" align="right"><img src="images/menu_r.gif" width="46" height="27" alt="" /></td>';
else
{
    echo '
                <td align="center"><a href="index.php"><img src="images/forum_3.gif" alt="Forum" title="Forum: Fans\' Community"  name="forum" width="84" height="27" border="0" id="forum" /></a></td>
                <td width="46" align="right">';
if($context['user']['is_logged']){
echo '
<form action="', $scripturl,  !empty($_SERVER['QUERY_STRING']) ? '?'.$_SERVER['QUERY_STRING'] : '' ,'" class="button" method="post">';
if($mywidth == '740px')
  echo ' <input type="image" src="images/extended.gif" value="95%" title="extended" class="button" name="options[theme_width]" /></form></td>';
else
  echo ' <input type="image" src="images/fixed.gif" value="740px" title="fixed" class="button" name="options[theme_width]" /></form></td>';
  }
  else {
echo ' <img src="images/menu_r.gif" width="46" height="27" alt="" /></td>';
}}

farhaddad

any idea ? yeah bump sorry for that but I couldn't fix it!

bloc

Actually...I did not use input buttons by the type "image" because they return a x,y value for the click inside the actual image - not the "value" set in them. And its different in various browsers too.

I simply used "submit" buttons and styled them with different backgroun+colors to look like images.

IchBin™

If you look at a theme that is already in the theme site here, you can see how themes are packaged.
IchBin™        TinyPortal

Advertisement: