News:

SMF 2.1.4 has been released! Take it for a spin! Read more.

Main Menu

Header customization

Started by Texan78, January 16, 2012, 04:42:34 PM

Previous topic - Next topic

Texan78

Forgive me if this is in the wrong area. Just have a small tweek I want to make but the code is a little more complex then what I am use to and can't find where to move this. I found how to move the news, but it isn't centered how I like. What I am wanting to do is move the news to the left above the nav centered between it and the forum/user info. The move the search straight down on the right side so it is even with the nav. Is this possible and could someone point me in the right direction?

Here is a example of what I would like to do.



-Thanks

Matthew K.

Hey there!

As this isn't directly related to SMF 2.x Support, it's best to be in SMF Coding Discussion, so I moved it accordingly.

Can you please attach your themes index.template.php? People can't help you if the file isn't here...

Texan78

Quote from: Labradoodle-360 on January 16, 2012, 04:44:17 PM
Can you please attach your themes index.template.php? People can't help you if the file isn't here...

Yes sure, I wasn't sure which files needed to be edited. I went through it but didn't know for sure since I didn't see the nav. Still finding my way around.

<?php/** * Simple Machines Forum (SMF) * * @package SMF * @author Simple Machines * @copyright 2011 Simple Machines * @license http://www.simplemachines.org/about/smf/license.php BSD * * @version 2.0 *//* 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; /* 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'] = '2.0'; /* Set a setting that tells the theme that it can render the tabs. */ $settings['use_tabs'] = true; /* Use plain buttons - as opposed to text buttons? */ $settings['use_buttons'] = true; /* Show sticky and lock status separate from topic icons? */ $settings['separate_sticky_lock'] = true; /* Does this theme use the strict doctype? */ $settings['strict_doctype'] = false; /* Does this theme use post previews on the message index? */ $settings['message_index_preview'] = false; /* Set the following variable to true if this theme requires the optional theme strings file to be loaded. */ $settings['require_theme_strings'] = false;}// The main sub template above the content.function template_html_above(){ global $context, $settings, $options, $scripturl, $txt, $modSettings; // 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>'; // The ?fin20 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'], '/css/index', $context['theme_variant'], '.css?fin20" />'; // Some browsers need an extra stylesheet due to bugs/compatibility issues. foreach (array('ie7', 'ie6', 'webkit') as $cssfix) if ($context['browser']['is_' . $cssfix]) echo ' <link rel="stylesheet" type="text/css" href="', $settings['default_theme_url'], '/css/', $cssfix, '.css" />'; // RTL languages require an additional stylesheet. if ($context['right_to_left']) echo ' <link rel="stylesheet" type="text/css" href="', $settings['theme_url'], '/css/rtl.css" />'; // Here comes the JavaScript bits! echo ' <script type="text/javascript" src="', $settings['default_theme_url'], '/scripts/script.js?fin20"></script> <script type="text/javascript" src="', $settings['theme_url'], '/scripts/theme.js?fin20"></script> <script type="text/javascript"><!-- // --><![CDATA[ var smf_theme_url = "', $settings['theme_url'], '"; var smf_default_theme_url = "', $settings['default_theme_url'], '"; var smf_images_url = "', $settings['images_url'], '"; var smf_scripturl = "', $scripturl, '"; var smf_iso_case_folding = ', $context['server']['iso_case_folding'] ? 'true' : 'false', '; var smf_charset = "', $context['character_set'], '";', $context['show_pm_popup'] ? ' var fPmPopup = function () { if (confirm("' . $txt['show_personal_messages'] . '")) window.open(smf_prepareScriptUrl(smf_scripturl) + "action=pm"); } addLoadEvent(fPmPopup);' : '', ' var ajax_notification_text = "', $txt['ajax_in_progress'], '"; var ajax_notification_cancel_text = "', $txt['modify_cancel'], '"; // ]]></script>'; echo ' <meta http-equiv="Content-Type" content="text/html; charset=', $context['character_set'], '" /> <meta name="description" content="', $context['page_title_html_safe'], '" />', !empty($context['meta_keywords']) ? ' <meta name="keywords" content="' . $context['meta_keywords'] . '" />' : '', ' <title>', $context['page_title_html_safe'], '</title>'; // Please don't index these Mr Robot. if (!empty($context['robot_no_index'])) echo ' <meta name="robots" content="noindex" />'; // Present a canonical url for search engines to prevent duplicate content in their indices. if (!empty($context['canonical_url'])) echo ' <link rel="canonical" href="', $context['canonical_url'], '" />'; // Show all the relative links, such as help, search, contents, and the like. echo ' <link rel="help" href="', $scripturl, '?action=help" /> <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']) && (!empty($modSettings['allow_guestAccess']) || $context['user']['is_logged'])) echo ' <link rel="alternate" type="application/rss+xml" title="', $context['forum_name_html_safe'], ' - ', $txt['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" />'; // Output any remaining HTML headers. (from mods, maybe?) echo $context['html_headers']; echo '</head><body>';}function template_body_above(){ global $context, $settings, $options, $scripturl, $txt, $modSettings; echo !empty($settings['forum_width']) ? '<div id="wrapper" style="width: ' . $settings['forum_width'] . '">' : '', ' <div id="header"><div class="frame"> <div id="top_section"> <h1 class="forumtitle"> <a href="', $scripturl, '">', empty($context['header_logo_url_html_safe']) ? $context['forum_name'] : '<img src="' . $context['header_logo_url_html_safe'] . '" alt="' . $context['forum_name'] . '" />', '</a> </h1>'; // the upshrink image, right-floated echo ' <img id="upshrink" src="', $settings['images_url'], '/upshrink.png" alt="*" title="', $txt['upshrink_description'], '" style="display: none;" />'; echo ' ', empty($settings['site_slogan']) ? '<img id="smflogo" src="' . $settings['images_url'] . ' " alt=" " title=" " />' : '<div id="siteslogan" class="floatright">' . $settings['site_slogan'] . '</div>', ' </div> <div id="upper_section" class="middletext"', empty($options['collapse_header']) ? '' : ' style="display: none;"', '> <div class="user">'; // If the user is logged in, display stuff like their name, new messages, etc. if ($context['user']['is_logged']) { if (!empty($context['user']['avatar'])) echo ' <p class="avatar">', $context['user']['avatar']['image'], '</p>'; echo ' <ul class="reset"> <li class="greeting">', $txt['hello_member_ndt'], ' <span>', $context['user']['name'], '</span></li> <li><a href="', $scripturl, '?action=unread">', $txt['unread_since_visit'], '</a></li> <li><a href="', $scripturl, '?action=unreadreplies">', $txt['show_unread_replies'], '</a></li>'; // Is the forum in maintenance mode? if ($context['in_maintenance'] && $context['user']['is_admin']) echo ' <li class="notice">', $txt['maintain_mode_on'], '</li>'; // Are there any members waiting for approval? if (!empty($context['unapproved_members'])) echo ' <li>', $context['unapproved_members'] == 1 ? $txt['approve_thereis'] : $txt['approve_thereare'], ' <a href="', $scripturl, '?action=admin;area=viewmembers;sa=browse;type=approve">', $context['unapproved_members'] == 1 ? $txt['approve_member'] : $context['unapproved_members'] . ' ' . $txt['approve_members'], '</a> ', $txt['approve_members_waiting'], '</li>'; if (!empty($context['open_mod_reports']) && $context['show_open_reports']) echo ' <li><a href="', $scripturl, '?action=moderate;area=reports">', sprintf($txt['mod_reports_waiting'], $context['open_mod_reports']), '</a></li>'; echo ' <li>', $context['current_time'], '</li> </ul>'; } // Otherwise they're a guest - this time ask them to either register or login - lazy bums... elseif (!empty($context['show_login_bar'])) { echo ' <script type="text/javascript" src="', $settings['default_theme_url'], '/scripts/sha1.js"></script> <form id="guest_form" action="', $scripturl, '?action=login2" method="post" accept-charset="', $context['character_set'], '" ', empty($context['disable_login_hashing']) ? ' onsubmit="hashLoginPassword(this, \'' . $context['session_id'] . '\');"' : '', '> <div class="info">', sprintf($txt['welcome_guest'], $txt['guest_title']), '</div> <input type="text" name="user" size="10" class="input_text" /> <input type="password" name="passwrd" size="10" class="input_password" /> <select name="cookielength"> <option value="60">', $txt['one_hour'], '</option> <option value="1440">', $txt['one_day'], '</option> <option value="10080">', $txt['one_week'], '</option> <option value="43200">', $txt['one_month'], '</option> <option value="-1" selected="selected">', $txt['forever'], '</option> </select> <input type="submit" value="', $txt['login'], '" class="button_submit" /><br /> <div class="info">', $txt['quick_login_dec'], '</div>'; if (!empty($modSettings['enableOpenID'])) echo ' <br /><input type="text" name="openid_identifier" id="openid_url" size="25" class="input_text openid_login" />'; echo ' <input type="hidden" name="hash_passwrd" value="" /> </form>'; } echo ' </div> <div class="news normaltext"> <form id="search_form" action="', $scripturl, '?action=search2" method="post" accept-charset="', $context['character_set'], '">                                        <a href="http://www.weather-connection.com/index.php?action=search;advanced" title="Advanced search"><img id="advsearch" src="http://www.weather-connection.com/Themes/default/images/filter.gif" alt="Advanced search" align="middle"></a> <input type="text" name="search" value="" class="input_text" />&nbsp; <input type="submit" name="submit" value="', $txt['search'], '" class="button_submit" /> <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>'; // Show a random news item? (or you could pick one from news_lines...) if (!empty($settings['enable_news'])) echo ' <h2>', $txt['news'], ': </h2> <p>', $context['random_news_line'], '</p>'; echo ' </div> </div> <br class="clear" />'; // Define the upper_section toggle in JavaScript. echo ' <script type="text/javascript"><!-- // --><![CDATA[ var oMainHeaderToggle = new smc_Toggle({ bToggleEnabled: true, bCurrentlyCollapsed: ', empty($options['collapse_header']) ? 'false' : 'true', ', aSwappableContainers: [ \'upper_section\' ], aSwapImages: [ { sId: \'upshrink\', srcExpanded: smf_images_url + \'/upshrink.png\', altExpanded: ', JavaScriptEscape($txt['upshrink_description']), ', srcCollapsed: smf_images_url + \'/upshrink2.png\', altCollapsed: ', JavaScriptEscape($txt['upshrink_description']), ' } ], oThemeOptions: { bUseThemeSettings: ', $context['user']['is_guest'] ? 'false' : 'true', ', sOptionName: \'collapse_header\', sSessionVar: ', JavaScriptEscape($context['session_var']), ', sSessionId: ', JavaScriptEscape($context['session_id']), ' }, oCookieOptions: { bUseCookie: ', $context['user']['is_guest'] ? 'true' : 'false', ', sCookieName: \'upshrink\' } }); // ]]></script>'; // Show the menu here, according to the menu sub template. template_menu(); echo ' <br class="clear" /> </div></div>'; // The main content should go here. echo ' <div id="content_section"><div class="frame"> <div id="main_content_section">'; // Custom banners and shoutboxes should be placed here, before the linktree. // Show the navigation tree. theme_linktree();}function template_body_below(){ global $context, $settings, $options, $scripturl, $txt, $modSettings; echo '                <div class="AdSense"><script type="text/javascript"><!--google_ad_client = "ca-pub-8048181801684156";/* WC Footer1 */google_ad_slot = "4736642609";google_ad_width = 728;google_ad_height = 15;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script></div> </div> </div></div>'; // Show the "Powered by" and "Valid" logos, as well as the copyright. Remember, the copyright must be somewhere! echo ' <div id="footer_section"><div class="frame"> <ul class="reset"> <li class="copyright">', theme_copyright(), '</li> '; if (!empty($modSettings['seo_enable_sitemap'])) echo' <li><a href="', $scripturl, '?action=sitemap" title="', $txt['seo_sitemap'], '"><span>', $txt['seo_sitemap'], '</span></a></li>'; echo' <li><a id="button_xhtml" href="http://validator.w3.org/check?uri=referer" target="_blank" class="new_win" title="', $txt['valid_xhtml'], '"><span>', $txt['xhtml'], '</span></a></li> ', !empty($modSettings['xmlnews_enable']) && (!empty($modSettings['allow_guestAccess']) || $context['user']['is_logged']) ? '<li><a id="button_rss" href="' . $scripturl . '?action=.xml;type=rss" class="new_win"><span>' . $txt['rss'] . '</span></a></li>' : '', ' <li class="last"><a id="button_wap2" href="', $scripturl , '?wap2" class="new_win"><span>', $txt['wap2'], '</span></a></li> </ul>'; // Show the load time? if ($context['show_load_time']) echo ' <p>', $txt['page_created'], $context['load_time'], $txt['seconds_with'], $context['load_queries'], $txt['queries'], '</p>'; echo ' </div></div>', !empty($settings['forum_width']) ? '</div>' : '';}function template_html_below(){ global $context, $settings, $options, $scripturl, $txt, $modSettings; echo '</body></html>';}// Show a linktree. This is that thing that shows "My Community | General Category | General Discussion"..function theme_linktree($force_show = false){ global $context, $settings, $options, $shown_linktree; // If linktree is empty, just return - also allow an override. if (empty($context['linktree']) || (!empty($context['dont_default_linktree']) && !$force_show)) return; echo ' <div class="navigate_section"> <ul>'; // Each tree item has a URL and name. Some may have extra_before and extra_after. foreach ($context['linktree'] as $link_num => $tree) { echo ' <li', ($link_num == count($context['linktree']) - 1) ? ' class="last"' : '', '>'; // 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 $settings['linktree_link'] && isset($tree['url']) ? ' <a href="' . $tree['url'] . '"><span>' . $tree['name'] . '</span></a>' : '<span>' . $tree['name'] . '</span>'; // 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 ' &#38;#187;'; echo ' </li>'; } echo ' </ul> </div>'; $shown_linktree = true;}// Show the menu up top. Something like [home] [help] [profile] [logout]...function template_menu(){ global $context, $settings, $options, $scripturl, $txt; echo ' <div id="main_menu"> <ul class="dropmenu" id="menu_nav">'; foreach ($context['menu_buttons'] as $act => $button) { echo ' <li id="button_', $act, '"> <a class="', $button['active_button'] ? 'active ' : '', 'firstlevel" href="', $button['href'], '"', isset($button['target']) ? ' target="' . $button['target'] . '"' : '', '> <span class="', isset($button['is_last']) ? 'last ' : '', 'firstlevel">', $button['title'], '</span> </a>'; if (!empty($button['sub_buttons'])) { echo ' <ul>'; foreach ($button['sub_buttons'] as $childbutton) { echo ' <li> <a href="', $childbutton['href'], '"', isset($childbutton['target']) ? ' target="' . $childbutton['target'] . '"' : '', '> <span', isset($childbutton['is_last']) ? ' class="last"' : '', '>', $childbutton['title'], !empty($childbutton['sub_buttons']) ? '...' : '', '</span> </a>'; // 3rd level menus :) if (!empty($childbutton['sub_buttons'])) { echo ' <ul>'; foreach ($childbutton['sub_buttons'] as $grandchildbutton) echo ' <li> <a href="', $grandchildbutton['href'], '"', isset($grandchildbutton['target']) ? ' target="' . $grandchildbutton['target'] . '"' : '', '> <span', isset($grandchildbutton['is_last']) ? ' class="last"' : '', '>', $grandchildbutton['title'], '</span> </a> </li>'; echo ' </ul>'; } echo ' </li>'; } echo ' </ul>'; } echo ' </li>'; } echo ' </ul> </div>';}// Generate a strip of buttons.function template_button_strip($button_strip, $direction = 'top', $strip_options = array()){ global $settings, $context, $txt, $scripturl; if (!is_array($strip_options)) $strip_options = array(); // List the buttons in reverse order for RTL languages. if ($context['right_to_left']) $button_strip = array_reverse($button_strip, true); // Create the buttons... $buttons = array(); foreach ($button_strip as $key => $value) { if (!isset($value['test']) || !empty($context[$value['test']])) $buttons[] = ' <li><a' . (isset($value['id']) ? ' id="button_strip_' . $value['id'] . '"' : '') . ' class="button_strip_' . $key . (isset($value['active']) ? ' active' : '') . '" href="' . $value['url'] . '"' . (isset($value['custom']) ? ' ' . $value['custom'] : '') . '><span>' . $txt[$value['text']] . '</span></a></li>'; } // No buttons? No button strip either. if (empty($buttons)) return; // Make the last one, as easy as possible. $buttons[count($buttons) - 1] = str_replace('<span>', '<span class="last">', $buttons[count($buttons) - 1]); echo ' <div class="buttonlist', !empty($direction) ? ' float' . $direction : '', '"', (empty($buttons) ? ' style="display: none;"' : ''), (!empty($strip_options['id']) ? ' id="' . $strip_options['id'] . '"': ''), '> <ul>', implode('', $buttons), ' </ul> </div>';}?>

