Allow main theme in login screen.
[squirrelmail.git] / functions / page_header.php
index 2b22afcc91e68e794577f805b0d2888afd80cd5e..60c8ec7ab044960cf26798be4266211ec486b569 100644 (file)
 // Always set up the language before calling these functions
 function displayHtmlHeader( $title = 'SquirrelMail', $xtra = '', $do_hook = TRUE ) {
 
-        global $theme_css;
-
-        echo '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">' .
-             "\n\n<HTML>\n<HEAD>\n";
-
+    global $theme_css, $custom_css;
+    
+    echo '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">' .
+         "\n\n<HTML>\n<HEAD>\n";
+    
+    if ( !isset( $custom_css ) || $custom_css == 'none' ) {
         if ($theme_css != '') {
             echo "<LINK REL=\"stylesheet\" TYPE=\"text/css\" HREF=\"$theme_css\">\n";
         }
-
-        if( $do_hook ) {
-            do_hook ("generic_header");
-        }
-
-        echo "<title>$title</title>$xtra</head>\n\n";
+    } else {
+        echo "<LINK REL=\"stylesheet\" TYPE=\"text/css\" HREF=\"../themes/css/$custom_css\">\n";
+    }
+    
+    if( $do_hook ) {
+        do_hook ("generic_header");
+    }
+    
+    echo "<title>$title</title>$xtra</head>\n\n";
 }
 
 function displayInternalLink($path, $text, $target='') {
@@ -41,10 +45,56 @@ function displayInternalLink($path, $text, $target='') {
 }
 
 function displayPageHeader($color, $mailbox) {
-    global $delimiter, $hide_sm_attributions;
+
+    global $delimiter, $hide_sm_attributions, $base_uri, $PHP_SELF;
+
     displayHtmlHeader ();
 
-    echo "<BODY TEXT=\"$color[8]\" BGCOLOR=\"$color[4]\" LINK=\"$color[7]\" VLINK=\"$color[7]\" ALINK=\"$color[7]\" onLoad='if ( ( document.forms.length > 0 ) && ( document.forms[0].elements[0].type == \"text\" ) ) { document.forms[0].elements[0].focus(); }'>\n\n";
+    $module = substr( $PHP_SELF, ( strlen( $PHP_SELF ) - strlen( $base_uri ) ) * -1 );
+
+    /*
+        Locate the first displayable form element
+    */
+    switch ( $module ) {
+    case 'src/search.php':
+        $pos = getPref($data_dir, $username, 'search_pos', 0 ) - 1;
+        $onload = "onLoad=\"document.forms[$pos].elements[2].focus();\"";
+        break;
+    default:
+        echo '
+<script language="JavaScript">
+<!--
+function checkForm() {
+
+    var f = document.forms.length;
+    var i = 0;
+    var pos = -1;
+    while( pos == -1 && i < f ) {
+        var e = document.forms[i].elements.length;
+        var j = 0;
+        while( pos == -1 && j < e ) {
+            if ( document.forms[i].elements[j].type == \'text\' ) {
+                pos = j;
+            }
+            j++;
+        }
+        i++;
+    }
+    if( pos >= 0 ) {
+        // document.write( "Si tio" );
+        document.forms[i-1].elements[pos].focus();
+    }
+    
+}
+-->
+</script>
+        ';
+        $onload = "onLoad=\"checkForm();\"";
+        break;   
+
+    }
+
+    echo "<BODY TEXT=\"$color[8]\" BGCOLOR=\"$color[4]\" LINK=\"$color[7]\" VLINK=\"$color[7]\" ALINK=\"$color[7]\" $onload>\n\n";
 
     /** Here is the header and wrapping table **/
     $shortBoxName = readShortMailboxName($mailbox, $delimiter);