From 597170feb25f5c2e5a90a9c0b1fd62001f169afb Mon Sep 17 00:00:00 2001
From: thomascube <thomas@roundcube.net>
Date: Tue, 04 Oct 2005 16:28:01 -0400
Subject: [PATCH] Added new languages, hierarchical folder tree and attachments in forwarded messages

---
 CHANGELOG                            |    7 
 program/include/main.inc             |    6 
 program/steps/mail/compose.inc       |   44 +
 skins/default/mail.css               |   35 +
 program/localization/fr/labels.inc   |  172 +++++++
 program/localization/da/labels.inc   |  175 +++++++
 program/localization/it/messages.inc |   56 ++
 index.php                            |   22 
 program/include/rcube_db.inc         |   69 ++
 program/steps/mail/upload.inc        |   14 
 program/localization/it/labels.inc   |  172 +++++++
 program/steps/mail/func.inc          |  165 +++++++
 program/localization/da/messages.inc |   58 ++
 program/localization/fr/messages.inc |   56 ++
 program/localization/es/labels.inc   |  171 +++++++
 program/localization/es/messages.inc |   56 ++
 program/js/app.js                    |    6 
 program/include/rcube_imap.inc       |    9 
 18 files changed, 1,235 insertions(+), 58 deletions(-)

diff --git a/CHANGELOG b/CHANGELOG
index 76ae49f..07b2069 100644
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -26,11 +26,14 @@
 - Make list of special mailboxes configurable
 
 
-2005/09/28
+2005/10/04
 ----------
 - Added French, Italian, Spanish, Danish translation
 - Fixed PHP warnings (Bug #1299403)
 - Fixed english translation bug #1295406
 - Fixed bug #1290833: Last character of email not seen
 - Added setting for showing pretty dates
-
+- Added support for SQLite database
+- Make use of message caching configurable
+- Also add attachments when forwarding a message
+- Show nested mailboxes hieracically
diff --git a/index.php b/index.php
index ba2692c..31c39ea 100644
--- a/index.php
+++ b/index.php
@@ -68,10 +68,10 @@
 
 
 // catch some url/post parameters
-$_auth = strlen($_POST['_auth']) ? $_POST['_auth'] : $_GET['_auth'];
-$_task = strlen($_POST['_task']) ? $_POST['_task'] : ($_GET['_task'] ? $_GET['_task'] : 'mail');
-$_action = strlen($_POST['_action']) ? $_POST['_action'] : $_GET['_action'];
-$_framed = ($_GET['_framed'] || $_POST['_framed']);
+$_auth = !empty($_POST['_auth']) ? $_POST['_auth'] : $_GET['_auth'];
+$_task = !empty($_POST['_task']) ? $_POST['_task'] : (!empty($_GET['_task']) ? $_GET['_task'] : 'mail');
+$_action = !empty($_POST['_action']) ? $_POST['_action'] : (!empty($_GET['_action']) ? $_GET['_action'] : '');
+$_framed = (!empty($_GET['_framed']) || !empty($_POST['_framed']));
 
 // start session with requested task
 rcmail_startup($_task);
@@ -83,7 +83,7 @@
 
 
 // add framed parameter
-if ($_GET['_framed'] || $_POST['_framed'])
+if ($_framed)
   {
   $COMM_PATH .= '&_framed=1';
   $SESS_HIDDEN_FIELD = "\n".'<input type="hidden" name="_framed" value="1" />';
@@ -95,7 +95,7 @@
 
 
 // error steps
-if ($_action=='error' && strlen($_GET['_code']))
+if ($_action=='error' && !empty($_GET['_code']))
   {
   raise_error(array('code' => hexdec($_GET['_code'])), FALSE, TRUE);
   }
@@ -107,11 +107,11 @@
   $host = $_POST['_host'] ? $_POST['_host'] : $CONFIG['default_host'];
   
   // check if client supports cookies
-  if (!$_COOKIE[session_name()])
+  if (empty($_COOKIE))
     {
     show_message("cookiesdisabled", 'warning');
     }
-  else if ($_POST['_user'] && $_POST['_pass'] && rcmail_login($_POST['_user'], $_POST['_pass'], $host))
+  else if (isset($_POST['_user']) && isset($_POST['_pass']) && rcmail_login($_POST['_user'], $_POST['_pass'], $host))
     {
     // send redirect
     header("Location: $COMM_PATH");
@@ -143,7 +143,7 @@
 
 
 // log in to imap server
-if ($_SESSION['user_id'] && $_task=='mail')
+if (!empty($_SESSION['user_id']) && $_task=='mail')
   {
   $conn = $IMAP->connect($_SESSION['imap_host'], $_SESSION['username'], decrypt_passwd($_SESSION['password']));
   if (!$conn)
@@ -155,12 +155,12 @@
 
 
 // not logged in -> set task to 'login
-if (!$_SESSION['user_id'])
+if (empty($_SESSION['user_id']))
   $_task = 'login';
 
 
 
-// set taask and action to client
+// set task and action to client
 $script = sprintf("%s.set_env('task', '%s');", $JS_OBJECT_NAME, $_task);
 if (!empty($_action))
   $script .= sprintf("\n%s.set_env('action', '%s');", $JS_OBJECT_NAME, $_action);
diff --git a/program/include/main.inc b/program/include/main.inc
index 7173917..0a63b68 100644
--- a/program/include/main.inc
+++ b/program/include/main.inc
@@ -219,7 +219,7 @@
   $javascript = "var $JS_OBJECT_NAME = new rcube_webmail();\n";
   $javascript .= "$JS_OBJECT_NAME.set_env('comm_path', '$COMM_PATH');\n";
 
-  if ($_GET['_framed'] || $_POST['_framed'])
+  if (!empty($GLOBALS['_framed']))
     $javascript .= "$JS_OBJECT_NAME.set_env('framed', true);\n";
 
   $OUTPUT->add_script($javascript);
@@ -339,7 +339,7 @@
   {
   global $OUTPUT, $JS_OBJECT_NAME, $REMOTE_REQUEST;
 
-  $framed = ($_GET['framed'] || $_POST['_framed']);
+  $framed = $GLOBALS['_framed'];
   $command = sprintf("display_message('%s', '%s');",
                      addslashes(rep_specialchars_output(rcube_label($message))),
                      $type);
@@ -837,7 +837,7 @@
     $input = new textfield($attrib);
 
   // use value from post
-  if ($_POST[$fname])
+  if (!empty($_POST[$fname]))
     $value = $_POST[$fname];
 
   $out = $input->show($value);
diff --git a/program/include/rcube_db.inc b/program/include/rcube_db.inc
index fe838da..9c76cb3 100755
--- a/program/include/rcube_db.inc
+++ b/program/include/rcube_db.inc
@@ -51,8 +51,10 @@
     // Connect to specific database 
     function dsn_connect($dsn)
     {
-        // Use persistent connections if available
+        $dsn_array = DB::parseDSN($dsn);
+        $this->db_provider = $dsn_array['phptype'];
         
+        // Use persistent connections if available
         $dbh = DB::connect($dsn, array('persistent' => $true));
 
         if (DB::isError($dbh))
@@ -61,6 +63,12 @@
                         'line' => __LINE__,
                         'file' => __FILE__,
                         'message' => $dbh->getMessage()), TRUE, FALSE);
+        else if ($this->db_provider=='sqlite')
+        {
+            if (!is_file($dsn_array['database']) || !filesize($dsn_array['database']))
+                $this->_sqlite_create_database($dbh, 'SQL/sqlite.initial.sql');
+        }
+        
         return $dbh;
     }
 
@@ -96,22 +104,23 @@
     function query($query)
     {
         // Read or write ?
-        
         if (strtolower(trim(substr($query,0,6)))=='select')
             $mode='r';
         else
-            {
             $mode='w';
-            }
         
-        $this->db_connect($mode);           
-    
+        $this->db_connect($mode);
+
+        if ($this->db_provider == 'sqlite')
+            $query = $this->_sqlite_prepare_query($query);
+            
         $result = $this->db_handle->query($query);
         
         if (DB::isError($result))
-            raise_error( array('code' => 500, 'type' => 'db', 'line' => __LINE__, 
-                         'file' => __FILE__, 
-                         'message' => $result->getMessage()), TRUE, FALSE);
+            raise_error(array('code' => 500, 'type' => 'db',
+                              'line' => __LINE__, 
+                              'file' => __FILE__, 
+                              'message' => $result->getMessage()), TRUE, FALSE);
         
         return $this->_add_result($result, $query);
     }
@@ -119,6 +128,9 @@
     function db_execute ($query)
     {
         db_connect('w');
+
+        if ($this->db_provider == 'sqlite')
+            $query = $this->_sqlite_prepare_query($query);
 
         $result = $this->db_handle->query($query);
 
@@ -162,7 +174,10 @@
                 
             case 'mysql': // This is unfortuneate
                 return mysql_insert_id($this->db_handle);
-                
+
+            case 'sqlite':
+                return sqlite_last_insert_rowid($this->db_handle->connection);
+
             default:
                 die("portability issue with this database, please have the developer fix");
         }
@@ -209,6 +224,40 @@
         return FALSE;
     }
 
+
+    // create a sqlite database from a file
+    function _sqlite_create_database($dbh, $fileName)
+    {
+        if (empty($fileName) || !is_string($fileName))
+            return ;
+
+        $fd = fopen($fileName, 'r');
+        if (!$fd)
+            return ;
+
+        $data = '';
+        while ($line = fgets($fd, 4096))
+            $data .= $line;
+
+        fclose($fd);
+        sqlite_exec($dbh->connection, $data);
+    }
+
+    // transform a query so that it is sqlite2 compliant
+    function _sqlite_prepare_query($query)
+    {
+        if (!is_string($query))
+            return ($query);
+
+        $search = array('/NOW\(\)/',
+                        '/`/');
+        $replace = array("datetime('now')",
+                         '"');
+        $query = preg_replace($search, $replace, $query);
+
+        return ($query);
+    }
+    
 }
 
 ?>
\ No newline at end of file
diff --git a/program/include/rcube_imap.inc b/program/include/rcube_imap.inc
index e743214..127409d 100644
--- a/program/include/rcube_imap.inc
+++ b/program/include/rcube_imap.inc
@@ -35,6 +35,7 @@
   var $mailbox = 'INBOX';
   var $list_page = 1;
   var $page_size = 10;
+  var $delimiter = NULL;
   var $caching_enabled = FALSE;
   var $default_folders = array('inbox', 'drafts', 'sent', 'junk', 'trash');
   var $cache = array();
@@ -153,6 +154,14 @@
     }
 
 