Matthew K.

Not a problem, can you actually attach it, rather than wrapping it in [code][/code] tags? It just helps make things easier...

Texan78

Certainly, I have attached it below. Thank you for your help.

Matthew K.

I don't have time right now to address this topic - Right now, I am working on fixing some issues in Menu Editor Lite. I'll mark this as unread and hit it up when I am done.

Texan78

Quote from: Labradoodle-360 on January 16, 2012, 09:45:30 PM
I don't have time right now to address this topic - Right now, I am working on fixing some issues in Menu Editor Lite. I'll mark this as unread and hit it up when I am done.

Thank you for the help, I will keep a eye on this post. In the meantime I will try to see if I can get it to work and if I do I will post a update.

-Thanks

Matthew K.

Sorry it took so long. Try this...if it doesn't look right, post back with a screenshot please.

Texan78

I was able to get the news over where I need it properly now. Only issue I am having is getting the search down opposite with the menu. Problem is I can't locate the menu template or file as the menu style isn't in the index.template. Any suggestions.

Here is how it is now and where I need the search box.


Matthew K.

Did you look at the file I gave you...? I coded the whole thing for you...


I'll go ahead and explain it, in case you want to just duplicate what I did instead of using the file I attached.

The menu template (as I explained in your duplicate topic) is defined in function template_menu() which is in ./Themes/default/index.template.php.

