New icon theming. Also added basic template for left_main.php
[squirrelmail.git] / src / left_main.php
index 79aa3da2290ababf3140ba4e6b5a095b897eda43..262a97175823828a5fe6d2117d84e69fcb5e2f86 100644 (file)
@@ -3,12 +3,11 @@
 /**
  * left_main.php
  *
- * Copyright (c) 1999-2005 The SquirrelMail Project Team
- * Licensed under the GNU GPL. For full terms see the file COPYING.
- *
  * This is the code for the left bar. The left bar shows the folders
  * available, and has cookie information.
  *
+ * @copyright © 1999-2006 The SquirrelMail Project Team
+ * @license http://opensource.org/licenses/gpl-license.php GNU Public License
  * @version $Id$
  * @package squirrelmail
  */
 define('SM_PATH','../');
 
 /* SquirrelMail required files. */
-require_once(SM_PATH . 'include/validate.php');
+include_once(SM_PATH . 'include/validate.php');
 require_once(SM_PATH . 'functions/imap.php');
 require_once(SM_PATH . 'functions/plugin.php');
 require_once(SM_PATH . 'functions/page_header.php');
 require_once(SM_PATH . 'functions/html.php');
 require_once(SM_PATH . 'functions/date.php');
 
+/** add required includes */
+include_once(SM_PATH . 'templates/util_global.php');
+include_once(SM_PATH . 'templates/util_left_main.php');
+
 /* These constants are used for folder stuff. */
 define('SM_BOX_UNCOLLAPSED', 0);
 define('SM_BOX_COLLAPSED',   1);
@@ -34,163 +37,24 @@ define('SM_BOX_COLLAPSED',   1);
 /* --------------------- FUNCTIONS ------------------------- */
 
 
+
 /**
- * Recursive function to output a tree of folders.
- * It is called on a list of boxes and iterates over that tree.
+ * Recursive functions to output a tree of folders.
+ * They are called on a list of boxes and iterates over that tree.
  *
+ * NOTE: These functions are deprecated and replaced with templates in 1.5.2.
+ *       They remain until the advanced tree tempalte is completed also,
+ *       at which point both functions below will be removed
+ * 
  * @since 1.3.0
+ * @deprecated
  */