+  function get_hierarchy_delimiter()
+    {
+    if ($this->conn && empty($this->delimiter))
+      $this->delimiter = iil_C_GetHierarchyDelimiter($this->conn);
+
+    return $this->delimiter;
+    }
+
   // public method for mailbox listing
   // convert mailbox name with root dir first
   function list_mailboxes($root='', $filter='*')
diff --git a/program/js/app.js b/program/js/app.js
index 87fd255..30d8704 100644
--- a/program/js/app.js
+++ b/program/js/app.js
@@ -1985,9 +1985,11 @@
       var item, reg, text_obj;
       var s_mbox = String(mbox).toLowerCase().replace(this.mbox_expression, '');
       var s_current = this.env.mailbox.toLowerCase().replace(this.mbox_expression, '');
-      for (var n=0; n<this.gui_objects.mailboxlist.childNodes.length; n++)
+      var nodes = this.gui_objects.mailboxlist.getElementsByTagName('LI');
+      
+      for (var n=0; n<nodes.length; n++)
         {
-        item = this.gui_objects.mailboxlist.childNodes[n];
+        item = nodes[n];
         if (item.className && item.className.indexOf('mailbox '+s_mbox+' ')>=0)
           this.set_classname(item, 'selected', true);
         else if (item.className && item.className.indexOf('mailbox '+s_current)>=0)
diff --git a/program/localization/da/labels.inc b/program/localization/da/labels.inc
new file mode 100644
index 0000000..bec439d
--- /dev/null
+++ b/program/localization/da/labels.inc
@@ -0,0 +1,175 @@
+<?php
+
+/*
+ +-----------------------------------------------------------------------+
+ | language/da/labels.inc                                                |
+ |                                                                       |
+ | Language file of the RoundCube Webmail client                         |
+ | Copyright (C) 2005, RoundQube Dev. - Switzerland                      |
+ | Licensed under the GNU GPL                                            |
+ |                                                                       |
+ +-----------------------------------------------------------------------+
+ | Author: Thomas Bruederli <roundcube@gmail.com>                        |
+ +-----------------------------------------------------------------------+
+ | Danish translation: Martin Moeller <martin@liga.dk>                   |
+ +-----------------------------------------------------------------------+
+ 
+ $Id$
+
+*/
+
+$labels = array();
+
+// login page
+$labels['username']  = 'Brugernavn';
+$labels['password']  = 'Adgangskode';
+$labels['server']    = 'Server';
+$labels['login']     = 'Log p�';
+
+// taskbar
+$labels['logout']   = 'Log af';
+$labels['mail']     = 'Email';
+$labels['settings'] = 'Personlige indstillinger';
+$labels['addressbook'] = 'Adressebog';
+
+// mailbox names
+$labels['inbox']  = 'Indbakke';
+$labels['sent']   = 'Sendt post';
+$labels['trash']  = 'Skrald';
+$labels['drafts'] = 'Klader';
+$labels['junk']   = 'Ragelse';
+
+// message listing
+$labels['subject'] = 'Emne';
+$labels['from']    = 'Afsender';
+$labels['to']      = 'Modtager';
+$labels['cc']      = 'Kopi til';
+$labels['bcc']     = 'BCC';
+$labels['replyto'] = 'Svar til';
+$labels['date']    = 'Dato';
+$labels['size']    = 'St�rrelse';
+$labels['priority'] = 'Prioritet';
+$labels['organization'] = 'Organisation';
+
+// aliases
+$labels['reply-to'] = $labels['replyto'];
+
+$labels['mailboxlist'] = 'Foldere';
+$labels['messagesfromto'] = 'Beskeder $from til $to af $count';
+$labels['messagenrof'] = 'Besked $nr af $count';
+
+$labels['moveto']   = 'flyt til...';
+$labels['download'] = 'download';
+
+$labels['filename'] = 'Filnavn';
+$labels['filesize'] = 'Filst�rrelse';
+
+$labels['preferhtml'] = 'Foretr�k HTML';
+$labels['htmlmessage'] = 'HTML besked';
+$labels['prettydate'] = 'P�n datovisning';
+
+$labels['addtoaddressbook'] = 'Tilf�j til adressebogen';
+
+// weekdays short
+$labels['sun'] = 'S�n';
+$labels['mon'] = 'Man';
+$labels['tue'] = 'Tir';
+$labels['wed'] = 'Ons';
+$labels['thu'] = 'Tor';
+$labels['fri'] = 'Fre';
+$labels['sat'] = 'L�r';
+
+// weekdays long
+$labels['sunday']    = 'S�ndag';
+$labels['monday']    = 'Mandag';
+$labels['tuesday']   = 'Tirsdag';
+$labels['wednesday'] = 'Onsdag';
+$labels['thursday']  = 'Torsdag';
+$labels['friday']    = 'Fredag';
+$labels['saturday']  = 'L�rdag';
+
+$labels['today'] = 'I dag';
+
+// toolbar buttons
+$labels['writenewmessage']  = 'Opret en ny besked';
+$labels['replytomessage']   = 'Svar p� denne besked';
+$labels['forwardmessage']   = 'Videresend denne besked';
+$labels['deletemessage']    = 'Flyt beskeden til skrald';
+$labels['printmessage']     = 'Udskriv denne besked';
+$labels['previousmessages'] = 'Vis forrige s�t beskeder';
+$labels['nextmessages']     = 'Vis n�ste s�t beskeder';
+$labels['backtolist']       = 'Tilbage til beskedlisten';
+
+$labels['select'] = 'V�lg';
+$labels['all'] = 'Alle';
+$labels['none'] = 'Ingen';
+$labels['unread'] = 'Ul�ste';
+
+// message compose
+$labels['compose']  = 'Forfat en besked';
+$labels['sendmessage']  = 'Send beskeden nu';
+$labels['addattachment']  = 'Vedh�ft en fil';
+
+$labels['attachments'] = 'Vedh�ftninger';
+$labels['upload'] = 'Upload';
+$labels['close']  = 'Luk';
+
+$labels['low']     = 'Lav';
+$labels['lowest']  = 'Lavest';
+$labels['normal']  = 'Normal';
+$labels['high']    = 'H�j';
+$labels['highest'] = 'H�jest';
+
+$labels['showimages'] = 'Vis billeder';
+
+
+// address boook
+$labels['name']      = 'Vist navn';
+$labels['firstname'] = 'Fornavn';
+$labels['surname']   = 'Efternavn';
+$labels['email']     = 'Email';
+
+$labels['addcontact'] = 'Tilf�j en ny kontakt';
+$labels['editcontact'] = 'Redig�r kontakt';
+
+$labels['edit']   = 'Redig�r';
+$labels['cancel'] = 'Afbryd';
+$labels['save']   = 'Gem';
+$labels['delete'] = 'Slet';
+
+$labels['newcontact']     = 'Opret nyt kontaktkort';
+$labels['deletecontact']  = 'Slet valgte kontakter';
+$labels['composeto']      = 'Skriv brev til';
+$labels['contactsfromto'] = 'Kontakter $from til $to af $count';
+
+
+// settings
+$labels['settingsfor']  = 'Indstillinger for';
+
+$labels['preferences']  = 'Pr�ferencer';
+$labels['userpreferences']  = 'Brugerpr�ferencer';
+$labels['editpreferences']  = 'Redig�r brugerpr�ferencer';
+
+$labels['identities']  = 'Identiteter';
+$labels['manageidentities']  = 'Styr identiteterne for denne konto';
+$labels['newidentity']  = 'Ny identitet';
+
+$labels['newitem']  = 'Nyt punkt';
+$labels['edititem']  = 'Redig�r punkt';
+
+$labels['setdefault']  = 'S�t standard';
+$labels['language']  = 'Sprog';
+$labels['timezone']  = 'Tidszone';
+$labels['pagesize']  = 'R�kker per side';
+
+
+$labels['folders']  = 'Foldere';
+$labels['foldername']  = 'Foldernavn';
+$labels['subscribed']  = 'Abonneret';
+$labels['create']  = 'Opret';
+$labels['createfolder']  = 'Opret ny folder';
+$labels['deletefolder']  = 'Slet folder';
+$labels['managefolders']  = 'Styr foldere';
+
+
+?>
diff --git a/program/localization/da/messages.inc b/program/localization/da/messages.inc
new file mode 100644
index 0000000..5cbe985
--- /dev/null
+++ b/program/localization/da/messages.inc
@@ -0,0 +1,58 @@
+<?php
+
+/*
+ +-----------------------------------------------------------------------+
+ | language/da/messages.inc                                              |
+ |                                                                       |
+ | Language file of the RoundCube Webmail client                         |
+ | Copyright (C) 2005, RoundCube Dev. - Switzerland                      |
+ | Licensed under the GNU GPL                                            |
+ |                                                                       |
+ +-----------------------------------------------------------------------+
+ | Author: Thomas Bruederli <roundcube@gmail.com>                        |
+ +-----------------------------------------------------------------------+
+ | Danish translation : Martin Moeller <martin@liga.dk>                  |
+ +-----------------------------------------------------------------------+
+
+ $Id$
+
+*/
+
+$messages = array();
+
+$messages['loginfailed']  = 'Det lykkedes ikke at logge p�';
+
+$messages['cookiesdisabled'] = 'Din browser accepterer ikke cookies';
+
+$messages['sessionerror'] = 'Din session er ugyldig eller udl�bet';
+
+$messages['imaperror'] = 'Forbindelse til IMAP serveren fejlede';
+
+$messages['nomessagesfound'] = 'Der blev ikke fundet nogen beskeder i denne postkasse';
+
+$messages['loggedout'] = 'Du er nu logget af webmail. Farvel s� l�nge!';
+
+$messages['mailboxempty'] = 'Postkassen er tom!';
+
+$messages['loadingdata'] = 'Indl�ser data...';
+
+$messages['messagesent'] = 'Beskeden blev sendt korrekt';
+
+$messages['successfullysaved'] = 'Det lykkedes at gemme';
+
+$messages['addedsuccessfully'] = 'Kontakten blev tilf�jet adressebogen';
+
+$messages['contactexists'] = 'Der er allerede en kontakt med denne email adresse';
+
+$messages['blockedimages'] = 'For at beskytte dit privatliv er billeder fra internet servere blokeret i denne besked.';
+
+$messages['encryptedmessage'] = 'Dette er en krypteret besked og kan ikke vises. Beklager!';
+
+$messages['nocontactsfound'] = 'Ingen kontakter blev fundet';
+
+$messages['sendingfailed'] = 'Kunne ikke sende beskeden';
+
+$messages['errorsaving'] = 'Der opstod en fejl ved lagring af data';
+
+
+?>
diff --git a/program/localization/es/labels.inc b/program/localization/es/labels.inc
new file mode 100644
index 0000000..f0fdca5
--- /dev/null
+++ b/program/localization/es/labels.inc
@@ -0,0 +1,171 @@
+<?php
+
+/*
+ +-----------------------------------------------------------------------+
+ | language/en/labels.inc                                                |
+ |                                                                       |
+ | Language file of the RoundCube Webmail client                         |
+ | Licensed under the GNU GPL                                            |
+ |                                                                       |
+ +-----------------------------------------------------------------------+
+ | Author: David Grajal Blanco <dgrabla@gmail.com>                        |
+ +-----------------------------------------------------------------------+
+
+ $Id: labels.inc,v 1.1.1.1 2005/09/17
+
+*/
+
+$labels = array();
+
+// login page
+$labels['username']  = 'Nombre de usuario';
+$labels['password']  = 'Contrase�a';
+$labels['server']    = 'Servidor';
+$labels['login']     = 'Entrar';
+
+// taskbar
+$labels['logout']   = 'Cerrar sesi�n';
+$labels['mail']     = 'E-Mail';
+$labels['settings'] = 'Configuraci�n';
+$labels['addressbook'] = 'Contactos';
+
+// mailbox names
+$labels['inbox']  = 'Entrada';
+$labels['sent']   = 'Enviados';
+$labels['trash']  = 'Papelera';
+$labels['drafts'] = 'Borradores';
+$labels['junk']   = 'Basura';
+
+// message listing
+$labels['subject'] = 'Asunto';
+$labels['from']    = 'Remitente';
+$labels['to']      = 'Destinatario';
+$labels['cc']      = 'CC';
+$labels['bcc']     = 'BCC';
+$labels['replyto'] = 'Responder';
+$labels['date']    = 'Fecha';
+$labels['size']    = 'Tama�o';
+$labels['priority'] = 'Prioridad';
+$labels['organization'] = 'Organizaci�n';
+
+// aliases
+$labels['reply-to'] = $labels['replyto'];
+
+$labels['mailboxlist'] = 'Carpetas';
+$labels['messagesfromto'] = 'Mensajes desde $from a $to de $count';
+$labels['messagenrof'] = 'Mensaje $nr de $count';
+
+$labels['moveto']   = 'mover a...';
+$labels['download'] = 'descargar';
+
+$labels['filename'] = 'Nombre del fichero';
+$labels['filesize'] = 'Tama�o del fichero';
+
+$labels['preferhtml'] = 'Prefiero HTML';
+$labels['htmlmessage'] = 'Mensaje HTML';
+
+$labels['addtoaddressbook'] = 'A�adir a contactos';
+
+// weekdays short
+$labels['sun'] = 'D';
+$labels['mon'] = 'L';
+$labels['tue'] = 'M';
+$labels['wed'] = 'X';
+$labels['thu'] = 'J';
+$labels['fri'] = 'V';
+$labels['sat'] = 'S';
+
+// weekdays long
+$labels['sunday']    = 'Domingo';
+$labels['monday']    = 'Lunes';
+$labels['tuesday']   = 'Martes';
+$labels['wednesday'] = 'Miercoles';
+$labels['thursday']  = 'Jueves';
+$labels['friday']    = 'Viernes';
+$labels['saturday']  = 'S�bado';
+
+$labels['today'] = 'Hoy';
+
+// toolbar buttons
+$labels['writenewmessage']  = 'Crear nuevo mensaje';
+$labels['replytomessage']   = 'Responder al mensaje';
+$labels['forwardmessage']   = 'Reenviar mensaje';
+$labels['deletemessage']    = 'Move message to trash';
+$labels['printmessage']     = 'Imprimir este mensaje';
+$labels['previousmessages'] = 'Mostrar mensajes anteriores';
+$labels['nextmessages']     = 'Mostrar mensajes siguientes';
+$labels['backtolist']       = 'Volver a la lista de mensajes';
+
+$labels['select'] = 'Seleccionar';
+$labels['all'] = 'Todos';
+$labels['none'] = 'Ninguno';
+$labels['unread'] = 'No leidos';
+
+// message compose
+$labels['compose']  = 'Escribir un mensaje';
+$labels['sendmessage']  = 'Enviar ahora el mensaje';
+$labels['addattachment']  = 'A�adir un fichero';
+
+$labels['attachments'] = 'Adjuntos';
+$labels['upload'] = 'Subir';
+$labels['close']  = 'Cerrar';
+
+$labels['low']     = 'Bajo';
+$labels['lowest']  = 'Baj�simo';
+$labels['normal']  = 'Normal';
+$labels['high']    = 'Alto';
+$labels['highest'] = 'Alt�simo';
+
+$labels['showimages'] = 'Mostrar im�genes';
+
+
+// address boook
+$labels['name']      = 'Mostrar nombre';
+$labels['firstname'] = 'Nombre';
+$labels['surname']   = 'Apellido';
+$labels['email']     = 'E-Mail';
+
+$labels['addcontact'] = 'A�adir nuevo contacto';
+$labels['editcontact'] = 'Editar contacto';
+
+$labels['edit']   = 'Editar';
+$labels['cancel'] = 'Cancelar';
+$labels['save']   = 'Salvar';
+$labels['delete'] = 'Eliminar';
+
+$labels['newcontact']     = 'Crear nuevo contacto';
+$labels['deletecontact']  = 'Eliminar contactos seleccionados';
+$labels['composeto']      = 'Redactar correo a';
+$labels['contactsfromto'] = 'Contactos $from a $to de $count';
+
+
+// settings
+$labels['settingsfor']  = 'Configuraci�n para';
+
+$labels['preferences']  = 'Preferencias';
+$labels['userpreferences']  = 'Preferencias de usuario';
+$labels['editpreferences']  = 'Editar preferencias de usuario';
+
+$labels['identities']  = 'Identidades';
+$labels['manageidentities']  = 'Gestionar identidades para esta cuenta';
+$labels['newidentity']  = 'Nueva identidad';
+
+$labels['newitem']  = 'Nuevo';
+$labels['edititem']  = 'Editar';
+
+$labels['setdefault']  = 'Seleccionar opci�n por defecto';
+$labels['language']  = 'Idioma';
+$labels['timezone']  = 'Zona horaria';
+$labels['pagesize']  = 'Filas por p�gina';
+
+
+$labels['folders']  = 'Carpetas';
+$labels['foldername']  = 'Nombre de carpeta';
+$labels['subscribed']  = 'Suscribirse';
+$labels['create']  = 'Crear';
+$labels['createfolder']  = 'Crear nueva carpeta';
+$labels['deletefolder']  = 'Eliminar carpeta';
+$labels['managefolders']  = 'Gestionar carpetas';
+
+
+?>
diff --git a/program/localization/es/messages.inc b/program/localization/es/messages.inc
new file mode 100644
index 0000000..cc0c6b1
--- /dev/null
+++ b/program/localization/es/messages.inc
@@ -0,0 +1,56 @@
+<?php
+
+/*
+ +-----------------------------------------------------------------------+
+ | language/en/messages.inc                                              |
+ |                                                                       |
+ | Language file of the RoundCube Webmail client                         |
+ | Licensed under the GNU GPL                                            |
+ |                                                                       |
+ +-----------------------------------------------------------------------+
+ | Author: David Grajal <dgrabla@gmail.com>                              |
+ +-----------------------------------------------------------------------+
+
+ $Id: messages.inc,v 1.1.1.1 2005/09/17 
+
+*/
+
+$messages = array();
+
+$messages['loginfailed']  = 'Contrase�a incorrecta';
+
+$messages['cookiesdisabled'] = 'Su navegador no acepta cookies';
+
+$messages['sessionerror'] = 'Su sesi�n no existe o ha expirado';
+
+$messages['imaperror'] = 'Fallo de conexi�n con el servidor IMAP';
+
+$messages['nomessagesfound'] = 'No se han encontrado mensajes en este buz�n';
+
+$messages['loggedout'] = 'Ha cerrado la sesi�n. �Hasta pronto!';
+
+$messages['mailboxempty'] = 'El buz�n esta vacio';
+
+$messages['loadingdata'] = 'Cargando datos...';
+
+$messages['messagesent'] = 'Mensaje enviado correctamente';
+
+$messages['successfullysaved'] = 'guardado correctamente';
+
+$messages['addedsuccessfully'] = 'Contacto a�adido correctamente a la libreta de direcciones';
+
+$messages['contactexists'] = 'Ya existe un contacto con esta direcci�n de correo';
+
+$messages['blockedimages'] = 'Para proteger su privacidad, las im�genes remotas han sido bloqueadas en este mensaje';
+
+$messages['encryptedmessage'] = 'Este es un mensaje cifrado y no puede
+ser mostrado. �Lo siento!';
+
+$messages['nocontactsfound'] = 'No hay contactos';
+
+$messages['sendingfailed'] = 'Error al enviar mensaje';
+
+$messages['errorsaving'] = 'Ocurri� un error mientras se guardaba';
+
+
+?>
diff --git a/program/localization/fr/labels.inc b/program/localization/fr/labels.inc
new file mode 100644
index 0000000..5b92518
--- /dev/null
+++ b/program/localization/fr/labels.inc
@@ -0,0 +1,172 @@
+<?php
+
+/*
+ +-----------------------------------------------------------------------+
+ | language/fr/labels.inc                                                |
+ |                                                                       |
+ | Language file of the RoundCube Webmail client                         |
+ | Copyright (C) 2005, RoundQube Dev. - Switzerland                      |
+ | Licensed under the GNU GPL                                            |
+ |                                                                       |
+ +-----------------------------------------------------------------------+
+ | Author: aldweb <info@aldweb.com>                                      |
+ +-----------------------------------------------------------------------+
+
+ $Id$
+
+*/
+
+$labels = array();
+
+// login page
+$labels['username']  = 'ID utilisateur';
+$labels['password']  = 'Mot de passe';
+$labels['server']    = 'Serveur';
+$labels['login']     = 'Connexion';
+
+// taskbar
+$labels['logout']   = 'Quitter';
+$labels['mail']     = 'e-Mail';
+$labels['settings'] = 'Pr�f�rences';
+$labels['addressbook'] = 'Carnet d\'adresses';
+
+// mailbox names
+$labels['inbox']  = 'Bo�te de r�ception';
+$labels['sent']   = 'Messages envoy�s';
+$labels['trash']  = 'Corbeille';
+$labels['drafts'] = 'Brouillons';
+$labels['junk']   = 'A trier';
+
+// message listing
+$labels['subject'] = 'Sujet';
+$labels['from']    = 'De';
+$labels['to']      = 'A';
+$labels['cc']      = 'Cc';
+$labels['bcc']     = 'Cci';
+$labels['replyto'] = 'R�pondre �';
+$labels['date']    = 'Date';
+$labels['size']    = 'Taille';
+$labels['priority'] = 'Priorit�';
+$labels['organization'] = 'Organisation';
+
+// aliases
+$labels['reply-to'] = $labels['replyto'];
+
+$labels['mailboxlist'] = 'Dossiers';
+$labels['messagesfromto'] = 'Messages $from � $to sur $count';
+$labels['messagenrof'] = 'Message $nr sur $count';
+
+$labels['moveto']   = 'D�placer vers...';
+$labels['download'] = 'T�l�charger';
+
+$labels['filename'] = 'Nom du fichier';
+$labels['filesize'] = 'Taille du fichier';
+
+$labels['preferhtml'] = 'Pr�f�rer HTML';
+$labels['htmlmessage'] = 'Message HTML';
+
+$labels['addtoaddressbook'] = 'Ajouter au carnet d\'adresses';
+
+// weekdays short
+$labels['sun'] = 'Dim';
+$labels['mon'] = 'Lun';
+$labels['tue'] = 'Mar';
+$labels['wed'] = 'Mer';
+$labels['thu'] = 'Jeu';
+$labels['fri'] = 'Ven';
+$labels['sat'] = 'Sam';
+
+// weekdays long
+$labels['sunday']    = 'Dimanche';
+$labels['monday']    = 'Lundi';
+$labels['tuesday']   = 'Mardi';
+$labels['wednesday'] = 'Mercredi';
+$labels['thursday']  = 'Jeudi';
+$labels['friday']    = 'Vendredi';
+$labels['saturday']  = 'Samedi';
+
+$labels['today'] = 'Aujourd\'hui';
+
+// toolbar buttons
+$labels['writenewmessage']  = 'Cr�er un nouveau message';
+$labels['replytomessage']   = 'R�pondre au message';
+$labels['forwardmessage']   = 'Transmettre le message';
+$labels['deletemessage']    = 'D�placer le message dans la corbeille';
+$labels['printmessage']     = 'Imprimer ce message';
+$labels['previousmessages'] = 'Voir les messages pr�c�dents';
+$labels['nextmessages']     = 'Voir les messages suivants';
+$labels['backtolist']       = 'Retourner � la liste des messages';
+
+$labels['select'] = 'S�lectionner';
+$labels['all'] = 'Tous';
+$labels['none'] = 'Aucun';
+$labels['unread'] = 'Non lus';
+
+// message compose
+$labels['compose']  = 'Composer un nouveau message';
+$labels['sendmessage']  = 'Envoyer le message maintenant';
+$labels['addattachment']  = 'Joindre un fichier';
+
+$labels['attachments'] = 'Attachments';
+$labels['upload'] = 'Joindre';
+$labels['close']  = 'Fermer';
+
+$labels['low']     = 'Basse';
+$labels['lowest']  = 'Tr�s basse';
+$labels['normal']  = 'Normale';
+$labels['high']    = 'Elev�e';
+$labels['highest'] = 'Tr�s �lev�e';
+
+$labels['showimages'] = 'Montrer les images';
+
+
+// address boook
+$labels['name']      = 'Nom � afficher';
+$labels['firstname'] = 'Pr�nom';
+$labels['surname']   = 'Nom';
+$labels['email']     = 'e-Mail';
+
+$labels['addcontact'] = 'Ajouter un nouveau contact';
+$labels['editcontact'] = 'Editer le contact';
+
+$labels['edit']   = 'Editer';
+$labels['cancel'] = 'Annuler';
+$labels['save']   = 'Sauvegarder';
+$labels['delete'] = 'Supprimer';
+
+$labels['newcontact']     = 'Cr�er un nouveau contact';
+$labels['deletecontact']  = 'Supprimer les contacts s�lectionn�s';
+$labels['composeto']      = 'Ecrire un message �';
+$labels['contactsfromto'] = 'Contacts $from � $to sur $count';
+
+
+// settings
+$labels['settingsfor']  = 'Param�tres pour';
+
+$labels['preferences']  = 'Pr�f�rences';
+$labels['userpreferences']  = 'Pr�f�rences utilisateur';
+$labels['editpreferences']  = 'Editer les pr�f�rences utilisateur';
+
+$labels['identities']  = 'Identit�s';
+$labels['manageidentities']  = 'G�rer les identit�s pour ce compte';
+$labels['newidentity']  = 'Nouvelle identit�';
+
+$labels['newitem']  = 'Nouvel �l�ment';
+$labels['edititem']  = 'Editer l\'�l�ment';
+
+$labels['setdefault']  = 'Param�tres par d�faut';
+$labels['language']  = 'Langue';
+$labels['timezone']  = 'Fuseau horaire';
+$labels['pagesize']  = 'nombre de lignes par page';
+
+
+$labels['folders']  = 'Dossiers';
+$labels['foldername']  = 'Nom du dossier';
+$labels['subscribed']  = 'Abonn�';
+$labels['create']  = 'Cr�er';
+$labels['createfolder']  = 'Cr�er un nouveau dossier';
+$labels['deletefolder']  = 'Supprimer le dossier';
+$labels['managefolders']  = 'G�rer les dossiers';
+
+
+?>
diff --git a/program/localization/fr/messages.inc b/program/localization/fr/messages.inc
new file mode 100644
index 0000000..0ecfb76
--- /dev/null
+++ b/program/localization/fr/messages.inc
@@ -0,0 +1,56 @@
+<?php
+
+/*
+ +-----------------------------------------------------------------------+
+ | language/fr/messages.inc                                              |
+ |                                                                       |
+ | Language file of the RoundCube Webmail client                         |
+ | Copyright (C) 2005, RoundCube Dev. - Switzerland                      |
+ | Licensed under the GNU GPL                                            |
+ |                                                                       |
+ +-----------------------------------------------------------------------+
+ | Author: aldweb <info@aldweb.com>                                      |
+ +-----------------------------------------------------------------------+
+
+ $Id$
+
+*/
+
+$messages = array();
+
+$messages['loginfailed']  = 'Erreur de connexion';
+
+$messages['cookiesdisabled'] = 'Votre navigateur n\'accepte pas les cookies';
+
+$messages['sessionerror'] = 'Votre session n\'est pas valide ou a expir�';
+
+$messages['imaperror'] = 'Erreur de connexion au serveur IMAP';
+
+$messages['nomessagesfound'] = 'Auncun message trouv� dans cette bo�te aux lettres';
+
+$messages['loggedout'] = 'Vous venez de vous d�connecter avec succ�s. Au revoir !';
+
+$messages['mailboxempty'] = 'Bo�te aux lettres vide';
+
+$messages['loadingdata'] = 'Chargement des donn�es en cours...';
+
+$messages['messagesent'] = 'Message envoy�';
+
+$messages['successfullysaved'] = 'Sauvegarde effectu�e';
+
+$messages['addedsuccessfully'] = 'Contact ajout� dans le carnet d\'adresses';
+
+$messages['contactexists'] = 'Un contact avec cette adresse e-Mail existe d�j�';
+
+$messages['blockedimages'] = 'Afin de pr�server votre intimit�, les images distantes ont �t� bloqu�es dans ce message.';
+
+$messages['encryptedmessage'] = 'Ceci est un message crypt� et il ne peut pas �tre affich�. D�sol� !';
+
+$messages['nocontactsfound'] = 'Aucun contact trouv�';
+
+$messages['sendingfailed'] = 'Le message n\'a pas �t� envoy�';
+
+$messages['errorsaving'] = 'Une erreur est apparue pendant la sauvegarde';
+
+
+?>
diff --git a/program/localization/it/labels.inc b/program/localization/it/labels.inc
new file mode 100644
index 0000000..3eba8b6
--- /dev/null
+++ b/program/localization/it/labels.inc
@@ -0,0 +1,172 @@
+<?php
+
+/*
+ +-----------------------------------------------------------------------+
+ | language/it/labels.inc                                                |
+ |                                                                       |
+ | Language file of the RoundCube Webmail client                         |
+ | Copyright (C) 2005, RoundQube Dev. - Switzerland                      |
+ | Licensed under the GNU GPL                                            |
+ |                                                                       |
+ +-----------------------------------------------------------------------+
+ | Author: APaella <apaella@yahoo.it>                                    |
+ +-----------------------------------------------------------------------+
+
+ $Id$
+
+*/
+
+$labels = array();
+
+// login page
+$labels['username']  = 'Username';
+$labels['password']  = 'Password';
+$labels['server']    = 'Server';
+$labels['login']     = 'Login';
+
+// taskbar
+$labels['logout']   = 'Logout';
+$labels['mail']     = 'E-Mail';
+$labels['settings'] = 'Impostazioni personali';
+$labels['addressbook'] = 'Rubrica';
+
+// mailbox names
+$labels['inbox']  = 'In arrivo';
+$labels['sent']   = 'Spedita';
+$labels['trash']  = 'Cestino';
+$labels['drafts'] = 'Bozze';
+$labels['junk']   = 'Spazzatura';
+
+// message listing
+$labels['subject'] = 'Soggetto';
+$labels['from']    = 'Mittente';
+$labels['to']      = 'A';
+$labels['cc']      = 'Cc';
+$labels['bcc']     = 'Bcc';
+$labels['replyto'] = 'Rispondi a';
+$labels['date']    = 'Data';
+$labels['size']    = 'Dimensione';
+$labels['priority'] = 'Priorit�';
+$labels['organization'] = 'Organizzazione';
+
+// aliases
+$labels['reply-to'] = $labels['replyto'];
+
+$labels['mailboxlist'] = 'Cartelle';
+$labels['messagesfromto'] = 'Messaggi $from a $to di $count';
+$labels['messagenrof'] = 'Messaggio $nr di $count';
+
+$labels['moveto']   = 'sposta in...';
+$labels['download'] = 'scarica';
+
+$labels['filename'] = 'Nome del file';
+$labels['filesize'] = 'Dimensione del file';
+
+$labels['preferhtml'] = 'Preferisci HTML';
+$labels['htmlmessage'] = 'HTML Messaggio';
+
+$labels['addtoaddressbook'] = 'Aggiungi alla rubrica';
+
+// weekdays short
+$labels['sun'] = 'Dom';
+$labels['mon'] = 'Lun';
+$labels['tue'] = 'Mar';
+$labels['wed'] = 'Mer';
+$labels['thu'] = 'Gio';
+$labels['fri'] = 'Ven';
+$labels['sat'] = 'Sab';
+
+// weekdays long
+$labels['sunday']    = 'Domenica';
+$labels['monday']    = 'Luned�';
+$labels['tuesday']   = 'Marted�';
+$labels['wednesday'] = 'Mercoled�';
+$labels['thursday']  = 'Gioved�';
+$labels['friday']    = 'Venerd�';
+$labels['saturday']  = 'Sabato';
+
+$labels['today'] = 'Oggi';
+
+// toolbar buttons
+$labels['writenewmessage']  = 'Crea un nuovo messaggio';
+$labels['replytomessage']   = 'Rispondi al messaggio';
+$labels['forwardmessage']   = 'Inoltra il messaggio';
+$labels['deletemessage']    = 'Sposta il messaggio nel cestino';
+$labels['printmessage']     = 'Stampa questo messaggio';
+$labels['previousmessages'] = 'Mostra i messaggi precedenti';
+$labels['nextmessages']     = 'Mostra i messaggi successivi';
+$labels['backtolist']       = 'Torna all\'elenco dei messaggi';
+
+$labels['select'] = 'Seleziona';
+$labels['all'] = 'Tutto';
+$labels['none'] = 'Nulla';
+$labels['unread'] = 'Non letti';
+
+// message compose
+$labels['compose']  = 'Componi un messaggio';
+$labels['sendmessage']  = 'Spedisci il messaggio ora';
+$labels['addattachment']  = 'Allega un file';
+
+$labels['attachments'] = 'Collegamenti';
+$labels['upload'] = 'Upload';
+$labels['close']  = 'Chiudi';
+
+$labels['low']     = 'Bassma';
+$labels['lowest']  = 'Bassissia';
+$labels['normal']  = 'Normale';
+$labels['high']    = 'Alta';
+$labels['highest'] = 'Altissima';
+
+$labels['showimages'] = 'Mostra immagini';
+
+
+// address boook
+$labels['name']      = 'Nome da visualizzare';
+$labels['firstname'] = 'Nome';
+$labels['surname']   = 'Cognome';
+$labels['email']     = 'E-Mail';
+
+$labels['addcontact'] = 'Aggiungi nuovo contatto';
+$labels['editcontact'] = 'Modifica contatto';
+
+$labels['edit']   = 'Modifica';
+$labels['cancel'] = 'Annulla';
+$labels['save']   = 'Salva';
+$labels['delete'] = 'Elimina';
+
+$labels['newcontact']     = 'Crea una nuova scheda contatto';
+$labels['deletecontact']  = 'Elimina il contatto selezionato';
+$labels['composeto']      = 'Componi una mail per';
+$labels['contactsfromto'] = 'Contatti $from a $to di $count';
+
+
+// settings
+$labels['settingsfor']  = 'Impostazioni per';
+
+$labels['preferences']  = 'Preferenze';
+$labels['userpreferences']  = 'Preferenze utente';
+$labels['editpreferences']  = 'Modifica preferenze utente';
+
+$labels['identities']  = 'Identit�';
+$labels['manageidentities']  = 'Gestisci le identit� per questo account';
+$labels['newidentity']  = 'Nuova identit�';
+
+$labels['newitem']  = 'Nuovo oggetto';
+$labels['edititem']  = 'Modifica oggetto';
+
+$labels['setdefault']  = 'Imposta predefinito';
+$labels['language']  = 'Lingua';
+$labels['timezone']  = 'Fuso orario';
+$labels['pagesize']  = 'Righe per pagina';
+
+
+$labels['folders']  = 'Cartelle';
+$labels['foldername']  = 'nome della cartella';
+$labels['subscribed']  = 'Sottoscritto/a';
+$labels['create']  = 'Creato/a';
+$labels['createfolder']  = 'Crea nuova cartella';
+$labels['deletefolder']  = 'Elimina cartella';
+$labels['managefolders']  = 'Gestisci cartelle';
+
+
+?>
\ No newline at end of file
diff --git a/program/localization/it/messages.inc b/program/localization/it/messages.inc
new file mode 100644
index 0000000..1525ea1
--- /dev/null
+++ b/program/localization/it/messages.inc
@@ -0,0 +1,56 @@
+<?php
+
+/*
+ +-----------------------------------------------------------------------+
+ | language/it/messages.inc                                              |
+ |                                                                       |
+ | Language file of the RoundCube Webmail client                         |
+ | Copyright (C) 2005, RoundCube Dev. - Switzerland                      |
+ | Licensed under the GNU GPL                                            |
+ |                                                                       |
+ +-----------------------------------------------------------------------+
+ | Author: APaella <apaella@yahoo.it>                                    |
+ +-----------------------------------------------------------------------+
+
+ $Id$
+
+*/
+
+$messages = array();
+
+$messages['loginfailed']  = 'Login non riuscito';
+
+$messages['cookiesdisabled'] = 'Il browser non accetta cookie';
+
+$messages['sessionerror'] = 'La sessione � invalida o scaduta.';
+
+$messages['imaperror'] = 'Connessione al server IMAP non riuscita';
+
+$messages['nomessagesfound'] = 'Non ci sono messaggi in questa mailbox';
+
+$messages['loggedout'] = 'Sessione chiusa correttamente. Arrivederci!';
+
+$messages['mailboxempty'] = 'La mailbox � vuota';
+
+$messages['loadingdata'] = 'Sto caricando i dati...';
+
+$messages['messagesent'] = 'Messaggio spedito con successo';
+
+$messages['successfullysaved'] = 'Salvato con successo';
+
+$messages['addedsuccessfully'] = 'Contatto aggiunto con successo alla rubrica';
+
+$messages['contactexists'] = 'Esiste gi� un contatto con questa email';
+
+$messages['blockedimages'] = 'Per proteggere la privacy, le immagini remote in questo messaggio sono bloccate.';
+
+$messages['encryptedmessage'] = 'Questo � un messaggio criptato e non pu� essere visualizzato. Mi dispiace!';
+
+$messages['nocontactsfound'] = 'Nessun contatto trovato';
+
+$messages['sendingfailed'] = 'spedizione del messaggio non riuscita';
+
+$messages['errorsaving'] = 'Errore durante il salvataggio';
+
+
+?>
\ No newline at end of file
diff --git a/program/steps/mail/compose.inc b/program/steps/mail/compose.inc
index 1848acf..03f508b 100644
--- a/program/steps/mail/compose.inc
+++ b/program/steps/mail/compose.inc
@@ -120,7 +120,7 @@
       $header = 'to';
       
       // we have contact id's as get parameters
-      if (strlen($_GET['_to']) && preg_match('/[0-9]+,?/', $_GET['_to']))
+      if (!empty($_GET['_to']) && preg_match('/[0-9]+,?/', $_GET['_to']))
         {
         $a_recipients = array();
         $sql_result = $DB->query(sprintf("SELECT name, email
@@ -138,7 +138,7 @@
         if (sizeof($a_recipients))
           $fvalue = join(', ', $a_recipients);
         }
-      else if (strlen($_GET['_to']))
+      else if (!empty($_GET['_to']))
         $fvalue = $_GET['_to'];
         
     case 'cc':
@@ -165,7 +165,7 @@
     }
     
     
-  if ($fname && $_POST[$fname])
+  if ($fname && !empty($_POST[$fname]))
     $fvalue = $_POST[$fname];
   else if ($header && is_object($REPLY_MESSAGE['headers']))
     {
@@ -282,7 +282,7 @@
   $body = '';
   
   // use posted message body
-  if ($_POST['_message'])
+  if (!empty($_POST['_message']))
     $body = stripslashes($_POST['_message']);
     
   // compose reply-body
@@ -352,6 +352,34 @@
                    $IMAP->decode_header($FORWARD_MESSAGE['headers']->from),
                    $IMAP->decode_header($FORWARD_MESSAGE['headers']->to));
 
+  // add attachments
+  if (!isset($_SESSION['compose']['forward_attachments']) && is_array($FORWARD_MESSAGE['parts']) && sizeof($FORWARD_MESSAGE['parts'])>1)
+    {
+    $temp_dir = rcmail_create_compose_tempdir();
+
+    if (!is_array($_SESSION['compose']['attachments']))
+      $_SESSION['compose']['attachments'] = array();
+  
+    foreach ($FORWARD_MESSAGE['parts'] as $part)
+      {
+      if ($part->disposition != 'attachment')
+        continue;
+
+      $tmp_path = tempnam($temp_dir, 'rcmAttmnt');
+      if ($fp = fopen($tmp_path, 'w'))
+        {
+        fwrite($fp, $IMAP->mime_decode($part->body, $part->headers['content-transfer-encoding']));
+        fclose($fp);
+
+        $_SESSION['compose']['attachments'][] = array('name' => $part->d_parameters['filename'],
+                                                      'mimetype' => $part->ctype_primary . '/' . $part->ctype_secondary,
+                                                      'path' => $tmp_path);
+        }
+      }
+
+    $_SESSION['compose']['forward_attachments'] = TRUE;
+    }
+
   return $prefix.$body;
   }
 
@@ -370,7 +398,7 @@
   $subject = '';
 
   // use subject from post
-  if ($_POST['_subject'])
+  if (isset($_POST['_subject']))
     $subject = stripslashes($_POST['_subject']);
     
   // create a reply-subject
@@ -473,7 +501,7 @@
                        rcube_label('highest')),
                  array(1, 2, 0, 4, 5));
                  