So what you do is...assign a width to the menu div and float it left, then put the search code after, and float that right with the difference in the width. In the code I gave you, the menu was 85%, and the search was set to 15%.

Texan78

Quote from: Labradoodle-360 on January 17, 2012, 12:47:39 AM
So what you do is...assign a width to the menu div and float it left, then put the search code after, and float that right with the difference in the width. In the code I gave you, the menu was 85%, and the search was set to 15%.

Yes you are correct with the float left and right. Problem is then it puts it on two separate lines and doesn't align them on the same line together.  Which in turn causes them to fight over the same line and breaking the template. What needs to be done is they need to be within the same div sharing a ID then you can assign the class of float left and float right. So I am trying to get it within the same div container so they will be on the same line together.

-Thanks

Matthew K.

Nah...here's an example.
echo '<div class="floatleft" style="width: 75%;">Menu Here.</div><div class="floatright" style="width: 25%;">Search Form Here.</div><br class="clear" />';
Unless you're leaving an id on that kills the floating, it'll work.

Texan78

As I stated before the float left and right is partially correct for lining it left and right. But since you have them wrapped in two different div containers it will have them fighting over the same space and put them on the same line.

Instead it should be this so it lines it up on the same line and they aren't fighting over the same space.

echo '<div class="floatleft" style="width: 75%;">Menu Here.<div class="floatright">Search Form Here.</div>';