-function ListBoxes ($boxes, $j=0 ) {
-    global $data_dir, $username, $color, $unseen_notify, $unseen_type,
-           $move_to_trash, $trash_folder, $collapse_folders, $imapConnection,
-           $use_icons, $icon_theme, $use_special_folder_color;
-
-    // stop condition
-    if (empty($boxes)) {
-        return;
-    }
-
-    $pre = '<span style="white-space: nowrap;">';
-    $end = '';
-    $collapse = false;
-    $unseen_found = false;
-    $unseen = 0;
-
-    $mailbox = $boxes->mailboxname_full;
-    $leader = '<tt>';
-    $leader .= str_repeat('&nbsp;&nbsp;',$j);
-    $mailboxURL = urlencode($mailbox);
-
-    /* get unseen/total messages information */
-    /* Only need to display info when option is set */
-    if (isset($unseen_notify) && ($unseen_notify > 1) &&
-        (($boxes->unseen !== false) || ($boxes->total !== false))) {
-
-        if ($boxes->unseen !== false)
-            $unseen = $boxes->unseen;
-
-        /*
-            Should only display unseen info if the folder is inbox
-            or you set the option for all folders
-        */
-
-        if ((strtolower($mailbox) == 'inbox') || ($unseen_notify == 3)) {
-            $unseen_string = $unseen;
-
-            /* If users requests, display message count too */
-            if (isset($unseen_type) && ($unseen_type == 2) && ($boxes->total !== false)) {
-                $unseen_string .= '/' . $boxes->total;
-            }
-
-            $unseen_string = "<font color=\"$color[11]\">($unseen_string)</font>";
-
-            /*
-                Finally allow the script to display the values by setting a boolean.
-                This can only occur if the unseen count is great than 0 (if you have
-                unseen count only), or you have the message count too.
-            */
-            if (($unseen > 0) || (isset($unseen_type) && ($unseen_type ==2))) {
-                $unseen_found = true;
-            }
-        }
-    }
-
-    if (isset($boxes->mbxs[0]) && $collapse_folders) {
-        $collapse = getPref($data_dir, $username, 'collapse_folder_' . $mailbox);
-        $collapse = ($collapse == '' ? SM_BOX_UNCOLLAPSED : $collapse);
-
-        $link = '<a target="left" style="text-decoration:none" ' .'href="left_main.php?';
-        if ($collapse) {
-            if ($use_icons && $icon_theme != 'none') {
-                $link .= "unfold=$mailboxURL\">$leader<img src=\"" . SM_PATH . 'images/plus.png" border="0" height="7" width="7" />&nbsp;</tt>';
-            } else {
-                $link .= "unfold=$mailboxURL\">$leader+&nbsp;</tt>";
-            }
-        } else {
-            if ($use_icons && $icon_theme != 'none') {
-                $link .= "fold=$mailboxURL\">$leader<img src=\"" . SM_PATH . 'images/minus.png" border="0" height="7" width="7" />&nbsp;</tt>';
-            } else {
-                $link .= "fold=$mailboxURL\">$leader-&nbsp;</tt>";
-            }
-        }
-        $link .= '</a>';
-        $pre .= $link;
-    } else {
-        $pre.= $leader . '&nbsp;&nbsp;</tt>';
-    }
-
-    /* If there are unseen message, bold the line. */
-    if (($move_to_trash) && ($mailbox == $trash_folder)) {
-        if (! isset($boxes->total)) {
-            $boxes->total = sqimap_status_messages($imapConnection, $mailbox);
-        }
-        $pre .= "<a href=\"right_main.php?PG_SHOWALL=0&amp;startMessage=1&amp;mailbox=$mailboxURL\" target=\"right\" style=\"text-decoration:none\">";
-        if ($unseen > 0) {
-            $pre .= '<b>';
-            $end .= '</b>';
-        }
-        $end .= '</a>';
-        if ($boxes->total > 0) {
-            /* Print unseen information. */
-            if ($unseen_found) {
-                $end .= "&nbsp;<small>$unseen_string</small>";
-            }
-            $end .= "\n\t<small>" .
-                 '&nbsp;&nbsp;[<a href="empty_trash.php">'._("Purge").'</a>]'.
-                 '</small>';
-        }
-    } else {
-        if (!$boxes->is_noselect) {
-            $pre .= "<a href=\"right_main.php?PG_SHOWALL=0&amp;startMessage=1&amp;mailbox=$mailboxURL\" target=\"right\" style=\"text-decoration:none\">";
-            if ($unseen > 0) {
-                $pre .= '<b>';
-                $end .= '</b>';
-            }
-            $end .= '</a>';
-        }
-        /* Print unseen information. */
-        if ($unseen_found) {
-            $end .= "&nbsp;<small>$unseen_string</small>";
-        }
-
-    }
-
-    $font = '';
-    $fontend = '';
-    if ($use_special_folder_color && $boxes->is_special) {
-        $font = "<font color=\"$color[11]\">";
-        $fontend = "</font>";
-    } elseif ( $boxes->is_noselect ) {
-        $font = "<font color=\"$color[15]\">";
-        $fontend = '</font>';
-    }
-        
-    // let plugins fiddle with end of line
-    $end .= concat_hook_function('left_main_after_each_folder',
-        array(isset($numMessages) ? $numMessages : '',
-              $boxes->mailboxname_full, $imapConnection));
-
-    $end .= '</span>';
-
-    if (!$boxes->is_root) {
-        echo "" . $pre .$font.
-            str_replace( 
-                array(' ','<','>'),
-                array('&nbsp;','&lt;','&gt;'),
-                $boxes->mailboxname_sub) .
-            $fontend . $end. '<br />' . "\n";
-        $j++;
-    }
-
-    if (!$collapse || $boxes->is_root) {
-        for ($i = 0; $i <count($boxes->mbxs); $i++) {
-            ListBoxes($boxes->mbxs[$i],$j);
-        }
-    }
+function ListBoxes ($boxes, $j=0) {
+    return '';
 }
 
 function ListAdvancedBoxes ($boxes, $mbx, $j='ID.0000' ) {
-    global $data_dir, $username, $color, $unseen_notify, $unseen_type,
+    global $data_dir, $username, $color, $unseen_notify, $unseen_type, $unseen_cum,
         $move_to_trash, $trash_folder, $collapse_folders, $use_special_folder_color;
 
     if (empty($boxes)) {
@@ -209,36 +73,61 @@ function ListAdvancedBoxes ($boxes, $mbx, $j='ID.0000' ) {
     $mailbox = $boxes->mailboxname_full;
     $mailboxURL = urlencode($mailbox);
 
+     /* get collapse information */
+     if ($collapse_folders) {
+          $form_entry = $j.'F';
+          if (isset($mbx) && isset($mbx[$form_entry])) {
+              $collapse = $mbx[$form_entry];
+              setPref($data_dir, $username, 'collapse_folder_'.$boxes->mailboxname_full ,
+                    $collapse ? SM_BOX_COLLAPSED : SM_BOX_UNCOLLAPSED);
+          } else {
+              $collapse = getPref($data_dir, $username, 'collapse_folder_' . $mailbox);
+              $collapse = ($collapse == '' ? SM_BOX_UNCOLLAPSED : $collapse);
+          }
+          $img_src = ($collapse ? '../images/plus.png' : '../images/minus.png');
+          $collapse_link = '<a href="javascript:void(0)">' .
+                    " <img src=\"$img_src\" border=\"1\" id=$j onclick=\"hidechilds(this)\" style=\"cursor:hand\" /></a>";
+    } else {
+         $collapse_link='';
+    }
+
     /* get unseen/total messages information */
     /* Only need to display info when option is set */
-    if (isset($unseen_notify) && ($unseen_notify > 1) &&
-        (($boxes->unseen !== false) || ($boxes->total !== false))) {
-
-        if ($boxes->unseen !== false)
-            $unseen = $boxes->unseen;
-
-        /*
-            Should only display unseen info if the folder is inbox
-            or you set the option for all folders
-        */
-
-        if ((strtolower($mailbox) == 'inbox') || ($unseen_notify == 3)) {
-            $unseen_string = $unseen;
-
-            /* If users requests, display message count too */
-            if (isset($unseen_type) && ($unseen_type == 2) && ($boxes->total !== false)) {
-                $unseen_string .= '/' . $boxes->total;
+    if (isset($unseen_notify) && ($unseen_notify > 1)) {
+        /* handle Cumulative Unread Message Notification */
+        if ($collapse && $unseen_cum) {
+            foreach ($boxes->mbxs as $cumn_box) {
+                if (!empty($cumn_box->unseen)) $boxes->unseen += $cumn_box->unseen;
+                if (!empty($cumn_box->total)) $boxes->total += $cumn_box->total;
             }
-
-            $unseen_string = "<font color=\"$color[11]\">($unseen_string)</font>";
-
-            /*
-                Finally allow the script to display the values by setting a boolean.
-                This can only occur if the unseen count is great than 0 (if you have
-                unseen count only), or you have the message count too.
-            */
-            if (($unseen > 0) || (isset($unseen_type) && ($unseen_type ==2))) {
-                $unseen_found = true;
+        }
+        if (($boxes->unseen !== false) || ($boxes->total !== false)) {
+            if ($boxes->unseen !== false)     $unseen = $boxes->unseen;
+               /*
+                * Should only display unseen info if the folder is inbox
+                * or you set the option for all folders
+                */
+                if ((strtolower($mailbox) == 'inbox') || ($unseen_notify == 3)) {
+                     $unseen_string = $unseen;
+
+                    /* If users requests, display message count too */
+                    if (isset($unseen_type) && ($unseen_type == 2) && ($boxes->total !== false)) {
+                        $unseen_string .= '/' . $boxes->total;
+                    }
+                    if (isset($boxes->recent) && $boxes->recent > 0) {
+                        $unseen_string = "<span class=\"leftrecent\">($unseen_string)</span>";
+                    } else {
+                        $unseen_string = "<span class=\"leftunseen\">($unseen_string)</span>";
+                    }
+
+                    /*
+                     * Finally allow the script to display the values by setting a boolean.
+                     * This can only occur if the unseen count is great than 0 (if you have
+                     * unseen count only), or you have the message count too.
+                     */
+                     if (($unseen > 0) || (isset($unseen_type) && ($unseen_type ==2))) {
+                         $unseen_found = true;
+                     }
             }
         }
     }
@@ -248,8 +137,8 @@ function ListAdvancedBoxes ($boxes, $mbx, $j='ID.0000' ) {
 
     /* color special boxes */
     if ($use_special_folder_color && $boxes->is_special) {
-        $pre .= "<font color=\"$color[11]\">";
-        $end .= '</font>';
+        $pre .= "<span class=\"leftspecial\">";
+        $end .= '</span>';
     }
 
     /* If there are unseen message, close bolding. */
@@ -279,6 +168,7 @@ function ListAdvancedBoxes ($boxes, $mbx, $j='ID.0000' ) {
         array(isset($numMessages) ? $numMessages : '',
               $boxes->mailboxname_full, $imapConnection));
 
+    $out = '';
     if (!$boxes->is_root) {
         if ($use_folder_images) {
             if ($boxes->is_inbox) {
@@ -294,57 +184,43 @@ function ListAdvancedBoxes ($boxes, $mbx, $j='ID.0000' ) {
             } else {
                 $folder_img = '../images/folder.png';
             }
-            $folder_img = '&nbsp;<img src="'.$folder_img.'" height="15" valign="center" />&nbsp;';
+            $folder_img = '&nbsp;<img src="'.$folder_img.'" height="15" />&nbsp;';
         } else {
             $folder_img = '';
         }
         if (!isset($boxes->mbxs[0])) {
-            echo '   ' . html_tag( 'div',
-                            '<tt>'. $pre . $folder_img . '</tt>' .
+            $out .= '   ' . html_tag( 'div',
+                            $pre . $folder_img .
                                 str_replace( array(' ','<','>'),
                                              array('&nbsp;','&lt;','&gt;'),
                                              $boxes->mailboxname_sub) .
                                 $end,
                             'left', '', 'class="mbx_sub" id="' .$j. '"' ) . "\n";
         } else {
-            /* get collapse information */
-            if ($collapse_folders) {
-                $form_entry = $j.'F';
-                if (isset($mbx) && isset($mbx[$form_entry])) {
-                    $collapse = $mbx[$form_entry];
-                    setPref($data_dir, $username, 'collapse_folder_'.$boxes->mailboxname_full ,
-                        $collapse ? SM_BOX_COLLAPSED : SM_BOX_UNCOLLAPSED);
-                } else {
-                    $collapse = getPref($data_dir, $username, 'collapse_folder_' . $mailbox);
-                    $collapse = ($collapse == '' ? SM_BOX_UNCOLLAPSED : $collapse);
-                }
-                $img_src = ($collapse ? '../images/plus.png' : '../images/minus.png');
-                $collapse_link = '<a href="javascript:void(0)">' .
-                    " <img src=\"$img_src\" border=\"1\" id=$j onclick=\"hidechilds(this)\" style=\"cursor:hand\" /></a>";
-            } else {
-                 $collapse_link='';
-            }
-            echo '   ' . html_tag( 'div',
+
+            $out .= '   ' . html_tag( 'div',
                             $collapse_link . $pre . $folder_img . '&nbsp;'. $boxes->mailboxname_sub . $end ,
                             'left', '', 'class="mbx_par" id="' .$j. 'P"' ) . "\n";
-            echo '   <input type="hidden" name="mbx['.$j. 'F]" value="'.$collapse.'" id="mbx['.$j.'F]" />'."\n";
+            $out .= '   <input type="hidden" name="mbx['.$j. 'F]" value="'.$collapse.'" id="mbx['.$j.'F]" />'."\n";
         }
     }
 
     $visible = ($collapse ? ' style="display:none"' : ' style="display:block"');
     if (isset($boxes->mbxs[0]) && !$boxes->is_root) /* mailbox contains childs */
-        echo html_tag( 'div', '', 'left', '', 'class="par_area" id='.$j.'.0000 '. $visible ) . "\n";
+        $out .= html_tag( 'div', '', 'left', '', 'class="par_area" id='.$j.'.0000 '. $visible ) . "\n";
 
     if ($j !='ID.0000') {
        $j = $j .'.0000';
     }
     for ($i = 0; $i <count($boxes->mbxs); $i++) {
         $j++;
-        ListAdvancedBoxes($boxes->mbxs[$i],$mbx,$j);
+        $out .= ListAdvancedBoxes($boxes->mbxs[$i],$mbx,$j);
     }
     if (isset($boxes->mbxs[0]) && !$boxes->is_root) {
-        echo '</div>'."\n\n";
+        $out .= '</div>'."\n\n";
     }
+    
+    return $out;
 }
 
 
@@ -383,18 +259,9 @@ if (!empty($left_refresh) &&
  * $advanced_tree and is a boolean var which is default set to default
  * SM behaviour.
  * Setting $advanced tree to true causes SM to display a experimental
- * mailbox-tree with dhtml behaviour.
- * It only works on browsers which supports css and javascript. The used
- * javascript is experimental and doesn't support all browsers.
- * It has been tested on IE6 an Konquerer 3.0.0-2.
- * It is now tested and working on: (please test and update this list)
- * Windows: IE 5.5 SP2, IE 6 SP1, Gecko based (Mozilla, Firebird) and Opera7
- * XWindow: ?
- * Mac: ?
- * In the function ListAdvancedBoxes there is another var $use_folder_images.
- * setting this to true is only usefull if the images exists in ../images.
- *
- * Feel free to experiment with the code and report bugs and enhancements
+ * mailbox-tree with dhtml behaviour.  
+ * 
+ * See templates/default/left_main_advanced.tpl
  **/
 
 /* set this to true if you want to see a nicer mailboxtree */
@@ -402,238 +269,22 @@ if (empty($advanced_tree)) {
     $advanced_tree=false;
 }
 
-if ($advanced_tree) {
-$xtra .= '<script language="Javascript" type="text/javascript">'."\n".
-'<!--'."\n".
-'    function preload() {'."\n".
-'      if (document.images) {'."\n".
-'        var treeImages = new Array;'."\n".
-'        var arguments = preload.arguments;'."\n".
-'        for (var i = 0; i<arguments.length; i++) {'."\n".
-'          treeImages[i] = new Image();'."\n".
-'          treeImages[i].src = arguments[i];'."\n".
-'        }'."\n".
-'      }'."\n".
-'    }'."\n".
-'var vTreeImg;'."\n".
-'var vTreeDiv;'."\n".
-'var vTreeSrc;'."\n".
-'    function fTreeTimeout() {'."\n".
-'      if (vTreeDiv.readyState == "complete")'."\n".
-'        vTreeImg.src = vTreeSrc;'."\n".
-'      else'."\n".
-'        setTimeout("fTreeTimeout()", 100);'."\n".
-'    }'."\n".
-'    function hidechilds(img) {'."\n".
-'      id = img.id + ".0000";'."\n".
-'      form_id = "mbx[" + img.id +"F]";'."\n".
-'      if (document.all) { //IE, Opera7'."\n".
-'        div = document.all[id];'."\n".
-'        if (div) {'."\n".
-'           if (div.style.display == "none") {'."\n".
-'              vTreeSrc = "../images/minus.png";'."\n".
-'              style = "block";'."\n".
-'              value = 0;'."\n".
-'           }'."\n".
-'           else {'."\n".
-'              vTreeSrc = "../images/plus.png";'."\n".
-'              style = "none";'."\n".
-'              value = 1;'."\n".
-'           }'."\n".
-'           vTreeImg = img;'."\n".
-'           vTreeDiv = div;'."\n".
-'           if (typeof vTreeDiv.readyState != "undefined") //IE'."\n".
-'              setTimeout("fTreeTimeout()",100);'."\n".
-'           else //Non IE'."\n".
-'              vTreeImg.src = vTreeSrc;'."\n".
-'           div.style.display = style;'."\n".
-'           document.all[form_id].value = value;'."\n".
-'        }'."\n".
-'      }'."\n".
-'      else if (document.getElementById) { //Gecko'."\n".
-'        div = document.getElementById(id);'."\n".
-'        if (div) {'."\n".
-'           if (div.style.display == "none") {'."\n".
-'              src = "../images/minus.png";'."\n".
-'              style = "block";'."\n".
-'              value = 0;'."\n".
-'           }'."\n".
-'           else {'."\n".
-'              src = "../images/plus.png";'."\n".
-'              style = "none";'."\n".
-'              value = 1;'."\n".
-'           }'."\n".
-'           div.style.display = style;'."\n".
-'           img.src = src;'."\n".
-'           document.getElementById(form_id).value = value;'."\n".
-'        }'."\n".
-'      }'."\n".
-'    }'."\n".
-'   function buttonover(el,on) {'."\n".
-'      if (!on) {'."\n".
-"//         el.style.borderColor=\"$color[9]\";}\n".
-"         el.style.background=\"$color[0]\";}\n".
-'      else {'."\n".
-"         el.style.background=\"$color[9]\";}\n".
-'   }'."\n".
-'   function buttonclick(el,on) {'."\n".
-'      if (!on) {'."\n".
-'         el.style.border="groove";}'."\n".
-'      else {'."\n".
-'         el.style.border="ridge";}'."\n".
-'   }'."\n".
-'   function hideframe(hide) {'."\n".
-'      left_size = "' . $left_size . '";'."\n".
-'      if (document.all) {'."\n".
-'        masterf = window.parent.document.all["fs1"];'."\n".
-'        leftf = window.parent.document.all["left"];'."\n".
-'        leftcontent = document.all["leftframe"];'."\n".
-'        leftbutton = document.all["showf"];'."\n".
-'      } else if (document.getElementById) {'."\n".
-'        masterf = window.parent.document.getElementById("fs1");'."\n".
-'        leftf = window.parent.document.getElementById("left");'."\n".
-'        leftcontent = document.getElementById("leftframe");'."\n".
-'        leftbutton = document.getElementById("showf");'."\n".
-'      } else {'."\n".
-'        return false;'."\n".
-'      }'."\n".
-'      if(hide) {'."\n".
-'         new_col = calc_col("20");'."\n".
-'         masterf.cols = new_col;'."\n".
-'         document.body.scrollLeft=0;'."\n".
-'         document.body.style.overflow="hidden";'."\n".
-'         leftcontent.style.display = "none";'."\n".
-'         leftbutton.style.display="block";'."\n".
-'      } else {'."\n".
-'         masterf.cols = calc_col(left_size);'."\n".
-'         document.body.style.overflow="";'."\n".
-'         leftbutton.style.display="none";'."\n".
-'         leftcontent.style.display="block";'."\n".
-'      }'."\n".
-'   }'."\n".
-'   function calc_col(c_w) {'."\n";
-
-   if ($location_of_bar == 'right') {
-       $xtra .= '     right=true;';
-   } else {
-       $xtra .= '     right=false;';
-   }
-   $xtra .= "\n";
-
-$xtra .= 'if (right) {'."\n".
-"         new_col = '*,'+c_w;"."\n".
-'     } else {'."\n".
-"         new_col = c_w+',*';"."\n".
-'     }'."\n".
-'     return new_col;'."\n".
-'   }'."\n".
-'   function resizeframe(direction) {'."\n".
-'     if (document.all) {'."\n".
-'        masterf = window.parent.document.all["fs1"];'."\n".
-'     } else if (document.getElementById) {'."\n".
-'        window.parent.document.getElementById("fs1");'."\n".
-'     } else {'."\n".
-'        return false;'."\n".
-'     }'."\n";
-
-   if ($location_of_bar == 'right') {
-       $xtra .= '  colPat=/^\*,(\d+)$/;';
-   } else {
-       $xtra .= '  colPat=/^(\d+),.*$/;';
-   }
-   $xtra .= "\n";
-
-$xtra .= 'old_col = masterf.cols;'."\n".
-'     colPat.exec(old_col);'."\n".
-'     if (direction) {'."\n".
-'        new_col_width = parseInt(RegExp.$1) + 25;'."\n".
-'     } else {'."\n".
-'        if (parseInt(RegExp.$1) > 35) {'."\n".
-'           new_col_width = parseInt(RegExp.$1) - 25;'."\n".
-'        }'."\n".
-'     }'."\n".
-'     masterf.cols = calc_col(new_col_width);'."\n".
-'   }'."\n".
-'//-->'."\n".
-'</script>'."\n";
-
-/* style definitions */
-
-$xtra .= '<style type="text/css">'."\n".
-'<!--'."\n".
-'  body {'."\n".
-'     margin: 0px 0px 0px 0px;'."\n".
-'     padding: 5px 5px 5px 5px;'."\n".
-'  }'."\n".
-'  .button {'."\n".
-'     border:outset;'."\n".
-"     border-color: $color[9];\n".
-"     background:$color[0];\n".
-"     color:$color[6];\n".
-'     width:99%;'."\n".
-'     heigth:99%;'."\n".
-'  }'."\n".
-'  .mbx_par {'."\n".
-'     font-size:1.0em;'."\n".
-'     margin-left:4px;'."\n".
-'     margin-right:0px;'."\n".
-'  }'."\n".
-'  a.mbx_link {'."\n".
-'      text-decoration: none;'."\n".
-"      background-color: $color[0];\n".
-'      display: inline;'."\n".
-'  }'."\n".
-'  a:hover.mbx_link {'."\n".
-"      background-color: $color[9];\n".
-'  }'."\n".
-'  a.mbx_link img {'."\n".
-'      border-style: none;'."\n".
-'  }'."\n".
-'  .mbx_sub {'."\n".
-'     padding-left:5px;'."\n".
-'     padding-right:0px;'."\n".
-'     margin-left:4px;'."\n".
-'     margin-right:0px;'."\n".
-'     font-size:0.9em;'."\n".
-'  }'."\n".
-'  .par_area {'."\n".
-'     margin-top:0px;'."\n".
-'     margin-left:4px;'."\n".
-'     margin-right:0px;'."\n".
-'     padding-left:10px;'."\n".
-'     padding-bottom:5px;'."\n".
-'     border-left: solid;'."\n".
-'     border-left-width:0.1em;'."\n".
-"     border-left-color:$color[9];\n".
-'     border-bottom: solid;'."\n".
-'     border-bottom-width:0.1em;'."\n".
-"     border-bottom-color:$color[9];\n".
-'     display: block;'."\n".
-'  }'."\n".
-'  .mailboxes {'."\n".
-'     padding-bottom:3px;'."\n".
-'     margin-right:4px;'."\n".
-'     padding-right:4px;'."\n".
-'     margin-left:4px;'."\n".
-'     padding-left:4px;'."\n".
-'     border: groove;'."\n".
-'     border-width:0.1em;'."\n".
-"     border-color:$color[9];\n".
-"     background: $color[0];\n".
-'  }'."\n".
-'-->'."\n".
-'</style>'."\n";
-}
+// get mailbox list and cache it
+$mailboxes=sqimap_get_mailboxes($imapConnection,false,$show_only_subscribed_folders);
 
 displayHtmlHeader( 'SquirrelMail', $xtra );
+
 sqgetGlobalVar('auto_create_done',$auto_create_done,SQ_SESSION);
 /* If requested and not yet complete, attempt to autocreate folders. */
 if ($auto_create_special && !isset($auto_create_done)) {
     $autocreate = array($sent_folder, $trash_folder, $draft_folder);
+    $folders_created = false;
     foreach( $autocreate as $folder ) {
         if (($folder != '') && ($folder != 'none')) {
-            if ( !sqimap_mailbox_exists($imapConnection, $folder)) {
+            // use $mailboxes array for checking if mailbox exists
+            if ( !sqimap_mailbox_exists($imapConnection, $folder, $mailboxes)) {
                 sqimap_mailbox_create($imapConnection, $folder, '');
+                $folders_created = true;
             } else {
                 // check for subscription is useless and expensive, just
                 // surpress the NO response. Unless we're on Mecury, which
@@ -642,6 +293,7 @@ if ($auto_create_special && !isset($auto_create_done)) {
                 if ( strtolower($imap_server_type) != 'mercury32' ||
                     !sqimap_mailbox_is_subscribed($imapConnection, $folder) ) {
                     sqimap_subscribe($imapConnection, $folder, false);
+                    $folders_created = true;
                 }
             }
         }
@@ -650,30 +302,12 @@ if ($auto_create_special && !isset($auto_create_done)) {
     /* Let the world know that autocreation is complete! Hurrah! */
     $auto_create_done = TRUE;
     sqsession_register($auto_create_done, 'auto_create_done');
+    // reload mailbox list
+    if ($folders_created)
+        $mailboxes=sqimap_get_mailboxes($imapConnection,true,$show_only_subscribed_folders);
 }
 
-if ($advanced_tree) {
-    echo "\n<body" .
-            ' onload="preload(\'../images/minus.png\',\'../images/plus.png\')"' .
-            " bgcolor=\"$color[3]\" text=\"$color[6]\" link=\"$color[6]\" vlink=\"$color[6]\" alink=\"$color[6]\">\n";
-} else {
-    echo "\n<body bgcolor=\"$color[3]\" text=\"$color[6]\" link=\"$color[6]\" vlink=\"$color[6]\" alink=\"$color[6]\">\n";
-}
-
-do_hook('left_main_before');
-if ($advanced_tree) {
-   /* nice future feature, needs layout !! volunteers?   */
-   $right_pos = $left_size - 20;
-/*   echo '<div style="position:absolute;top:0;border=solid;border-width:0.1em;border-color:blue;"><div id="hidef" style="width=20;font-size:12"><a href="javascript:hideframe(true)"><b>&lt;&lt;</b></a></div>';
-   echo '<div id="showf" style="width=20;font-size:12;display:none;"><a href="javascript:hideframe(false)"><b>&gt;&gt;</b></a></div>';
-   echo '<div id="incrf" style="width=20;font-size:12"><a href="javascript:resizeframe(true)"><b>&gt;</b></a></div>';
-   echo '<div id="decrf" style="width=20;font-size:12"><a href="javascript:resizeframe(false)"><b>&lt;</b></a></div></div>';
-   echo '<div id="leftframe"><br /><br />';*/
-}
-
-echo "\n\n" . 
-    '<center><font size="4"><b>'. _("Folders") . "</b><br /></font>\n\n";
-
+$clock = '';
 if ($date_format != 6) {
     /* First, display the clock. */
     if ($hour_format == 1) {
@@ -708,16 +342,11 @@ if ($date_format != 6) {
     }
     $clk = str_replace(' ','&nbsp;',$clk);
 
-    echo '<small><span style="white-space: nowrap;">' 
-       . str_replace(' ', '&nbsp;', _("Last Refresh")) 
+    $clock = '<small><span style="white-space: nowrap;">'
+       . str_replace(' ', '&nbsp;', _("Last Refresh"))
        . ":</span><br /><span style=\"white-space: nowrap;\">$clk</span></small><br />\n";
 }
 
-/* Next, display the refresh button. */
-echo '<div style="white-space: nowrap;"><small>[<a href="../src/left_main.php" target="left">'.
-     _("Check mail") . "</a>]</small></div></center><br />\n\n";
-
-/* Lastly, display the folder list. */
 if ( $collapse_folders ) {
     /* If directed, collapse or uncollapse a folder. */
     if (isset($fold)) {
@@ -747,25 +376,53 @@ if (empty($unseen_notify)) {
     }
 }
 
-$boxes = sqimap_mailbox_tree($imapConnection);
+/**
+ * pass $mailboxes now instead of $imapconnection - sqimap_get_mailboxes() has been separated from
+ * sqimap_mailbox_tree() so that the cached mailbox list can be used elsewhere in left_main and beyond
+ */
+$boxes = sqimap_mailbox_tree($imapConnection,$mailboxes,$show_only_subscribed_folders);
+
+$mailbox_listing = '';
 if (isset($advanced_tree) && $advanced_tree) {
-    echo '<form name="collapse" action="left_main.php" method="post" ' .
-         'enctype="multipart/form-data"'."\n";
-    echo '<small>';
-    echo '<button type="submit" class="button" onmouseover="buttonover(this,true)" onmouseout="buttonover(this,false)" onmousedown="buttonclick(this,true)" onmouseup="buttonclick(this,false)">'. _("Save folder tree") .'</button><br /><br />';
-    echo '<div id="mailboxes" class="mailboxes">'."\n\n";
+    $mailbox_listing = '<form name="collapse" action="left_main.php" method="post" ' .
+         'enctype="multipart/form-data">'."\n";
+    $mailbox_listing .= '<button type="submit" class="button" onmouseover="buttonover(this,true)" onmouseout="buttonover(this,false)" onmousedown="buttonclick(this,true)" onmouseup="buttonclick(this,false)">'. _("Save folder tree") .'</button><br /><br />';
+    $mailbox_listing .= '<div id="mailboxes" class="mailboxes">'."\n\n";
     sqgetGlobalVar('mbx', $mbx, SQ_POST);
     if (!isset($mbx)) $mbx=NULL;
-    ListAdvancedBoxes($boxes, $mbx);
-    echo '</div>';
-    echo '</small>';
-    echo '</form>'."\n";
+    $mailbox_listing .=ListAdvancedBoxes($boxes, $mbx);
+    $mailbox_listing .= '</div>';
+    $mailbox_listing .= '</form>'."\n";
 } else {
-    ListBoxes($boxes);
+    $mailbox_listing = ListBoxes($boxes);
 }
 
-do_hook('left_main_after');
-sqimap_logout($imapConnection);
+$mailbox_structure = getBoxStructure($boxes);
+
+$oTemplate->assign('clock', $clock);
+$oTemplate->assign('mailbox_listing', $mailbox_listing);
+$oTemplate->assign('location_of_bar', $location_of_bar);
+$oTemplate->assign('left_size', $left_size);
+
+$oTemplate->assign('mailboxes', $mailbox_structure);
+$oTemplate->assign('imapConnection', $imapConnection);
+
+$oTemplate->assign('unread_notification_enabled', $unseen_notify!=1);
+$oTemplate->assign('unread_notification_cummulative', $unseen_cum==1);
+$oTemplate->assign('unread_notification_allFolders', $unseen_notify == 3);
+$oTemplate->assign('unread_notification_displayTotal', $unseen_type == 2);
+$oTemplate->assign('collapsable_folders_enabled', $collapse_folders==1);
+$oTemplate->assign('icon_theme_path', $icon_theme_path);
+$oTemplate->assign('use_special_folder_color', $use_special_folder_color);
+$oTemplate->assign('message_recycling_enabled', $move_to_trash);
+$oTemplate->assign('trash_folder_name', $trash_folder);
+
+if (isset($advanced_tree) && $advanced_tree)    {
+    $oTemplate->display('left_main_advanced.tpl');
+}   else    { 
+    $oTemplate->display('left_main.tpl');
+}
 
-?>
-</body></html>
+sqimap_logout($imapConnection);
+$oTemplate->display('footer.tpl');
+?>
\ No newline at end of file