-  $sel = $_POST['_priority'] ? $_POST['_priority'] : 0;
+  $sel = isset($_POST['_priority']) ? $_POST['_priority'] : 0;
 
   $out = $form_start ? "$form_start\n" : '';
   $out .= $selector->show($sel);
@@ -493,13 +521,13 @@
     $hiddenfields = new hiddenfield(array('name' => '_task', 'value' => $GLOBALS['_task']));
     $hiddenfields->add(array('name' => '_action', 'value' => 'send'));
     
-    $form_start = !strlen($attrib['form']) ? '<form name="form" action="./" method="post">' : '';
+    $form_start = empty($attrib['form']) ? '<form name="form" action="./" method="post">' : '';
     $form_start .= "\n$SESS_HIDDEN_FIELD\n";
     $form_start .= $hiddenfields->show();
     }
     
   $form_end = (strlen($MESSAGE_FORM) && !strlen($attrib['form'])) ? '</form>' : '';
-  $form_name = strlen($attrib['form']) ? $attrib['form'] : 'form';
+  $form_name = !empty($attrib['form']) ? $attrib['form'] : 'form';
   
   if (!strlen($MESSAGE_FORM))
     $OUTPUT->add_script("$JS_OBJECT_NAME.gui_object('messageform', '$form_name');");
diff --git a/program/steps/mail/func.inc b/program/steps/mail/func.inc
index 78b6137..6ffde1c 100644
--- a/program/steps/mail/func.inc
+++ b/program/steps/mail/func.inc
@@ -58,6 +58,7 @@
   {
   global $IMAP, $CONFIG, $OUTPUT, $JS_OBJECT_NAME, $COMM_PATH;
   static $s_added_script = FALSE;
+  static $a_mailboxes;
   
   $type = $attrib['type'] ? $attrib['type'] : 'ul';
   $add_attrib = $type=='select' ? array('style', 'class', 'id', 'name', 'onchange') :
@@ -77,37 +78,63 @@
                     rcube_label($attrib['noselection']));
   
   // get mailbox list
-  $a_folders = $IMAP->list_mailboxes();
   $mbox = $IMAP->get_mailbox_name();
   
   // for these mailboxes we have localized labels
   $special_mailboxes = array('inbox', 'sent', 'drafts', 'trash', 'junk');
 
+
+  // build the folders tree
+  if (empty($a_mailboxes))
+    {
+    // get mailbox list
+    $a_folders = $IMAP->list_mailboxes();
+    $delimiter = $IMAP->get_hierarchy_delimiter();
+    $a_mailboxes = array();
+    
+    foreach ($a_folders as $folder)
+      rcmail_build_folder_tree($a_mailboxes, $folder, $delimiter);
+    }
+
+// var_dump($a_mailboxes);
+
+  if ($type=='select')
+    $out .= rcmail_render_folder_tree_select($a_mailboxes, $special_mailboxes, $mbox);
+   else
+    $out .= rcmail_render_folder_tree_html($a_mailboxes, $special_mailboxes, $mbox);
+
+
+/*
   foreach ($a_folders as $i => $folder)
     {
     $zebra_class = $i%2 ? 'even' : 'odd';
-    
-    $folder_lc = strtolower($folder);
+    $folder_prop = $a_subfolders[$folder];
+    $foldername = isset($folder_prop) ? $folder_prop['name'] : $folder;
+
+    $folder_lc = strtolower($foldername);
     if (in_array($folder_lc, $special_mailboxes))
       $foldername = rcube_label($folder_lc);
-    else
-      $foldername = $folder;
         
     if ($unread_count = $IMAP->messagecount($folder, 'UNSEEN'))
       $foldername .= sprintf(' (%d)', $unread_count);
-      
+
+    $indent = isset($folder_prop) ? sprintf(' indent%d', $folder_prop['level']) : '';
+    $indent_str = isset($folder_prop) ? str_repeat('&nbsp;&nbsp;', (int)$folder_prop['level']) : '';
+  
     // compose mailbox line
     if ($type=='select')
-      $out .= sprintf('<option value="%s">%s</option>'."\n",
+      $out .= sprintf('<option value="%s">%s%s</option>'."\n",
                       $folder,
+                      $indent_str,
                       rep_specialchars_output($foldername));
     
     else
-      $out .= sprintf('<li class="mailbox %s %s%s%s"><a href="#%s" onclick="return %s.command(\'list\',\'%s\')" onmouseup="return %s.mbox_mouse_up(\'%s\')">%s</a></li>'."\n",
-                       preg_replace('/[^a-z0-9\-_]/', '', $folder_lc),
+      $out .= sprintf('<li class="mailbox %s %s%s%s%s"><a href="#%s" onclick="return %s.command(\'list\',\'%s\')" onmouseup="return %s.mbox_mouse_up(\'%s\')">%s</a></li>'."\n",
+                       preg_replace('/[^a-z0-9\-_]/', '', strtolower($folder)),
                        $zebra_class,
                        $unread_count ? ' unread' : '',
                        $folder==$mbox ? ' selected' : '',
+                       $indent,
                        $folder,
                        $JS_OBJECT_NAME,
                        $folder,
@@ -115,6 +142,7 @@
                        $folder,
                        rep_specialchars_output($foldername));
     }
+*/
 
   if ($type=='ul')
     $OUTPUT->add_script(sprintf("%s.gui_object('mailboxlist', '%s');", $JS_OBJECT_NAME, $attrib['id']));
@@ -129,6 +157,104 @@
     }
 */
   return $out . "</$type>";
+  }
+
+
+
+
+// create a hierarchical array of the mailbox list
+function rcmail_build_folder_tree(&$arrFolders, $folder, $delm='/', $path='')
+  {
+  $pos = strpos($folder, $delm);
+  if ($pos !== false)
+    {
+    $subFolders = substr($folder, $pos+1);
+    $currentFolder = substr($folder, 0, $pos);
+    }
+  else
+    {
+    $subFolders = false;
+    $currentFolder = $folder;
+    }
+
+  $path .= $currentFolder;
+
+  if (!isset($arrFolders[$currentFolder]))
+    {
+    $arrFolders[$currentFolder] = array('id' => $path,
+                                        'name' => $currentFolder,
+                                        'folders' => array());
+    }
+
+  if (!empty($subFolders))
+    rcmail_build_folder_tree($arrFolders[$currentFolder]['folders'], $subFolders, $delm, $path.$delm);
+  }
+  
+
+// return html for a structured list <ul> for the mailbox tree
+function rcmail_render_folder_tree_html(&$arrFolders, &$special, &$mbox, $nestLevel = 0)
+  {
+  global $JS_OBJECT_NAME, $IMAP;
+
+  $idx = 0;
+  $out = '';
+  foreach ($arrFolders as $key => $folder)
+    {
+    $zebra_class = ($nestLevel*$idx)%2 ? 'even' : 'odd';
+
+    $folder_lc = strtolower($folder['id']);
+    if (in_array($folder_lc, $special))
+      $foldername = rcube_label($folder_lc);
+    else
+      $foldername = $folder['name'];
+
+    if ($unread_count = $IMAP->messagecount($folder['id'], 'UNSEEN'))
+      $foldername .= sprintf(' (%d)', $unread_count);
+
+    $out .= sprintf('<li class="mailbox %s %s%s%s"><a href="#%s" onclick="return %s.command(\'list\',\'%s\')" onmouseup="return %s.mbox_mouse_up(\'%s\')">%s</a>'."\n",
+                    preg_replace('/[^a-z0-9\-_]/', '', $folder_lc),
+                    $zebra_class,
+                    $unread_count ? ' unread' : '',
+                    $folder['id']==$mbox ? ' selected' : '',
+                    $folder['id'],
+                    $JS_OBJECT_NAME,
+                    $folder['id'],
+                    $JS_OBJECT_NAME,
+                    $folder['id'],
+                    rep_specialchars_output($foldername));
+
+    if (!empty($folder['folders']))
+      $out .= '<ul>' . rcmail_render_folder_tree_html($folder['folders'], $special, $mbox, $nestLevel+1) . "</ul>\n";
+
+    $out .= "</li>\n";
+    $idx++;
+    }
+
+  return $out;
+  }
+
+
+// return html for a flat list <select> for the mailbox tree
+function rcmail_render_folder_tree_select(&$arrFolders, &$special, &$mbox, $nestLevel=0)
+  {
+  global $IMAP;
+
+  $idx = 0;
+  $out = '';
+  foreach ($arrFolders as $key=>$folder)
+    {
+    $out .= sprintf('<option value="%s">%s%s</option>'."\n",
+                    $folder['id'],
+                    str_repeat('&nbsp;', $nestLevel*4),
+                    rep_specialchars_output($folder['name']));
+
+    if (!empty($folder['folders']))
+      $out .= rcmail_render_folder_tree_select($folder['folders'], $special, $mbox, $nestLevel+1);
+
+    $idx++;
+    }
+
+  return $out;
   }
 
 
@@ -1078,6 +1204,27 @@
   }
 
 
+// create temp dir for attachments
+function rcmail_create_compose_tempdir()
+  {
+  global $CONFIG;
+  
+  if ($_SESSION['compose']['temp_dir'])
+    return $_SESSION['compose']['temp_dir'];
+  
+  if (!empty($CONFIG['temp_dir']))
+    $temp_dir = $CONFIG['temp_dir'].(!eregi('\/$', $CONFIG['temp_dir']) ? '/' : '').$_SESSION['compose']['id'];
+
+  // create temp-dir for uploaded attachments
+  if (!empty($CONFIG['temp_dir']) && is_writeable($CONFIG['temp_dir']))
+    {
+    mkdir($temp_dir);
+    $_SESSION['compose']['temp_dir'] = $temp_dir;
+    }
+
+  return $_SESSION['compose']['temp_dir'];
+  }
+
 
 // clear message composing settings
 function rcmail_compose_cleanup()
diff --git a/program/steps/mail/upload.inc b/program/steps/mail/upload.inc
index 3ae88fa..308ec79 100644
--- a/program/steps/mail/upload.inc
+++ b/program/steps/mail/upload.inc
@@ -26,20 +26,12 @@
   }
 
 
-if (strlen($CONFIG['temp_dir']))
-  $temp_dir = $CONFIG['temp_dir'].(!eregi('\/$', $CONFIG['temp_dir']) ? '/' : '').$_SESSION['compose']['id'];
+// create temp dir for file uploads
+$temp_dir = rcmail_create_compose_tempdir();
+
 
 if (!is_array($_SESSION['compose']['attachments']))
-  {
   $_SESSION['compose']['attachments'] = array();
-
-  // create temp-dir for uploaded attachments
-  if ($CONFIG['temp_dir'] && is_writeable($CONFIG['temp_dir']))
-    {
-    mkdir($temp_dir);
-    $_SESSION['compose']['temp_dir'] = $temp_dir;
-    }
-  }
 
 
 $response = '';
diff --git a/skins/default/mail.css b/skins/default/mail.css
index eb8d67c..5ae46f1 100644
--- a/skins/default/mail.css
+++ b/skins/default/mail.css
@@ -193,7 +193,7 @@
 
 #mailboxlist li
 {
-  height: 18px;
+ /* height: 18px; */
   font-size: 11px;
   background: url(images/icons/folder-closed.png) no-repeat;
   background-position: 10px 1px;
@@ -243,7 +243,7 @@
 #mailboxlist li.selected
 {
   background-color: #929292;
-  border-bottom: 1px solid #898989;  
+  border-bottom: 1px solid #898989;
 }
 
 #mailboxlist li.selected a
@@ -253,6 +253,37 @@
 }
 
 
+/* styles for nested folders */
+#mailboxlist ul {
+  list-style: none;
+  padding: 0;
+  margin:0;
+  border-top: 1px solid #EBEBEB;  
+}
+
+#mailboxlist ul li {
+  padding-left: 15px;
+  background-position: 25px 1px;
+}
+
+#mailboxlist li.selected li {
+  background-color: #F9F9F9;
+}
+
+#mailboxlist li.unread li {
+  font-weight: normal;
+}
+
+#mailboxlist li.unread li.unread {
+  font-weight: bold;
+}
+
+#mailboxlist li.selected li a{
+  color: black;
+  font-weight: normal;
+}
+
+
 /** message list styles */
 
 body.messagelist

--
Gitblit v1.9.1