Then just add your css to the stylesheet for the class floatleft and right and this will allow them to share the same line on equal sides.  Only need to assign the width once since it is sharing the same div and don't need the clear since it will add padding to the bottom unless you want that. In my case I didn't but if I did I would use a attribute in the css assigned to a ID.

Here are the examples of the two codes. The first one being your code, the red box is produced by a plugin called web developer for firefox. It is one of the tools for it that will let you see css styles. As you can see the div doesn't include the search box because they're separate thus making them fight over the same spot and pushing them on two separate lines. The box is bunched up due to the width setting but that is a easy fix, but your problem would still be the same.



Now here is the final code with the tweeks I made with them sharing the same div properly and then floating left and right as it should be and with the width only being assigned once and the clear remove. As you can see they are now sharing the same line and not fighting over the same spot and properly aligned left and right.



All is perfect now and I think you very much for your help. Without your guidance I wouldn't have been able to dissect the code. I am still learning my way around SMF. So we both learned something.  ;)

-Thanks

Matthew K.

Oh, I understand they are divs with their own attributes, but I also know CSS, and I know it's possible to manipulate the divs attributes using style="" and therefore force them to play nicely with eachother. All I am saying is it's possible.

Glad you got it figured out.

Texan78

Quote from: Labradoodle-360 on January 17, 2012, 02:11:28 AM
Oh, I understand they are divs with their own attributes, but I also know CSS, and I know it's possible to manipulate the divs attributes using style="" and therefore force them to play nicely with eachother. All I am saying is it's possible.

Yep, sharing the same container. Yes, I agree, it is possible to manipulate divs with  inline styles. I myself do it all the time too even though it's a bad habit..LoL Still haven't figured out why I can make a certain way work one time and the next it doesn't. Oh well, all in the fun. Thanks again!

Advertisement: