source: branches/2.2/expressoMail1_2/js/draw_api.js @ 3028

Revision 3028, 122.1 KB checked in by amuller, 14 years ago (diff)

Ticket #1035 - fazendo uso da funcao borkb no branches

  • Property svn:eol-style set to native
  • Property svn:executable set to *
Line 
1 var openTab = {
2        'type' : [], // 8 types of tabs, further info. see expressolivre.org/dev/wiki/mail/Documentacao
3        'content_id' : [],
4        'imapUid' : [], // Stores the imap email number of current tab
5        'countFile' : [0,0,0,0,0,0,0,0,0,0], // Stores the number of files attached in current tab
6        'imapBox' : [], // Stores the folder name
7        'toPreserve' : [], // Check if the message should be removed from draft after send
8        'autosave_timer' : [] // The timeout timer for autosave function
9};
10var tabTypes = {
11        'new':4,
12        'forward':6,
13        'reply_with_history':7,
14        'reply_to_all_with_history':7,
15        'reply_without_history':7,
16        'reply_to_all_without_history':7,
17        'edit':5
18        }
19var currentTab,numBox = 0; // Open Tab and num of mailboxes opened at context
20
21// Objeto Map, talvez o ideal fosse adicionar este objeto à Api do egroupware, e carregá-lo
22// aqui no expressoMail.
23function Map()
24{
25    this.keys = new Array();
26    this.values = new Array();
27}
28
29Map.prototype.add = function(key, value)
30{
31    this.keys.push(key);
32    this.values.push(value);
33}
34
35Map.prototype.get = function(key)
36{
37    result = new Array();
38    for (i = 0; i < this.keys.length; i++)
39    {
40        if (this.keys[i] == key)
41        {
42            result.push(this.values[i]);
43        }
44    }
45
46    if (result.length == 0)
47    {
48        return null;
49    }
50
51    return result;
52}
53
54var translatedFolders = new Map();
55
56function draw_tree_folders(folders){
57        // Check if the tree folders alredy exist.
58        translatedFolders = new Map();
59        if (Element('dftree_tree_folders')){
60                if (!expresso_offline) {
61                        var update_tree_folders = function(data){
62                                build_quota(data);
63                                var unseen_in_mailbox = 0;
64                                var unseen_in_shared_folders = 0;
65                                for (var i=0; i<data.length; i++){
66                                        if ( data[i].folder_unseen > 0 )
67                                        {
68                                                unseen_in_mailbox = parseInt( unseen_in_mailbox + data[ i ].folder_unseen );
69                                                if ( data[i].folder_id.indexOf( 'INBOX' ) !== 0 )
70                                                        unseen_in_shared_folders = parseInt( unseen_in_shared_folders + data[ i ].folder_unseen );
71                                        }
72       
73                                        var folder_unseen = Element('dftree_'+data[i].folder_id+'_unseen');
74                                       
75                                        if ((folder_unseen) && (data[i].folder_unseen > 0))
76                                        {
77                                                folder_unseen.innerHTML = data[i].folder_unseen;
78                                        }
79                                        else if (data[i].folder_unseen > 0)
80                                        {
81                                                tree_folders.getNodeById(data[i].folder_id).alter({caption:lang_folder(data[i].folder_name) + '<font style=color:red>&nbsp(</font><span id="dftree_'+data[i].folder_id+'_unseen" style=color:red>'+data[i].folder_unseen+'</span><font style=color:red>)</font>'});
82                                                tree_folders.getNodeById(data[i].folder_id)._refresh();
83                                        }
84                                        else if (data[i].folder_unseen <= 0)
85                                        {
86                                                tree_folders.getNodeById(data[i].folder_id).alter({caption:lang_folder(data[i].folder_name)});
87                                                tree_folders.getNodeById(data[i].folder_id)._refresh();
88                                        }
89
90                                        if(data[i].folder_id == current_folder){                                       
91                                                var old_new_m = isNaN(parseInt(Element('new_m').innerHTML)) ? parseInt(Element('new_m').firstChild.innerHTML) : parseInt(Element('new_m').innerHTML);
92        //                                      if(!isNaN(old_new_m) && old_new_m < data[i].folder_unseen){
93        //                                              Element('tot_m').innerHTML = parseInt(Element('tot_m').innerHTML) + (parseInt(data[i].folder_unseen)-old_new_m);
94        //                                      }
95                                                Element('new_m').innerHTML = data[i].folder_unseen ? '<font color="RED">'+data[i].folder_unseen+'</font>' : 0;
96                                                draw_paging(Element('tot_m').innerHTML);
97                                        }
98                                }
99
100                                var display_unseen_in_mailbox = tree_folders.getNodeById( 'root' );
101                                //if ( unseen_in_mailbox )
102                                //      display_unseen_in_mailbox.alter({caption:'<font style=color:red>[</font><span id="dftree_root_unseen" style="color:red">' + unseen_in_mailbox +'</span><font style=color:red>]</font> ' + get_lang("My Folders")});
103                                //else
104                                        display_unseen_in_mailbox.alter({caption:get_lang("My Folders")});
105                                display_unseen_in_mailbox._refresh();
106       
107                                var display_unseen_in_shared_folders = tree_folders.getNodeById( 'user' );
108                                if ( display_unseen_in_shared_folders )
109                                {
110                                        if ( unseen_in_shared_folders )
111                                                display_unseen_in_shared_folders.alter({caption:'<font style=color:red>[</font><span id="dftree_user_unseen" style="color:red">' + unseen_in_shared_folders +'</span><font style=color:red>]</font> ' + get_lang("Shared folders")});
112                                        else
113                                                display_unseen_in_shared_folders.alter({caption:get_lang("Shared folders")});
114                                        display_unseen_in_shared_folders._refresh();
115                                }
116                        }
117                        cExecute ("$this.imap_functions.get_folders_list&folder="+current_folder, update_tree_folders);
118                }
119       
120                return;
121        }
122        else{
123                if (!expresso_offline) {
124                        tree_folders = new dFTree({name: 'tree_folders'});
125       
126                        var n_root = new dNode({id:'root', caption: get_lang("My Folders")});
127                        tree_folders.add(n_root,'anything'); //Places the root; second argument can be anything.
128       
129                        var unseen_in_mailbox = 0;
130                        var unseen_in_shared_folders = 0;
131                        for (var i=0; i<folders.length; i++){
132                                if (folders[i].folder_unseen > 0)
133                                {
134                                        unseen_in_mailbox = parseInt( unseen_in_mailbox + folders[ i ].folder_unseen );
135                                        if ( folders[i].folder_id.indexOf( 'INBOX' ) !== 0 )
136                                                unseen_in_shared_folders = parseInt( unseen_in_shared_folders + folders[ i ].folder_unseen );
137
138                                        var nn = new dNode({id:folders[i].folder_id, caption:lang_folder(folders[i].folder_name) + '<font style=color:red>&nbsp(</font><span id="dftree_'+folders[i].folder_id+'_unseen" style=color:red>'+folders[i].folder_unseen+'</span><font style=color:red>)</font>', onClick:"change_folder('"+folders[i].folder_id+"','"+folders[i].folder_name+"')", plusSign:folders[i].folder_hasChildren});
139                               
140                                        if( folders[i].folder_name.toLowerCase() == 'inbox' )
141                                                Element('new_m').innerHTML = '<font style="color:red">' + folders[i].folder_unseen + '</font>';
142                                }
143                                else
144                                        var nn = new dNode({id:folders[i].folder_id, caption:lang_folder(folders[i].folder_name), onClick:"change_folder('"+folders[i].folder_id+"','"+folders[i].folder_name+"')", plusSign:folders[i].folder_hasChildren});
145                               
146                                if (folders[i].folder_parent == '')
147                                        folders[i].folder_parent = 'root';
148                                else if (folders[i].folder_parent == 'user'){   
149                                       
150                                        if (!tree_folders.getNodeById('user')){
151                                                tmpFolderId = folders[i].folder_id.split(cyrus_delimiter).pop();
152                                                if (tmpFolderId != folders[i].folder_name)
153                                                {
154                                                    translatedFolders.add(tmpFolderId, folders[i].folder_name);
155                                                }
156                                                var n_root_shared_folders = new dNode({id:'user', caption:get_lang("Shared folders"), plusSign:true});
157                                                tree_folders.add(n_root_shared_folders,'root');
158                                        }
159                                }
160                                tree_folders.add(nn,folders[i].folder_parent);
161                        }
162                }
163                //tree_local_folders = new dFTree({name: 'tree_local_folders'});
164                /**
165                 * Pastas locais
166                 */
167                if (preferences.use_local_messages==1 || expresso_offline) {
168                        if (!window.google || !google.gears) {
169                                if (!expresso_local_messages.installGears())
170                                        preferences.use_local_messages=0;
171                        }
172                        else{
173                                if (!window.google || !google.gears) {
174                                temp = confirm(get_lang("To use local messages you have to install google gears. Would you like to be redirected to gears installation page?"));
175                                if (temp) {
176                                        location.href = "http://gears.google.com/?action=install&message="+
177                                        "Para utilizar o recurso de mensagens locais, instale o google gears&return=" +
178                                        document.location.href;
179                                }
180                                else {
181                                        preferences.use_local_messages=0;
182                                }
183                        }
184                        else{
185                                if (expresso_offline)
186                                        tree_folders = new dFTree({
187                                                name: 'tree_folders'
188                                        });
189                                var root_local = new dNode({
190                                        id: "local_root",
191                                        caption: get_lang('local folders')
192                                });
193                                tree_folders.add(root_local, "root"); //coloca root local
194                                var local_folders = expresso_local_messages.list_local_folders();
195                                for (var i in local_folders) { //Coloca as pastas locais.
196                                        var node_root = "local_root";
197                                        var new_caption = local_folders[i][0];
198                                        if (local_folders[i][0].indexOf("/") != "-1") {
199                                                final_pos = local_folders[i][0].lastIndexOf("/");
200                                                node_root = "local_" + local_folders[i][0].substr(0, final_pos);
201                                                new_caption = local_folders[i][0].substr(final_pos + 1);
202                                        }
203                                        if (local_folders[i][1] > 0)
204                                                var nodeLocal = new dNode({
205                                                        id: "local_" + local_folders[i][0],
206                                                        caption: lang_folder(new_caption) + '<font style=color:red>&nbsp(</font><span id="local_unseen" style=color:red>' + local_folders[i][1] + '</span><font style=color:red>)</font>',
207                                                        onClick: "change_folder('local_" + local_folders[i][0] + "','" + new_caption + "')",
208                                                        plusSign: local_folders[i][2]
209                                                });
210                                        else
211                                                var nodeLocal = new dNode({
212                                                        id: "local_" + local_folders[i][0],
213                                                        caption: lang_folder(new_caption),
214                                                        onClick: "change_folder('local_" + local_folders[i][0] + "','" + new_caption + "')",
215                                                        plusSign: local_folders[i][2]
216                                                });
217                                                tree_folders.add(nodeLocal, node_root);
218                                        }
219                                }
220                        }               
221                }
222
223                tree_folders.draw(Element('content_folders'));
224                if (!expresso_offline) {
225                        n_root.changeState();
226                        tree_folders.getNodeById('INBOX')._select();
227                }
228                else {
229                        root_local.changeState();
230                        tree_folders.getNodeById('local_Inbox')._select();
231                }
232
233                var trash_span=document.getElementById('lINBOX/'+trashfolder+'tree_folders');
234                var draft_span=document.getElementById('lINBOX/'+draftsfolder+'tree_folders');
235                var sent_span=document.getElementById('lINBOX/'+sentfolder+'tree_folders');
236                var spam_span=document.getElementById('lINBOX/'+spamfolder+'tree_folders');
237
238                if (trash_span)
239                        trash_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_trash.png)";
240
241                if (draft_span)
242                        draft_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_draft.png)"
243
244                if (sent_span)
245                        sent_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_sent.png)";
246
247                if (spam_span)
248                        spam_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_spam.png)";
249
250
251                draw_paging(Element('tot_m').innerHTML);
252                if(document.getElementById("nINBOX/"+trashfolder+"tree_folders"))
253                {
254                        var trash = document.createElement("SPAN");
255                        trash.id = 'empty_trash';
256                        trash.className = 'clean_folder';
257                        trash.style.cursor = 'pointer';
258                        trash.onclick = function () {empty_trash_imap();};
259                        trash.innerHTML = "["+get_lang("Clean")+"]";
260                        trash.title=get_lang("Empty trash");
261                        trash.onmouseover = function() {trash.style.color="red";};
262                        trash.onmouseout= function() {trash.style.color="#666666";};
263                        document.getElementById("nINBOX/"+trashfolder+"tree_folders").appendChild(trash);
264                }
265                if(document.getElementById("nINBOX/"+spamfolder+"tree_folders"))
266                {
267                        var spam = document.createElement("SPAN");
268                        spam.id = 'empty_spam';
269                        spam.className = 'clean_folder';
270                        spam.style.cursor = 'pointer';
271                        spam.style.padding = '0 0 0 6px';
272                        spam.onclick = function () {empty_spam_imap();};
273                        spam.innerHTML = "["+get_lang("Clean")+"]";
274                        spam.title=get_lang("Empty Spam Folder");
275                        spam.onmouseover = function() {spam.style.color="red";};
276                        spam.onmouseout= function() {spam.style.color="#666666";};
277                        document.getElementById("nINBOX/"+spamfolder+"tree_folders").appendChild(spam);
278               }
279
280                // Draw right menu folders.
281                /*
282                var treeroot = document.getElementById('chroottree_folders');
283                for (var linkBox = treeroot.firstChild; linkBox != null; linkBox = linkBox.nextSibling)
284                        _dragArea.makeMenuBox(linkBox);
285                */
286
287                if(!expresso_offline)
288                        var display_unseen_in_mailbox = tree_folders.getNodeById( 'root' );
289                else
290                        var display_unseen_in_mailbox = tree_folders.getNodeById( 'local_root' );
291                //if ( unseen_in_mailbox )
292                //      display_unseen_in_mailbox.alter({caption:'<font style=color:red>[</font><span id="dftree_root_unseen" style="color:red">' + unseen_in_mailbox +'</span><font style=color:red>]</font> ' + get_lang("My Folders")});
293                //else
294                        display_unseen_in_mailbox.alter({caption:get_lang("My Folders")});
295                display_unseen_in_mailbox._refresh();
296
297                var display_unseen_in_shared_folders = tree_folders.getNodeById( 'user' );
298                if ( display_unseen_in_shared_folders )
299                {
300                        if ( unseen_in_shared_folders )
301                                display_unseen_in_shared_folders.alter({caption:'<font style=color:red>[</font><span id="dftree_user_unseen" style="color:red">' + unseen_in_shared_folders +'</span><font style=color:red>]</font> ' + get_lang("Shared folders")});
302                        else
303                                display_unseen_in_shared_folders.alter({caption:get_lang("Shared folders")});
304                        display_unseen_in_shared_folders._refresh();
305                }
306        }
307
308        if (!expresso_offline) {
309                var folder_create = "";
310                var nm1 = "";
311                if(tree_folders._folderPr.length > 0){
312                        var nm_folder = "";
313                        for(var i=0; i < tree_folders._folderPr.length; i++){
314                                nm_folder = tree_folders._folderPr[i].split(cyrus_delimiter);
315                                if(nm_folder[0] == "INBOX"){
316                                        if(nm1 == ""){
317                                                nm1 = nm_folder[1];
318                                                folder_create = "INBOX" + cyrus_delimiter + nm_folder[1] + ";";
319                                        }else{
320                                                if( nm1 != nm_folder[1]){
321                                                        folder_create += "INBOX" + cyrus_delimiter + nm_folder[1] + ";";
322                                                        nm1 = nm_folder[1];
323                                                }
324                                        }
325                                }
326                        }
327                }
328                if(folder_create != ""){
329                        if(confirm(get_lang("There are folders with invalid format. Do you want to fix them?"))){
330                                var handler_correct_folders = function(data){
331                                        //Timeout to release HTTPRequest , loadScript and update tree folders.
332                                        if(data)
333                                                setTimeout("connector.loadScript('TreeShow');ttreeBox.update_folder();",500);
334                                }
335                                cExecute("$this.imap_functions.create_extra_mailbox",handler_correct_folders,"nw_folders="+folder_create);
336                        }
337                }
338        }
339}
340
341function draw_tree_local_folders() {
342        /**
343         * Pastas locais
344         */
345        if(preferences.use_local_messages==1 || expresso_offline) {
346                var local_folders = expresso_local_messages.list_local_folders();
347                var has_changes = false;
348                for (var i in local_folders) { //Coloca as pastas locais.
349                       
350                        var new_caption = local_folders[i][0];
351                        if(local_folders[i][0].indexOf("/")!="-1") {
352                                final_pos = local_folders[i][0].lastIndexOf("/");
353                                new_caption = local_folders[i][0].substr(final_pos+1);
354                        }
355                       
356                        var folder_unseen = Element('dftree_local_'+local_folders[i][0]+'_unseen');
357                       
358                        if ((folder_unseen) && (local_folders[i][1] > 0))
359                        {
360                                folder_unseen.innerHTML = local_folders[i][1];
361                                has_changes = true;
362                        }
363                        else if (local_folders[i][1] > 0)
364                        {
365                                tree_folders.getNodeById("local_"+local_folders[i][0]).alter({caption:lang_folder(new_caption) + '<font style=color:red>&nbsp(</font><span id="dftree_local_'+local_folders[i][0]+'_unseen" style=color:red>'+local_folders[i][1]+'</span><font style=color:red>)</font>'});
366                                tree_folders.getNodeById("local_"+local_folders[i][0])._refresh();
367                                has_changes = true;
368                        }
369                        else if (local_folders[i][1] <= 0)
370                        {
371                                tree_folders.getNodeById("local_"+local_folders[i][0]).alter({caption:lang_folder(new_caption)});
372                                tree_folders.getNodeById("local_"+local_folders[i][0])._refresh();
373                                has_changes = true;
374                        }
375
376                        if("local_"+local_folders[i][0] == get_current_folder()){                                       
377                                var old_new_m = isNaN(parseInt(Element('new_m').innerHTML)) ? parseInt(Element('new_m').firstChild.innerHTML) : parseInt(Element('new_m').innerHTML);
378                                if(!isNaN(old_new_m) && old_new_m < local_folders[i][1]){
379                                        Element('tot_m').innerHTML = parseInt(Element('tot_m').innerHTML) + (parseInt(local_folders[i][1])-old_new_m);
380                                }
381                                Element('new_m').innerHTML = local_folders[i][1] ? '<font color="RED">'+local_folders[i][1]+'</font>' : 0;
382                                draw_paging(Element('tot_m').innerHTML);
383                                has_changes = true;
384                        }
385                }
386                if(has_changes)
387                        tree_folders.getNodeById("local_root").open();
388
389        }       
390}
391
392function update_menu(data){
393                /*
394                 * @AUTHOR Rodrigo Souza dos Santos
395                 * @DATE 2008/09/15
396                 * @BRIEF When occurs a error in imap server show the message that is in file "error.html".
397                 */
398                if ( data && data.imap_error )
399                {
400                        if(preferences.use_local_messages==1 && expresso_local_messages.is_offline_installed){
401                                conf = confirm(get_lang("The expresso imap server is currently down, expresso noticed you have offline mail module installed, would you like to use it?"));
402                                if(conf) {
403                                        window.onresize = function() {
404                                                var target = document.getElementById('divAppbox');
405                                                target.style.height= document.body.clientHeight - 83;
406                                        }
407                                        var target = document.getElementById('divAppbox');
408                                        document.getElementById("divAppboxHeader").innerHTML="";
409                                        target.style.height= document.body.clientHeight - 83;
410                                        expresso_local_messages.set_as_logged(account_id,0,true);
411                                        target.innerHTML = "<iframe src='offline.php?inside=1' width='100%' height='100%' frameBorder='0'></iframe>";
412                                        return false;
413                                }
414                        }
415                        connector.newRequest('error.html', 'templates/'+template+'/error.html', 'GET',
416                                function(data)
417                                {
418                                        var target = document.getElementById('divAppbox');
419                                        if ( target )
420                                                target.innerHTML = data;
421                                }
422                        );
423                        return false;
424                }
425
426                draw_tree_folders(data);
427                if(data) {
428                        build_quota(data);                     
429                        var f_unseen = Element('dftree_'+current_folder+'_unseen');
430                        if(f_unseen && f_unseen.innerHTML)
431                                Element('new_m').innerHTML = '<font face="Verdana" size="1" color="RED">'+f_unseen.innerHTML+'</font>';
432                        else
433                        {
434                                if( parseInt(Element('new_m').innerHTML) == 0 )
435                                        Element('new_m').innerHTML = 0;                 
436                        }
437                        folders = data;
438                }
439}
440
441var handler_draw_box = function(data){
442        draw_box(data, 'INBOX', true);
443        //alternate_border(0);
444}
445
446// Action on change folders.
447function change_folder(folder, folder_name){
448        if (openTab.imapBox[0] != folder)
449        {
450                current_folder = folder;
451                var handler_draw_box = function(data)
452                {
453                        if(!verify_session(data))
454                                return;
455                        alternate_border(0);
456                        Element("border_id_0").innerHTML = "&nbsp;" + lang_folder(folder_name) + '&nbsp;<font face="Verdana" size="1" color="#505050">[<span id="new_m">&nbsp;</span> / <span id="tot_m"></span>]</font>';
457                        draw_box(data, folder, true);
458                        draw_paging(data.num_msgs);
459                        Element("tot_m").innerHTML = data.num_msgs;
460                        update_menu();
461                        return true;
462                }
463                proxy_mensagens.messages_list(current_folder,1,preferences.max_email_per_page,sort_box_type,search_box_type,sort_box_reverse,preferences.preview_msg_subject,preferences.preview_msg_tip,handler_draw_box);
464//              cExecute ("$this.imap_functions.get_range_msgs2&folder="+current_folder+"&msg_range_begin=1&msg_range_end="+preferences.max_email_per_page+"&sort_box_type="+sort_box_type+ "&search_box_type="+ search_box_type +"&sort_box_reverse="+sort_box_reverse+"", handler_draw_box);
465        }
466        else
467                alternate_border(0);
468}
469
470function open_folder(folder, folder_name){
471        if (current_folder!= folder) {
472                current_folder = folder;
473                var handler_draw_box = function(data){
474                        if(!verify_session(data))
475                                return false;
476                        numBox++;
477                        create_border(folder_name,numBox.toString());
478                        draw_box(data, current_folder, false);
479                        alternate_border(numBox);
480                        return true;
481                }
482                cExecute ("$this.imap_functions.get_range_msgs2&folder="+current_folder+"&msg_range_begin=1&msg_range_end="+preferences.max_email_per_page+"&sort_box_type="+sort_box_type+ "&search_box_type="+ search_box_type +"&sort_box_reverse="+sort_box_reverse+"", handler_draw_box);
483        }
484        else
485                alternate_border(numBox);
486        return true;
487}
488
489var lastPage = 1;
490var numPages = 5;
491var last_folder = 'INBOX';
492function draw_paging(num_msgs){
493        num_msgs = parseInt(num_msgs);
494        total_pages = 1;
495
496        if(last_folder != current_folder){
497                lastPage = 1;
498                current_page = 1;
499                last_folder = current_folder;
500        }
501
502        if(num_msgs > parseInt(preferences.max_email_per_page)) {       
503                total_pages = parseInt(num_msgs/preferences.max_email_per_page);
504                if((num_msgs/preferences.max_email_per_page) > total_pages)
505                        total_pages++;                 
506        }
507
508        if(total_pages == 1) {
509                if(span_paging = document.getElementById("span_paging")) {
510                        span_paging.parentNode.removeChild(span_paging);
511                }
512                return;
513        }
514       
515        span_paging = document.getElementById("span_paging");
516        if(!span_paging){
517                span_paging = document.createElement("DIV");
518                span_paging.id = "span_paging";
519                span_paging.className = "boxHeaderText";
520                span_paging.align="right";
521                document.getElementById("div_menu_c3").appendChild(span_paging);       
522        }
523        span_paging.style.width="100%";                                 
524        span_paging.innerHTML="";
525        msg_range_begin = 1;
526        msg_range_end = preferences.max_email_per_page;
527        if(current_page != 1) {
528                lnk_page = document.createElement("A");
529                lnk_page.setAttribute("href", "javascript:current_page=1;kill_current_box(); draw_paging("+num_msgs+"); proxy_mensagens.messages_list(get_current_folder(),"+msg_range_begin+","+msg_range_end+",'"+sort_box_type+"','"+search_box_type+"',"+sort_box_reverse+","+preferences.preview_msg_subject+","+preferences.preview_msg_tip+",function handler(data){draw_box(data, get_current_folder());});");
530        }
531        else {
532                lnk_page = document.createElement("SPAN");
533        }
534        span_paging.appendChild(lnk_page);
535
536        lnk_page.innerHTML = "&lt;&lt;";
537        lnk_page.title = get_lang("First");
538        span_paging.innerHTML += "&nbsp;";
539               
540        if(current_page == lastPage + numPages)
541                lastPage = current_page - 1;           
542        else if((lastPage != 1 && lastPage == current_page) || current_page == total_pages)             
543                lastPage = current_page - (numPages - 1);
544        else if(current_page == 1)
545                lastPage = 1;
546
547        if(lastPage < 1)
548                lastPage = 1;
549        else if(lastPage > 1 && (lastPage > (total_pages -(numPages - 1))))
550                lastPage = total_pages -(numPages - 1);
551
552        var     hasMarked = false;
553
554        for(i = lastPage; i <= total_pages; i++) {
555                       
556                if(current_page == i || (i == total_pages && !hasMarked)) {                     
557                        lnk_page = document.createElement("SPAN");
558                        span_paging.appendChild(lnk_page);
559                        lnk_page.innerHTML = "&nbsp;<b>"+i+"</b>&nbsp;";
560                        hasMarked = true;
561                        continue;
562                }
563                else{                   
564                        lnk_page = document.createElement("A");
565                        span_paging.appendChild(lnk_page);
566                        msg_range_begin = ((i*preferences.max_email_per_page)-(preferences.max_email_per_page-1));
567                        msg_range_end = (i*preferences.max_email_per_page);
568                        lnk_page.setAttribute("href", "javascript:current_page="+i+";kill_current_box(); draw_paging("+num_msgs+"); proxy_mensagens.messages_list(get_current_folder(),"+msg_range_begin+","+msg_range_end+",'"+sort_box_type+"','"+search_box_type+"',"+sort_box_reverse+","+preferences.preview_msg_subject+","+preferences.preview_msg_tip+",function handler(data){draw_box(data, get_current_folder());});");
569                }
570               
571                lnk_page.innerHTML = "&nbsp;...&nbsp;";
572               
573                if(i == (lastPage + numPages))
574                                break;                 
575                else if(lastPage == 1 || i != lastPage)                                                 
576                        lnk_page.innerHTML = "&nbsp;"+i+"&nbsp;";
577               
578                span_paging.innerHTML += "&nbsp;";                                                                                                                                                                     
579        }
580       
581        if(current_page != total_pages) {
582                lnk_page = document.createElement("A");
583                msg_range_begin = ((total_pages*preferences.max_email_per_page)-(preferences.max_email_per_page-1));
584                msg_range_end = (total_pages*preferences.max_email_per_page);           
585                lnk_page.setAttribute("href", "javascript:current_page="+total_pages+";kill_current_box(); draw_paging("+num_msgs+"); proxy_mensagens.messages_list(get_current_folder(),"+msg_range_begin+","+msg_range_end+",'"+sort_box_type+"','"+search_box_type+"',"+sort_box_reverse+","+preferences.preview_msg_subject+","+preferences.preview_msg_tip+",function handler(data){draw_box(data, get_current_folder());});");
586        }
587        else {
588                lnk_page = document.createElement("SPAN");
589        }
590        span_paging.innerHTML += "&nbsp;";
591        span_paging.appendChild(lnk_page);
592
593        lnk_page.title = get_lang("Last");
594        lnk_page.innerHTML = "&gt;&gt;";
595}
596
597
598// Draw the inbox and another folders
599function draw_box(headers_msgs, msg_folder, alternate){
600        if (alternate)
601                kill_current_box();
602       
603        if(is_ie)
604                document.getElementById("border_table").width = "99.5%";
605
606        openTab.content_id[numBox] = document.getElementById("content_id_"+numBox);     
607        openTab.imapBox[numBox] = msg_folder;
608        openTab.type[numBox] = 0;
609       
610        table_message_header_box = document.getElementById("table_message_header_box_"+numBox);
611        if (table_message_header_box == null){
612                var table_element = document.createElement("TABLE");
613                var tbody_element = document.createElement("TBODY");
614                table_element.setAttribute("id", "table_message_header_box_"+numBox);
615                table_element.className = "table_message_header_box";
616               
617                tr_element = document.createElement("TR");
618                tr_element.className = "message_header";
619                td_element1 = document.createElement("TD");
620                td_element1.setAttribute("width", "1%");
621                chk_box_element = document.createElement("INPUT");
622                chk_box_element.id  = "chk_box_select_all_messages";
623                chk_box_element.setAttribute("type", "checkbox");
624                chk_box_element.className = "checkbox";
625                chk_box_element.onclick = function(){select_all_messages(this.checked);};
626                chk_box_element.onmouseover = function () {this.title=get_lang('Select all messages.')};
627                chk_box_element.onkeydown = function (e){
628                        if (is_ie)
629                        {
630                                if ((window.event.keyCode) == 46)
631                                        proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
632                        }
633                        else
634                        {
635                                if ((e.keyCode) == 46)
636                                        proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
637                        }
638                };
639               
640                td_element1.appendChild(chk_box_element);
641               
642                td_element2 = document.createElement("TD");
643                td_element2.setAttribute("width", "7%");
644                td_element3 = document.createElement("TD");
645                td_element3.setAttribute("width", "29%");
646                td_element3.onclick = function () {sort_box(search_box_type,'SORTFROM');};
647                td_element3.id = "message_header_SORTFROM_"+numBox;
648                td_element3.align = "left";
649                td_element3.innerHTML = get_lang("Who");
650               
651                td_element4 = document.createElement("TD");
652                td_element4.setAttribute("width", "38%");
653                td_element4.onclick = function () {sort_box(search_box_type,'SORTSUBJECT');};
654                td_element4.id = "message_header_SORTSUBJECT_"+numBox;
655                td_element4.align = "left";
656                td_element4.innerHTML = get_lang("Subject");
657       
658                td_element5 = document.createElement("TD");
659                td_element5.setAttribute("width", "14%");
660                td_element5.onclick = function () {sort_box(search_box_type,'SORTARRIVAL');};
661                td_element5.id = "message_header_SORTARRIVAL_"+numBox;
662                td_element5.align = "center";
663                td_element5.innerHTML = get_lang("Date");
664                td_element6 = document.createElement("TD");
665                td_element6.setAttribute("width", "14%");
666                td_element6.onclick = function () {sort_box(search_box_type,'SORTSIZE');}
667                td_element6.id = "message_header_SORTSIZE_"+numBox;
668                td_element6.align = "left";
669                td_element6.innerHTML = get_lang("Size");
670               
671                tr_element.appendChild(td_element1);
672                tr_element.appendChild(td_element2);           
673                var td_element21 = document.createElement("TD");
674                td_element21.innerHTML = "&nbsp;&nbsp;&nbsp;";
675                var td_element22 = document.createElement("TD");
676                td_element22.innerHTML = "&nbsp;&nbsp;&nbsp;";
677                var td_element23 = document.createElement("TD");
678                td_element23.innerHTML = "&nbsp;&nbsp;";
679                tr_element.appendChild(td_element21);
680                tr_element.appendChild(td_element22);
681                tr_element.appendChild(td_element23);
682                tr_element.appendChild(td_element3);
683                tr_element.appendChild(td_element4);
684                tr_element.appendChild(td_element5);
685                tr_element.appendChild(td_element6);
686                tbody_element.appendChild(tr_element);
687                table_element.appendChild(tbody_element);
688                openTab.content_id[numBox].appendChild(table_element);
689        }
690        draw_header_box();
691        var table_element = document.createElement("TABLE");
692        var tbody_element = document.createElement("TBODY");   
693        table_element.id = "table_box";
694        table_element.className = "table_box";
695        table_element.borderColorDark = "#bbbbbb";
696        table_element.frame = "void";
697        table_element.rules = "rows";
698        table_element.cellPadding = "0";
699        table_element.cellSpacing = "0";
700       
701        table_element.onkeydown = function (e){
702                if (is_ie)
703                {
704                        if ((window.event.keyCode) == 46)
705                        {
706                                //delete_all_selected_msgs_imap();
707                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
708                        }
709                }
710                else
711                {
712                        if ((e.keyCode) == 46)
713                        {
714                                //delete_all_selected_msgs_imap();
715                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
716                        }
717                }
718        };
719        if (is_ie)
720                table_element.style.cursor = "hand";
721       
722        tbody_element.setAttribute("id", "tbody_box");
723        table_element.appendChild(tbody_element);
724       
725        var _divScroll = document.getElementById("divScrollMain_"+numBox);
726
727
728        if(!_divScroll){               
729                _divScroll = document.createElement("DIV");
730                _divScroll.id = "divScrollMain_"+numBox;
731        }
732       
733        _divScroll.style.overflowY = "auto";                                                           
734        _divScroll.style.overflowX = "hidden";
735        _divScroll.style.width  ="100%";
736       
737        if (is_mozilla){
738                _divScroll.style.overflow = "-moz-scrollbars-vertical";
739                _divScroll.style.width  ="99.3%";
740        }
741        _divScroll.appendChild(table_element);
742        openTab.content_id[numBox].appendChild(_divScroll);
743       
744        var f_unseen = 0;
745
746                if (headers_msgs.num_msgs == 0){
747                        var tr_info = document.createElement("TR");
748                        var td_info = document.createElement("TD");
749                        td_info.setAttribute("colspan", "10");
750                        td_info.setAttribute("background", "#FFF");
751                        tr_info.setAttribute("id", "msg_info");
752                        td_info.align = "center";
753                        td_info.style.padding = "25px";
754                        td_info.style.fontWeight = "bold";
755                        td_info.style.fontSize = "11pt";
756                        td_info.innerHTML = get_lang("This mail box is empty");
757                        tr_info.appendChild(td_info);
758                        tbody_element.appendChild(td_info);
759                }
760       
761       
762        for (var i=0; i < headers_msgs.length; i++){
763                        if ((headers_msgs[i].Unseen == 'U') || (headers_msgs[i].Recent == 'N'))
764                                f_unseen++;                             
765                        tr_element = this.make_tr_message(headers_msgs[i], msg_folder);
766                        if (tr_element){
767                                tbody_element.appendChild(tr_element);
768                                add_className(tr_element, i%2 != 0 ? 'tr_msg_read2' : 'tr_msg_read');                           
769                        }
770                        _dragArea.makeDragged(tr_element, headers_msgs[i].msg_number, headers_msgs[i].subject, true);
771        }
772       
773        if ((preferences.use_shortcuts == '1') && (headers_msgs[0]))
774                select_msg(headers_msgs[0].msg_number, 'null', true);
775
776        var tdFolders  =  Element("folderscol");
777        tdFolders.style.display = preferences.hide_folders == '1'  ? "none" : "";
778        if ( !currentTab )
779                alternate_border(numBox);
780        draw_footer_box(headers_msgs.num_msgs);
781        Element('main_table').style.display = '';
782        if(is_ie6)      // Stupid Fixing on IE6.
783                setTimeout("resizeWindow()",1);
784        else
785                resizeWindow();
786        if(debug) {
787                var _eTime = new Date();
788                _eTime = _eTime.getTime();
789                alert("Carregou em "+(_eTime - _bTime)+" ms");
790        }
791        var msg_folder = Element('msg_folder').value;
792        var msg_number = Element('msg_number').value;   
793        if(!msg_folder && msg_number) {
794                new_message('new','null');
795        }
796        else if(msg_folder && msg_number){
797                cExecute("$this.imap_functions.get_info_msg&msg_number="+ msg_number + "&msg_folder=" + url_encode(msg_folder), show_msg);
798                Element('msg_folder').value = '';
799                Element('msg_number').value = '';
800        }
801
802        if(!is_ie) {
803                var scripts = new Array("ccQuickAdd",
804                                                        "color_palette",
805                                                        "filter",
806                                                        "filters",
807                                                        "html2xhtml",
808                                                        "preferences",
809                                                        "QuickCatalogSearch",
810                                                        "QuickSearchUser",
811                                                        "rich_text_editor",
812                                                        "sharemailbox",
813                                                        "search",
814                                                        "TreeS",
815                                                        "TreeShow");
816                                                       
817                connector.loadAllScripts(scripts);
818        }
819}
820
821function make_tr_message(headers_msgs, msg_folder){
822                var tr_element = document.createElement('tr');
823                tr_element.style.height = preferences.line_height;             
824                tr_element.id = headers_msgs.msg_number;
825
826                tr_element.msg_sample = "";
827                //if(headers_msgs.msg_sample && headers_msgs.msg_sample.preview_msg_subject != "")
828                if(headers_msgs.msg_sample && preferences.preview_msg_subject == "1")
829                {
830                        tr_element.msg_sample = headers_msgs.msg_sample.body.substr(0,120) + "..."; //trecho do body que sera exibido com o assunto;
831                }
832
833                tr_element.tip = "";
834                if(headers_msgs.msg_sample && preferences.preview_msg_tip == "1")
835                {
836                        tr_element.tip = headers_msgs.msg_sample.body.substr(3,300) + "..."; //trecho do body que sera exibido no tool-tip;
837                }
838
839                if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N')){
840                        if ((headers_msgs.Flagged == 'F') || (headers_msgs.Importance.toLowerCase().indexOf("high")!=-1 && parseInt(preferences.use_important_flag)))
841                                add_className(tr_element, 'flagged_msg');
842                        add_className(tr_element, 'tr_msg_unread');
843                }
844                else{
845                        if ((headers_msgs.Flagged == 'F') || (headers_msgs.Importance.toLowerCase().indexOf("high")!=-1 && parseInt(preferences.use_important_flag)))
846                                add_className(tr_element,'flagged_msg');
847                }
848
849                if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N'))
850                        add_className(tr_element, 'tr_msg_unread');
851               
852                if (headers_msgs.Flagged == 'F')
853                        add_className(tr_element,'flagged_msg');
854
855                td_element1 = document.createElement("TD");
856                td_element1.className = "td_msg";
857                td_element1.setAttribute("width", "1%");
858                chk_box_element = document.createElement("INPUT");
859                chk_box_element.setAttribute("type", "checkbox");
860                chk_box_element.className = "checkbox";
861                chk_box_element.setAttribute("id", "check_box_message_"+headers_msgs.msg_number);
862                chk_box_element.onclick = function(e){
863                        if (is_ie)
864                                changeBgColor(window.event,headers_msgs.msg_number);
865                        else
866                                changeBgColor(e,headers_msgs.msg_number);
867                };
868                td_element1.appendChild(chk_box_element);
869               
870                td_element2 = document.createElement("TD");
871                td_element2.className = "td_msg";
872                td_element2.setAttribute("width", "2%");
873                if (headers_msgs.attachment && headers_msgs.attachment.number_attachments > 0)
874                        td_element2.innerHTML = "<img src ='templates/"+template+"/images/clip.gif' title='" + url_decode(headers_msgs.attachment.names) + "'>";                       
875                       
876                td_element21 = document.createElement("TD");
877                td_element21.className = "td_msg";
878                td_element21.setAttribute("width", "1%");
879                td_element21.id = "td_message_answered_"+headers_msgs.msg_number;
880
881                if (headers_msgs.attachment && headers_msgs.attachment.number_attachments > 0) {
882                        attach_name = headers_msgs.attachment.names.split(", ");
883                        for(var item in attach_name)
884                        {
885                                if (url_decode(attach_name[item]) != 'smime.p7s' && url_decode(attach_name[item]) != 'smime.p7m'){
886                                        td_element21.innerHTML = "<img src ='templates/"+template+"/images/clip.gif' title='" + url_decode(attach_name[item]) + "'>";
887                                        break;
888                                }
889                        }
890                }
891
892                if ((headers_msgs.Forwarded == 'F')  || (headers_msgs.Draft == 'X' && headers_msgs.Answered == 'A')){
893                        td_element21.innerHTML = "<img src ='templates/"+template+"/images/forwarded.gif' title='"+get_lang('Forwarded')+"'>";
894                        headers_msgs.Draft = ''
895                        headers_msgs.Answered = '';
896                        headers_msgs.Forwarded = 'F';
897                }
898                else if (headers_msgs.Draft == 'X')
899                        td_element21.innerHTML = "<img src ='templates/"+template+"/images/draft.gif' title='"+get_lang('Draft')+"'>";
900                else if (headers_msgs.Answered == 'A')
901                        td_element21.innerHTML = "<img src ='templates/"+template+"/images/answered.gif' title='"+get_lang('Answered')+"'>";
902                else
903                        td_element21.innerHTML = "&nbsp;&nbsp;&nbsp;";
904
905                td_element22 = document.createElement("TD");
906                td_element22.className = "td_msg";
907                td_element22.setAttribute("width", "1%");
908                td_element22.id = "td_message_signed_"+headers_msgs.msg_number;
909
910        //td_element23 = document.createElement("TD");
911                //td_element23.setAttribute("width", "1%");
912                //td_element23.id = "td_message_signed_"+headers_msgs.msg_number;
913        switch(headers_msgs.ContentType)
914                {
915            case "signature":
916                        {
917                                td_element22.innerHTML = "<img src ='templates/"+template+"/images/signed_msg.gif' title='" + get_lang('Signed message') + "'>";
918                                break;
919                        }
920            case "cipher":
921                        {
922                                td_element22.innerHTML = "<img src ='templates/"+template+"/images/lock.gif' title='" + get_lang('Crypted message') + "'>";
923                                break;
924                        }
925            default:
926                        {
927                                break;
928                        }
929                }
930
931        td_element23 = document.createElement("TD");
932                td_element23.className = "td_msg"
933                td_element23.setAttribute("width", "1%");
934                td_element23.id = "td_message_important_"+headers_msgs.msg_number;
935
936                if (headers_msgs.Flagged == 'F' || (headers_msgs.Importance.toLowerCase().indexOf("high") != -1 && parseInt(preferences.use_important_flag)))
937                {
938                        td_element23.innerHTML = "<img src ='templates/"+template+"/images/important.gif' title='"+get_lang('Important')+"'>";
939                }
940                else
941                        td_element23.innerHTML = "&nbsp;&nbsp;&nbsp;";
942
943                td_element24 = document.createElement("TD");
944                td_element24.className = "td_msg";
945                td_element24.setAttribute("width", "1%");
946                td_element24.id = "td_message_sent_"+headers_msgs.msg_number;
947                td_element24.innerHTML = "&nbsp;&nbsp;&nbsp;";
948                // preload image
949                var _img_sent = new Image();
950                _img_sent.src    = "templates/"+template+"/images/sent.gif";
951
952
953
954                var td_element25 = document.createElement("TD");
955                td_element25.className = "td_msg";
956                td_element25.setAttribute("width", "1%");
957                td_element25.id = "td_message_unseen_"+headers_msgs.msg_number;
958                if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N'))
959                        td_element25.innerHTML = "<img src ='templates/"+template+"/images/unseen.gif' title='"+get_lang('Unseen')+"'>";
960                else
961                        td_element25.innerHTML = "<img src ='templates/"+template+"/images/seen.gif' title='"+get_lang('Seen')+"'>";
962
963
964                td_element3 = document.createElement("TD");
965                td_element3.className = "td_msg";
966                td_element3.id = "td_who_"+ headers_msgs.msg_number;
967                td_element3.setAttribute("width", "20%");
968                var _onclick = function(){InfoContact.hide();proxy_mensagens.get_msg(headers_msgs.msg_number, msg_folder,true, show_msg);};
969                td_element3.onclick = _onclick;
970                td_element3.innerHTML = '&nbsp;';
971               
972                if (typeof(headers_msgs.from) == 'undefined')
973                        return false;
974                if( headers_msgs.from.email && headers_msgs.from.email.toLowerCase() == Element("user_email").value )
975                {
976                        td_element3.onmouseover = function () {this.title=headers_msgs.to.email;};
977                        if (headers_msgs.Draft == 'X')
978                                td_element3.innerHTML += "<span style=\"color:red\">("+get_lang("Draft")+") </span>";
979                        else{                           
980                                if(headers_msgs.to.email != null && headers_msgs.to.email.toLowerCase() != Element("user_email").value)
981                                        td_element24.innerHTML = "<img valign='center' src ='templates/"+template+"/images/sent.gif' title='"+get_lang('Sent')+"'>";
982                       
983                                if ((headers_msgs.to)&&(headers_msgs.to.name != null))
984                                        td_element3.innerHTML += headers_msgs.to.name;
985                                else if (headers_msgs.to){
986                                        td_element3.innerHTML += headers_msgs.to.email;
987                                }
988                        }
989                }
990                else{
991                        if (headers_msgs.Draft == 'X'){
992                                td_element3.innerHTML = "<span style=\"color:red\">("+get_lang("Draft")+") </span>";
993                        }
994                        else{                           
995                                var spanSender = document.createElement("SPAN");
996                                spanSender.onmouseover = function (event) {this.style.textDecoration = "underline";try {InfoContact.begin(this,headers_msgs.from.email)} catch(e){};};
997                                spanSender.onmouseout = function (){ try {this.style.textDecoration = "none"; clearTimeout(InfoContact.timeout);} catch(e){}};
998                                spanSender.innerHTML =  headers_msgs.from.name != null ? headers_msgs.from.name : headers_msgs.from.email;
999                                if (spanSender.innerHTML.indexOf(" ") == '-1' && spanSender.innerHTML.length > 25){
1000                                        spanSender.innerHTML = spanSender.innerHTML.substring(0,25) + "...";
1001                                }
1002                                else if (spanSender.innerHTML.length > 40 ){
1003                                        spanSender.innerHTML = spanSender.innerHTML.substring(0,40) + "...";
1004                                }                               
1005                                td_element3.appendChild(spanSender);                           
1006                        }
1007                }                       
1008                td_element4 = document.createElement("TD");
1009                td_element4.className = "td_msg";
1010                td_element4.setAttribute("width", "50%");
1011                td_element4.onclick = _onclick;
1012//              td_element4.setAttribute("style","white-space:nowrap;");
1013                td_element4.innerHTML = !is_ie ? "<a nowrap id='a_message_"+tr_element.id+"'>&nbsp;" : "&nbsp;";
1014               
1015                if ((headers_msgs.subject)&&(headers_msgs.subject.length > 50))
1016                {
1017//                      if( (headers_msgs.subject.length+tr_element.msg_sample.length)>
1018                        td_element4.innerHTML += headers_msgs.subject.substring(0,50) + "..." + "<span style=\"color:#b3b3b3;\">  " + tr_element.msg_sample +"</span>";//modificacao feita para exibir o trecho do body ao lado do assunto da mensagem;
1019                }
1020                else
1021                {
1022                        td_element4.innerHTML += headers_msgs.subject + "<span style=\"color:#b3b3b3;\">  " + tr_element.msg_sample + "</span>";//modificacao feita para exibir o trecho do body ao lado do assunto da mensagem;
1023                }
1024                                       
1025                td_element4.title=tr_element.tip;
1026                if(!is_ie){
1027                        td_element4.innerHTML += "</a>";
1028                }
1029               
1030
1031                td_element5 = document.createElement("TD");
1032                td_element5.className = "td_msg";
1033                td_element5.setAttribute("width", "14%");
1034                td_element5.onclick = _onclick;
1035                td_element5.setAttribute("align", "center");
1036                td_element5.innerHTML = headers_msgs.udate;
1037
1038                td_element6 = document.createElement("TD");
1039                td_element6.className = "td_msg";
1040                td_element6.setAttribute("width", "14%");
1041                td_element6.onclick = _onclick;
1042                td_element6.setAttribute("noWrap","true");
1043                td_element6.setAttribute("align", "center");
1044
1045                td_element6.innerHTML = borkb(headers_msgs.Size);
1046
1047
1048                tr_element.appendChild(td_element1);
1049                tr_element.appendChild(td_element2);
1050                tr_element.appendChild(td_element21);
1051                tr_element.appendChild(td_element22);
1052                tr_element.appendChild(td_element23);
1053                tr_element.appendChild(td_element24);
1054                tr_element.appendChild(td_element25);
1055                tr_element.appendChild(td_element3);
1056                tr_element.appendChild(td_element4);
1057                tr_element.appendChild(td_element5);
1058                tr_element.appendChild(td_element6);
1059                return tr_element;
1060}
1061
1062function sort_box(search, sort){
1063        var message_header = Element("message_header_"+search);
1064        var handler_draw_box = function(data){
1065                draw_box(data, current_folder,true);
1066                draw_paging(Element('tot_m').innerHTML);
1067                //Mostrar as msgs nao lidas de acordo com o filtro de relevancia
1068                var msgs_unseen = 0;
1069                for(i in data){
1070                        if(data[i].Unseen == 'U')
1071                                msgs_unseen++;
1072        }
1073                Element("new_m").innerHTML = '<font style="color:'+(msgs_unseen == 0 ? '': 'red')+'">' + msgs_unseen + '</font>';
1074        }
1075
1076        if(sort_box_type == sort && search_box_type == search){
1077                sort_box_reverse = sort_box_reverse ? 0 : 1;
1078        }
1079        else if(sort_box_type != sort){
1080                if ( (sort == 'SORTFROM') || (sort == 'SORTSUBJECT') )
1081                        sort_box_reverse = 0;
1082                else
1083                        sort_box_reverse = 1;
1084        }
1085               
1086        // Global variable.
1087        sort_box_type = sort;
1088        search_box_type = search;
1089
1090        proxy_mensagens.messages_list(current_folder,1,preferences.max_email_per_page,sort,search,sort_box_reverse,preferences.preview_msg_subject,preferences.preview_msg_tip,handler_draw_box);
1091        current_page = 1;
1092        //Comentado para nao sobrepor o numero de msgs nao lidas ao utilizar os filtros
1093        //update_menu();
1094}
1095function draw_header_box(){
1096        switch(sort_box_type){
1097                case 'SORTFROM':
1098                        type_name = get_lang("Who");
1099                        break;
1100                case 'SORTSUBJECT':
1101                        type_name = get_lang("Subject");
1102                        break;
1103                case 'SORTARRIVAL':
1104                        type_name = get_lang("Date");
1105                        break;
1106                case 'SORTSIZE':
1107                        type_name = get_lang("Size");
1108                        break;
1109                default:
1110                        type_name = get_lang("Date");
1111                        break;
1112        }
1113        document.getElementById("message_header_SORTFROM_"+numBox).innerHTML    = get_lang("Who");
1114        document.getElementById("message_header_SORTSUBJECT_"+numBox).innerHTML = get_lang("Subject");
1115        document.getElementById("message_header_SORTARRIVAL_"+numBox).innerHTML = get_lang("Date");
1116        document.getElementById("message_header_SORTSIZE_"+numBox).innerHTML    = get_lang("Size");     
1117        document.getElementById("message_header_"+(sort_box_type.lastIndexOf("SORT") != "-1" ? sort_box_type : "SORTARRIVAL")+"_"+numBox ).innerHTML = "<B>"+type_name+"</B><img src ='templates/"+template+"/images/arrow_"+(sort_box_reverse == 1 ? 'desc' : 'asc')+"endant.gif'>";
1118}
1119function draw_message(info_msg, ID){
1120        var content = document.getElementById('content_id_' + ID);
1121       
1122        var menuHidden = Element("folderscol").style.display == 'none' ? true : false;
1123         //////////////////////////////////////////////////////////////////////////////////////////////////////
1124        //Make the next/previous buttom.
1125        //////////////////////////////////////////////////////////////////////////////////////////////////////
1126        var next_previous_msg_td = document.createElement("TD");
1127        next_previous_msg_td.setAttribute("noWrap","true");
1128        next_previous_msg_td.align = "right";
1129        next_previous_msg_td.width = "40px";
1130        var img_next_msg = document.createElement("IMG");
1131        img_next_msg.id = 'msg_opt_next_' + ID;
1132        img_next_msg.src = './templates/'+template+'/images/down.button.png';
1133        img_next_msg.title = get_lang('Next');
1134        img_next_msg.style.cursor = 'pointer';
1135
1136        // Old
1137        //img_next_msg.onclick = function () {cExecute ("$this.imap_functions.get_info_next_msg&msg_number="+ info_msg.msg_number + "&msg_folder="+ info_msg.msg_folder + "&sort_box_type="+ sort_box_type +  "&search_box_type="+ search_box_type +"&sort_box_reverse="+ sort_box_reverse +"&reuse_border="+ID, show_msg)};
1138    var folder_id = 0;
1139    folder_id = info_msg.original_ID ? info_msg.original_ID: info_msg.msg_number;
1140        var folder = document.getElementById(folder_id);
1141        if (!folder){
1142                delete_border(ID);
1143                return;
1144                }
1145    if (folder){ // mensagem local criptografada nao tem ID da pasta local
1146        if (folder.nextSibling){
1147            var nextMsgBox = folder.nextSibling.name?folder.nextSibling.name:info_msg.msg_folder;
1148
1149            if (nextMsgBox == "INBOX/decifradas")// teste para ver se a mensagem vem da pasta oculta decifradas
1150                    nextMsgBox = get_current_folder();
1151
1152            img_next_msg.onclick = function()
1153            {
1154                currentTab = ID;
1155                openTab.type[ID] = 2;
1156                            proxy_mensagens.get_msg(folder.nextSibling.id,nextMsgBox,true,show_msg);
1157                //cExecute("$this.imap_functions.get_info_msg&msg_number="+folder.nextSibling.id+"&msg_folder="+nextMsgBox, show_msg);
1158            };
1159        }
1160        else
1161        {
1162            img_next_msg.src = "./templates/"+template+"/images/down.gray.button.png";
1163            img_next_msg.style.cursor = 'default';
1164
1165        }
1166    }
1167    else
1168    {
1169        img_next_msg.src = "./templates/"+template+"/images/down.gray.button.png";
1170                img_next_msg.style.cursor = 'default';
1171                if (!proxy_mensagens.is_local_folder(get_current_folder()) && !(info_msg.msg_folder == "INBOX/decifradas")) // testa se a mensagem e local
1172                {
1173            img_next_msg.onclick = function()
1174                {
1175                    /*current_page++;
1176                    msg_range_end = (current_page*preferences.max_email_per_page);
1177                    msg_range_begin = (msg_range_end-(preferences.max_email_per_page)+1);
1178                    kill_current_box();
1179                    cExecute ('$this.imap_functions.get_range_msgs2&folder='+current_folder+'&msg_range_begin='+msg_range_begin+'&msg_range_end='+msg_range_end+'&sort_box_reverse=1', function handler(data){draw_box(data, current_folder);}) */
1180                        delete_border(ID);
1181                };
1182        }
1183    }
1184        var img_space = document.createElement("SPAN");
1185        img_space.innerHTML = "&nbsp;";
1186        var img_previous_msg = document.createElement("IMG");
1187        img_previous_msg.id = 'msg_opt_previous_' + ID;
1188        img_previous_msg.src = './templates/'+template+'/images/up.button.png';
1189        img_previous_msg.title = get_lang('Previous');
1190        img_previous_msg.style.cursor = 'pointer';
1191
1192        //Old
1193        //img_previous_msg.onclick = function () {cExecute ("$this.imap_functions.get_info_previous_msg&msgs_number="+ info_msg.msg_number + "&folder="+ info_msg.msg_folder + "&sort_box_type="+ sort_box_type+ "&search_box_type="+ search_box_type + "&sort_box_reverse="+ sort_box_reverse +"&reuse_border="+ID, show_msg)}
1194        //folder = document.getElementById(ID.substr(0, ID.indexOf('_')));
1195        if (!folder){
1196                delete_border(ID);
1197                return;
1198                }
1199    if (folder){ // mensagem local criptografada nao tem ID da pasta local
1200        if (folder.previousSibling)
1201        {
1202            var previousMsgBox = folder.previousSibling.name?folder.previousSibling.name:info_msg.msg_folder;
1203
1204            if (previousMsgBox == "INBOX/decifradas") // teste para ver se a mensagem vem da pasta oculta decifradas
1205                    previousMsgBox = get_current_folder();
1206
1207            img_previous_msg.onclick = function()
1208            {
1209                currentTab = ID;
1210                openTab.type[ID] = 2;
1211                //cExecute("$this.imap_functions.get_info_msg&msg_number="+folder.previousSibling.id+"&msg_folder=" + previousMsgBox, show_msg);
1212                            proxy_mensagens.get_msg(folder.previousSibling.id,previousMsgBox,true,show_msg);
1213            };
1214        }
1215        else
1216        {
1217            img_previous_msg.src = "./templates/"+template+"/images/up.gray.button.png";
1218            img_previous_msg.style.cursor = 'default';
1219        }
1220        }
1221        else
1222        {
1223                img_previous_msg.src = "./templates/"+template+"/images/up.gray.button.png";
1224                img_previous_msg.style.cursor = 'default';
1225                if (!proxy_mensagens.is_local_folder(get_current_folder()) && !(info_msg.msg_folder == "INBOX/decifradas")) // testa se a mensagem e local
1226        {
1227            img_previous_msg.onclick = function()
1228            {
1229                delete_border(ID);
1230            };
1231        }
1232    }
1233        next_previous_msg_td.appendChild(img_previous_msg);
1234        next_previous_msg_td.appendChild(img_space);
1235        next_previous_msg_td.appendChild(img_next_msg);
1236        //////////////////////////////////////////////////////////////////////////////////////////////////////
1237        //Make the header message.
1238        //////////////////////////////////////////////////////////////////////////////////////////////////////
1239        var table_message = document.createElement("TABLE");
1240        var tbody_message = document.createElement("TBODY");
1241        table_message.border = "0";
1242        table_message.width = "100%";
1243
1244        //////////////////////////////////////////////////////////////////////////////////////////////////////
1245        //Make the options message.
1246        //////////////////////////////////////////////////////////////////////////////////////////////////////
1247        var tr0 = document.createElement("TR");
1248        tr0.className = "tr_message_header";
1249        var td0 = document.createElement("TD");
1250        var table_message_options = document.createElement("TABLE");
1251        table_message_options.width = "100%";
1252        table_message_options.border = '0';
1253        table_message_options.className = 'table_message';
1254        var tbody_message_options = document.createElement("TBODY");
1255        var tr = document.createElement("TR");
1256        var td = document.createElement("TD");
1257        td.setAttribute("noWrap","true");
1258        var _name = '';
1259        var _maxChar = menuHidden ? 40 : 15;
1260       
1261        if (info_msg.from.name)
1262        {
1263                var spanName = document.createElement("SPAN");
1264                        spanName.innerHTML = info_msg.from.name;
1265                _name = spanName.innerHTML.length > _maxChar ? spanName.innerHTML.substring(0,_maxChar) + "..." : spanName.innerHTML;
1266        }
1267        else
1268                _name = info_msg.from.email.length > _maxChar ? info_msg.from.email.substring(0,_maxChar) + "..." : info_msg.from.email;
1269
1270        td.innerHTML = _name.bold() + ', ' + info_msg.smalldate;
1271        if (info_msg.attachments && info_msg.attachments.length > 0)
1272                td.innerHTML += "&nbsp<img style='cursor:pointer' onclick='javascript:Element(\"option_hide_more_"+ID+"\").onclick()' src ='templates/"+template+"/images/clip.gif' title='"+info_msg.attachments.names+"'>";
1273       
1274        if (typeof(info_msg.signature) == 'string')
1275        {       
1276                if (info_msg.signature != "void")
1277                        td.innerHTML += '&nbsp;<img style="cursor:pointer" onclick="alert(\''+ get_lang("This message is signed, and you can trust.") + info_msg.signature +'\');" src="templates/'+template+'/images/signed.gif">';
1278                else
1279                        td.innerHTML += "&nbsp;<img style='cursor:pointer' onclick='alert(\""+get_lang("This message is signed, but it is invalid. You should not trust on it.")+"\");' title='"+get_lang("Voided message")+"' src='templates/"+template+"/images/invalid.gif'>";
1280        }
1281       
1282        if (info_msg.DispositionNotificationTo)
1283        {
1284                td.innerHTML += '&nbsp;<img style="cursor:pointer" alt="'+ get_lang('Message with read notification') + '" title="'+ get_lang('Message with read notification') + '" src="templates/'+template+'/images/notification.gif">';
1285        }
1286       
1287        // NORMAL MSG
1288        if(info_msg.Draft != 'X')
1289        {
1290        var options = document.createElement("TD");
1291        options.width = "30%";
1292        options.setAttribute("noWrap","true");
1293        var option_hide_more = document.createElement("SPAN");
1294        option_hide_more.className = 'message_options';
1295        options.align = 'right';
1296        option_hide_more.value = 'more_options';
1297        option_hide_more.id = 'option_hide_more_'+ID;
1298        option_hide_more.onclick = function(){
1299                if (this.value == 'more_options'){
1300                        this.innerHTML = "<b><u>"+get_lang('Hide details')+"</u></b>";
1301                        this.value = 'hide_options';
1302                        Element('table_message_others_options_'+ID).style.display = '';
1303                }
1304                else{
1305                        this.innerHTML = get_lang('Show details');
1306                        this.value = 'more_options';
1307                        Element('table_message_others_options_'+ID).style.display = 'none';
1308                }
1309                resizeWindow();
1310        };
1311        var option_mark = document.createElement('TD');
1312        option_mark.align = "left";
1313        option_mark.width = "50%";
1314      var option_mark_as = '<span>'+get_lang("Mark as")+'</span>: ';
1315      var option_mark_as_unseen = '<span class="message_options" onclick="changeLinkState(this,\'seen\'); set_messages_flag(\'unseen\','+folder_id+'); write_msg(\''+get_lang('Message marked as ')+get_lang("Unseen")+'.\');">'+get_lang("Unseen")+'</span>, ';
1316
1317      if (info_msg.Flagged == "F")
1318              var option_mark_important = '<span class="message_options" onclick="changeLinkState(this,\'important\'); set_messages_flag(\'unflagged\','+folder_id+');write_msg(\''+get_lang('Message marked as ')+get_lang("Normal")+'.\');">'+get_lang("Normal")+'</span>';
1319      else
1320              var option_mark_important = '<span class="message_options" onclick="changeLinkState(this,\'normal\');set_messages_flag(\'flagged\','+folder_id+');write_msg(\''+get_lang('Message marked as ')+get_lang("Important")+'.\');">'+get_lang("Important")+'</span>';
1321      option_mark.innerHTML = option_mark_as+option_mark_as_unseen+option_mark_important;
1322        option_hide_more.innerHTML = get_lang('Show details');
1323        options.appendChild(option_hide_more);
1324
1325        var space0 = document.createElement("SPAN");
1326        space0.innerHTML = '&nbsp;|&nbsp;';
1327        var space1 = document.createElement("SPAN");
1328        space1.innerHTML = '&nbsp;|&nbsp;';
1329        var space2 = document.createElement("SPAN");
1330        space2.innerHTML = '&nbsp;|&nbsp;';
1331        var space3 = document.createElement("SPAN");
1332        space3.innerHTML = '&nbsp;|&nbsp;';
1333        var space4 = document.createElement("SPAN");
1334        space4.innerHTML = '&nbsp;|&nbsp;';
1335
1336        var option_forward = document.createElement("SPAN");
1337        option_forward.id = 'msg_opt_forward_'+ID;
1338        option_forward.className = 'message_options';
1339        option_forward.onclick = function(){new_message('forward', ID);};
1340        option_forward.innerHTML = get_lang('Forward');
1341        options.appendChild(space1);
1342        options.appendChild(option_forward);
1343        var option_reply = document.createElement("SPAN");
1344        option_reply.id = 'msg_opt_reply_'+ID;
1345        option_reply.className = 'message_options';
1346        option_reply.onclick = function(){new_message('reply_with_history', ID);};
1347        option_reply.innerHTML = get_lang('Reply');
1348        options.appendChild(space2);
1349
1350        var option_reply_options = document.createElement('IMG');
1351        option_reply_options.id = 'msg_opt_reply_options_'+ID;
1352        option_reply_options.src = '../expressoMail1_2/templates/default/images/down.png';
1353        option_reply_options.value = 'show';
1354
1355        option_reply_options.onmouseover = function(){
1356                option_reply_options.src= '../expressoMail1_2/templates/default/images/over.png';
1357        };
1358        option_reply_options.onmouseout = function(){
1359                if (this.value == 'show')
1360                {
1361                        option_reply_options.src= '../expressoMail1_2/templates/default/images/down.png';
1362                }
1363                else
1364                {
1365                        option_reply_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
1366                }
1367        };
1368        option_reply_options.onclick = function(){
1369                if (this.value != 'hide'){
1370                        this.value = 'hide';
1371                        option_reply_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
1372                        Element('tr_other_options_'+ID).style.display = '';
1373
1374                }
1375                else{
1376                        this.value = 'show';
1377                        option_reply_options.src= '../expressoMail1_2/templates/default/images/down.png';
1378                        Element('tr_other_options_'+ID).style.display = 'none';
1379                }
1380        };
1381        options.appendChild(option_reply_options);
1382        options.appendChild(option_reply);
1383       
1384        tr.appendChild(td);
1385        tr.appendChild(option_mark);
1386        tr.appendChild(options);
1387        tr.appendChild(next_previous_msg_td);
1388        tbody_message_options.appendChild(tr);
1389       
1390        ////////// OTHER OPTIONS ////////////////////
1391        var tr_other_options = document.createElement("TR");
1392        tr_other_options.id = 'tr_other_options_' + ID;
1393        tr_other_options.style.display = 'none';
1394       
1395        var td_other_options = document.createElement("TD");
1396        td_other_options.colSpan = '3';
1397        //td_other_options.align = 'right';
1398        //td_other_options.setAttribute("noWrap","true");
1399        var div_other_options = document.createElement("DIV");
1400
1401        var option_mark_as_unseen = '<span class="message_options" onclick="proxy_mensagens.proxy_set_messages_flag(\'unseen\','+info_msg.msg_number+');write_msg(\''+get_lang('Message marked as ')+get_lang("Unseen")+'.\');">'+get_lang("Unseen")+'</span>, ';
1402        var option_mark_as_important                    = '<span class="message_options" onclick="proxy_mensagens.proxy_set_messages_flag(\'flagged\','+info_msg.msg_number+');write_msg(\''+get_lang('Message marked as ')+get_lang("Important")+'.\');">'+get_lang("Important")+'</span>, ';
1403        var option_mark_as_normal                               = '<span class="message_options" onclick="proxy_mensagens.proxy_set_messages_flag(\'unflagged\','+info_msg.msg_number+');write_msg(\''+get_lang('Message marked as ')+get_lang("Normal")+'.\');">'+get_lang("Normal")+'</span> | ';
1404       
1405        var option_move = '<span class="message_options" onclick=wfolders.makeWindow("'+ID+'","move_to");>'+get_lang("Move")+'</span> | ';
1406        var option_reply_to_all = '<span onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options" onclick=new_message("reply_to_all_with_history","'+ID+'");>'+get_lang("Reply to all")+'</span> | ';
1407        var option_reply_without_history = '<span onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options" onclick=new_message("reply_without_history","'+ID+'");>'+get_lang("Reply without history")+'</span> | ';
1408        var option_reply_to_all_without_history = '<span onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options" onclick=new_message("reply_to_all_without_history","'+ID+'");>'+get_lang("Reply to all without history")+'</span>';
1409
1410        div_other_options.innerHTML = option_reply_to_all + option_reply_without_history + option_reply_to_all_without_history;
1411        if (use_spam_filter) {
1412                if(info_msg.msg_folder == 'INBOX'+cyrus_delimiter+'Spam')
1413                        div_other_options.innerHTML += ' | <span class="message_options" onclick="nospam('+info_msg.msg_number+',\'null\', \''+info_msg.msg_folder+'\')";>'+get_lang("Not Spam")+'</span>';     
1414                else
1415                        div_other_options.innerHTML += ' | <span class="message_options" onclick="spam(\''+info_msg.msg_folder+'\', '+info_msg.msg_number+',\'null\')";>'+get_lang("Mark as Spam")+'</span>';   
1416        }
1417        td_other_options.align = 'right';
1418        td_other_options.style.paddingTop = '3px';
1419        td_other_options.appendChild(div_other_options);
1420
1421
1422        tr_other_options.appendChild(td_other_options);
1423        tbody_message_options.appendChild(tr_other_options);
1424        ////////// END OTHER OPTIONS ////////////////
1425
1426        ////////// BEGIN SIGNATURE //////////////////
1427        if (info_msg.signature && info_msg.signature.length > 0)
1428        {
1429                var tr_signature = document.createElement("TR");
1430                var td_signature = document.createElement("TD");
1431                td_signature.className = 'tr_message_header';
1432                tr_signature.id = 'tr_signature_'+ID;
1433                td_signature.colSpan = "5";
1434                tr_signature.style.display = 'none';
1435
1436                for (i in info_msg.signature)
1437                        td_signature.innerHTML += '<span>'+info_msg.signature[i]+'</span> <br /> ';
1438                var signature_status_pos = info_msg.signature[0].indexOf(get_lang('Message untouched'));
1439                td_signature.id = "td_signature_"+ID;
1440                if(signature_status_pos < 0 )
1441                {
1442                td.innerHTML += '&nbsp;<img style="cursor:pointer" src="templates/'+template+'/images/signed_error.gif" title="'+get_lang("Details")+'">';
1443                tr_signature.style.display = '';
1444                }
1445                else
1446                {
1447                td.innerHTML += '&nbsp;<img style="cursor:pointer" src="templates/'+template+'/images/signed_table.gif" title="'+get_lang("Details")+'">';
1448                }
1449                td.onclick = function(){
1450                var _height = Element("div_message_scroll_"+ID).style.height;
1451                _height = parseInt(_height.replace("px",""));
1452                var _offset = 130;
1453                if (this.value == 'more_cert'){
1454                        //this.innerHTML += "<b><u>Mais Informaᅵᅵes</u></b>";
1455                        this.value = 'hide_cert';
1456                        Element("div_message_scroll_"+ID).style.height = (_height + _offset)+"px";
1457                        Element('tr_signature_'+ID).style.display = 'none';
1458                        Element('td_signature_'+ID).style.display = 'none';
1459
1460                }
1461                else{
1462                        //this.innerHTML += "Mais Informaᅵᅵes";
1463                        this.value = 'more_cert';
1464                        Element("div_message_scroll_"+ID).style.height = (_height - _offset)+"px";
1465                        Element('tr_signature_'+ID).style.display = '';
1466                        Element('td_signature_'+ID).style.display = '';
1467                }
1468        };
1469
1470                tr_signature.appendChild(td_signature);
1471                tbody_message_options.appendChild(tr_signature);
1472        /******************************************* Old signature   ***********************************************/
1473                //if (info_msg.signature != "void")
1474                //      td.innerHTML += '&nbsp;<img style="cursor:pointer" onclick="alert(\''+ get_lang("This message is signed, and you can trust.") + info_msg.signature +'\');" src="'+tpl_img_path+'/signed.gif">';
1475                //else
1476                //      td.innerHTML += "&nbsp;<img style='cursor:pointer' onclick='alert(\""+get_lang("This message is signed, but it is invalid. You should not trust on it.")+"\");' title='"+get_lang("Voided message")+"' src='"+tpl_img_path+"/invalid.gif'>";
1477        /*****************************************                                                                                                                      ********/
1478        }
1479        //////////// END SIGNATURE ////////////////
1480
1481        table_message_options.appendChild(tbody_message_options);
1482        td0.appendChild(table_message_options);
1483        tr0.appendChild(td0);
1484        tbody_message.appendChild(tr0);
1485        }
1486        // IF DRAFT
1487        else
1488        {
1489                var options = document.createElement("TD");
1490                options.width = "1%";
1491                options.setAttribute("noWrap","true");
1492                var option_edit   = ' | <span class="message_options" onclick="new_message(\'edit\',\''+ID+'\');">'+get_lang('Edit')+'</span>';
1493                var option_print = ' | <span class="message_options" onclick="print_msg(\''+info_msg.msg_folder+'\',\''+info_msg.msg_number+'\',\''+ID+'\');">'+get_lang('Print')+'</span>';
1494                var option_hide_more = document.createElement("SPAN");
1495                option_hide_more.className = 'message_options';
1496                options.align = 'right';
1497                option_hide_more.value = 'more_options';
1498                option_hide_more.id = 'option_hide_more_'+ID;
1499                option_hide_more.innerHTML = get_lang('Show details');
1500                option_hide_more.onclick = function(){
1501                        var _height = Element("div_message_scroll_"+ID).style.height;
1502                        _height = parseInt(_height.replace("px",""));
1503                        var _offset = 35;
1504                        if (this.value == 'more_options'){
1505                                this.innerHTML = "<b><u>"+get_lang('Hide details')+"</u></b>";
1506                                this.value = 'hide_options';
1507                                Element("div_message_scroll_"+ID).style.height = (_height - _offset)+"px";
1508                                Element('table_message_others_options_'+ID).style.display = '';
1509                        }
1510                        else{
1511                                this.innerHTML = get_lang('Show details');
1512                                this.value = 'more_options';
1513                                Element("div_message_scroll_"+ID).style.height = (_height + _offset)+"px";
1514                                Element('table_message_others_options_'+ID).style.display = 'none';
1515                        }
1516                };
1517                options.appendChild(option_hide_more);
1518                options_actions = document.createElement('SPAN');
1519                options_actions.innerHTML = option_edit + option_print;
1520                options.appendChild(options_actions);
1521                tr.appendChild(td);
1522                tr.appendChild(options);
1523                tr.appendChild(next_previous_msg_td);
1524                tbody_message_options.appendChild(tr);
1525                table_message_options.appendChild(tbody_message_options);
1526                td0.appendChild(table_message_options);
1527                tr0.appendChild(td0);
1528                tbody_message.appendChild(tr0);
1529        }
1530        //////////////////////////////////////////////////////////////////////////////////////////////////////
1531        // END options message.
1532        //////////////////////////////////////////////////////////////////////////////////////////////////////
1533
1534        var table_message_others_options = document.createElement("TABLE");
1535        table_message_others_options.id = 'table_message_others_options_' + ID;
1536        table_message_others_options.width = "100%";
1537        table_message_others_options.style.display = 'none';
1538        table_message_others_options.className = "table_message";
1539        var tbody_message_others_options = document.createElement("TBODY");
1540        var tr1 = document.createElement("TR");
1541        tr1.className = "tr_message_header";
1542        var td1 = document.createElement("TD");
1543        td1.innerHTML = get_lang("From: ");
1544        td1.appendChild(deny_email(info_msg.from.email));
1545        td1.width = "7%";
1546       
1547        if (info_msg.sender){
1548                var tr111 = document.createElement("TR");
1549                tr111.className = "tr_message_header";
1550                var td111 = document.createElement("TD");
1551                td111.innerHTML = get_lang("Sent by")+": ";
1552                td111.appendChild(deny_email(info_msg.sender.email));
1553                td111.setAttribute("noWrap","true");
1554                var sender = document.createElement("TD");
1555                sender.id = "sender_"+ID;
1556                var sender_values = document.createElement("INPUT");
1557                sender_values.id = "sender_values_"+ID;
1558                sender_values.type = "HIDDEN";
1559                sender_values.value = info_msg.sender.full; //Veio do IMAP, sem images nem links.
1560                sender.innerHTML += draw_plugin_cc(ID, info_msg.sender.full);
1561                sender.className = "header_message_field";
1562                tr111.appendChild(td111);
1563                tr111.appendChild(sender);
1564                tr111.appendChild(sender_values);
1565                tbody_message_others_options.appendChild(tr111);
1566        }
1567       
1568        var from = document.createElement("TD");
1569        from.id = "from_"+ID;
1570        from.innerHTML = info_msg.from.full;
1571        if (info_msg.Draft != "X"){
1572                from.innerHTML += draw_plugin_cc(ID, info_msg.from);
1573                tbody_message_others_options.appendChild(tr1);
1574        }
1575        from.className = "header_message_field";
1576        var from_values = document.createElement("INPUT");
1577        from_values.id = "from_values_"+ID;
1578        from_values.type = "HIDDEN";
1579        from_values.value = info_msg.from.full; //Veio do IMAP, sem images nem links.
1580
1581        var local_message = document.createElement("INPUT");
1582        local_message.id = "is_local_"+ID;
1583        local_message.name = "is_local";
1584        local_message.type = "HIDDEN";
1585        local_message.value = (info_msg.local_message)?"1":"0";
1586
1587        tr1.appendChild(td1);
1588        tr1.appendChild(from);
1589        tr1.appendChild(from_values);
1590        tr1.appendChild(local_message);
1591
1592
1593
1594        if (info_msg.reply_to){
1595                var tr11 = document.createElement("TR");
1596                tr11.className = "tr_message_header";
1597                var td11 = document.createElement("TD");
1598                td11.innerHTML = get_lang("Reply to")+": ";
1599                td11.setAttribute("noWrap","true");
1600                var reply_to = document.createElement("TD");
1601                reply_to.id = "reply_to_"+ID;
1602               
1603                var reply_to_values = document.createElement("INPUT");
1604                reply_to_values.id = "reply_to_values_"+ID;
1605                reply_to_values.type = "HIDDEN";
1606                reply_to_values.value = info_msg.reply_to; //Veio do IMAP, sem images nem links.
1607                reply_to.innerHTML = draw_plugin_cc(ID, info_msg.reply_to);
1608                reply_to.className = "header_message_field";
1609                tr11.appendChild(td11);
1610                tr11.appendChild(reply_to);
1611                tr11.appendChild(reply_to_values);
1612                tbody_message_others_options.appendChild(tr11);
1613        }
1614        //////////////////////////////////////////////////////////////////////////////////////////////////////
1615        var tr2 = document.createElement("TR");
1616        tr2.className = "tr_message_header";
1617        var td2 = document.createElement("TD");
1618        td2.innerHTML = get_lang("To: ");
1619        var to = document.createElement("TD");
1620        to.id = "to_"+ID;
1621
1622        var to_values = document.createElement("INPUT");
1623        to_values.id = "to_values_"+ID;
1624        to_values.type = "HIDDEN";
1625        to_values.value = info_msg.toaddress2; //Veio do IMAP, sem images nem links.   
1626
1627        // Salva a pasta da mensagem
1628        var input_current_folder = document.createElement('input');     
1629        input_current_folder.id = "input_folder_"+ID;
1630        input_current_folder.name = "input_folder";
1631        input_current_folder.type = "hidden";
1632        input_current_folder.value = info_msg.msg_folder;
1633        td2.appendChild(input_current_folder); 
1634        // fim
1635        toaddress_array[ID] = info_msg.toaddress2.split(",");
1636        if (toaddress_array[ID].length > 1){
1637                to.innerHTML += draw_plugin_cc(ID, toaddress_array[ID][0]);
1638                var div_toaddress = document.createElement("SPAN");
1639                div_toaddress.id = "div_toaddress_"+ID;
1640                div_toaddress.style.display="";
1641                div_toaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','to');>"+get_lang('more')+"</a>)";
1642                to.appendChild(div_toaddress);         
1643        }
1644        else {
1645                toAdd = toaddress_array[ID].toString().replace("<","&lt;");
1646                toAdd = toAdd.replace(">","&gt;");
1647                to.innerHTML += draw_plugin_cc(ID,toAdd);
1648        }
1649        to.className = "header_message_field";
1650        tr2.appendChild(td2);
1651        tr2.appendChild(to);
1652        tr2.appendChild(to_values);
1653        tbody_message_others_options.appendChild(tr2);
1654
1655        if (info_msg.cc){
1656                var tr3 = document.createElement("TR");
1657                tr3.className = "tr_message_header";
1658                var td3 = document.createElement("TD");
1659                td3.innerHTML = "CC: ";
1660                var cc = document.createElement("TD");
1661                cc.id = "cc_"+ID;
1662
1663                var cc_values = document.createElement("INPUT");
1664                cc_values.id = "cc_values_"+ID;
1665                cc_values.type = "HIDDEN";
1666                cc_values.value = info_msg.cc;
1667               
1668                ccaddress_array[ID] = info_msg.cc.split(",");           
1669                if (ccaddress_array[ID].length > 1){
1670                        var div_ccaddress = document.createElement("SPAN");
1671                        div_ccaddress.id = "div_ccaddress_"+ID;
1672                        var div_ccaddress_full = document.createElement("SPAN");
1673                        div_ccaddress_full.id = "div_ccaddress_full_"+ID;               
1674                        div_ccaddress.style.display="";
1675                        cc.innerHTML = draw_plugin_cc(ID, ccaddress_array[ID][0]);
1676                        div_ccaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','cc');>"+get_lang('more')+"</a>)";
1677                        cc.appendChild(div_ccaddress);
1678                }
1679                else{
1680                        cc.innerHTML = draw_plugin_cc(ID, info_msg.cc);
1681                }
1682                cc.className = "header_message_field";
1683                tr3.appendChild(td3);
1684                tr3.appendChild(cc);
1685                tr3.appendChild(cc_values);
1686                tbody_message_others_options.appendChild(tr3);
1687        }
1688
1689        /*
1690         * @AUTHOR Rodrigo Souza dos Santos
1691         * @MODIFY-DATE 2008/09/11
1692         * @BRIEF Adding routine to create bcc field if there is one.
1693         */
1694        if (info_msg.bcc)
1695        {
1696                var tr3 = document.createElement("tr");
1697                tr3.className = "tr_message_header";
1698                var td3 = document.createElement("td");
1699                td3.innerHTML = get_lang("BCC") + " : ";
1700                var cco = document.createElement("td");
1701                cco.id = "cco_"+ID;
1702
1703                var cco_values = document.createElement("input");
1704                cco_values.id = "cco_values_"+ID;
1705                cco_values.type = "hidden";
1706                cco_values.value = info_msg.bcc;
1707
1708                ccoaddress_array[ID] = info_msg.bcc.split(",");         
1709                if (ccoaddress_array[ID].length > 1){
1710                        var div_ccoaddress = document.createElement("SPAN");
1711                        div_ccoaddress.id = "div_ccoaddress_"+ID;
1712                        var div_ccoaddress_full = document.createElement("SPAN");
1713                        div_ccoaddress_full.id = "div_ccoaddress_full_"+ID;             
1714                        div_ccoaddress.style.display="";
1715
1716                        /*
1717                         * The function below is ugly, doesn't possible use this.
1718                         * The problem is that the code's function was written
1719                         * on a hardcode concept.
1720                         */
1721                        //cco.innerHTML = draw_plugin_cc(ID, ccoaddress_array[ID][0]);
1722                        cco.innerHTML = ccoaddress_array[ID][0];
1723                        div_ccoaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','cco');>"+get_lang('more')+"</a>)";
1724                        cco.appendChild(div_ccoaddress);
1725                }
1726                else{
1727                        /*
1728                         * The function below is ugly, it is not possible to use this.
1729                         * The problem is that the code's function was written
1730                         * on a hardcode concept.
1731                         */
1732                        //cco.innerHTML = draw_plugin_cc(ID, info_msg.cco);
1733                        cco.innerHTML = info_msg.bcc;
1734                }
1735                cco.className = "header_message_field";
1736                tr3.appendChild(td3);
1737                tr3.appendChild(cco);
1738                tr3.appendChild(cco_values);
1739                tbody_message_others_options.appendChild(tr3);
1740        }
1741
1742        var tr4 = document.createElement("TR");
1743        tr4.className = "tr_message_header";
1744        var td4 = document.createElement("TD");
1745        td4.innerHTML = get_lang("Date: ");
1746        var date = document.createElement("TD");
1747        date.id = "date_"+ID;
1748        date.innerHTML = info_msg.fulldate;
1749        var date_day = document.createElement("INPUT");
1750        date_day.id = "date_day_"+ID;
1751        date_day.type = "HIDDEN";
1752        date_day.value = info_msg.msg_day;
1753        var date_hour = document.createElement("INPUT");
1754        date_hour.id = "date_hour_"+ID;
1755        date_hour.type = "HIDDEN";
1756        date_hour.value = info_msg.msg_hour
1757        date.className = "header_message_field";
1758        tr4.appendChild(td4);
1759        tr4.appendChild(date);
1760        tr4.appendChild(date_day);
1761        tr4.appendChild(date_hour);
1762        tbody_message_others_options.appendChild(tr4);
1763       
1764        var tr5 = document.createElement("TR");
1765        tr5.className = "tr_message_header";
1766        var td5 = document.createElement("TD");
1767        td5.innerHTML = get_lang("Subject");
1768        var subject = document.createElement("TD");
1769        subject.id = "subject_"+ID;
1770        subject.innerHTML = info_msg.subject;
1771        subject.className = "header_message_field";
1772        tr5.appendChild(td5);
1773        tr5.appendChild(subject);
1774        tbody_message_others_options.appendChild(tr5);
1775        if ( info_msg.attachments && info_msg.attachments.length > 0 ){
1776        var tr6 = document.createElement("TR");
1777                tr6.className = "tr_message_header";
1778                var td6 = document.createElement("TD");
1779                td6.innerHTML = get_lang("Attachments: ");
1780
1781                var attachments = document.createElement("TD");
1782                td6.vAlign = "top";
1783                attachments.align='left';
1784                var zipped_attachments = '';
1785                if(info_msg.attachments.length >= 1) {
1786                        var zipped_attachments  = document.createElement("TABLE");
1787                        zipped_attachments.style.marginBottom = "4px";
1788                        zipped_attachments.cellPadding="0";
1789                        zipped_attachments.cellSpacing="0";
1790                        var td = document.createElement("TD");
1791                        if(info_msg.attachments.length > 1) {
1792                                var link_attachment     = document.createElement("A");
1793                 if(proxy_mensagens.is_local_folder(current_folder))
1794                    link_attachment.setAttribute("href", "javascript:expresso_local_messages.download_all_local_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
1795                else
1796                    link_attachment.setAttribute("href", "javascript:download_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
1797                                link_attachment.innerHTML = " "+info_msg.attachments.length+' '+get_lang('files')+' :: '+get_lang('Download all atachments');
1798                                link_attachment.innerHTML += '<BR>';
1799                                td.appendChild(link_attachment);
1800                        }
1801                        var tr = document.createElement("TR");
1802                        if(parseInt(preferences.remove_attachments_function))
1803                        {
1804                                var del_attachments = document.createElement("A");
1805                                del_attachments.setAttribute("href", "javascript:remove_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
1806                                del_attachments.innerHTML = get_lang('remove all attachments');
1807                                del_attachments.appendChild(document.createElement('BR'));
1808                                td.appendChild(del_attachments);
1809                                tr.appendChild(td);
1810                        }
1811                        tr.appendChild(td);
1812                        zipped_attachments.appendChild(tr);
1813                        attachments.appendChild(zipped_attachments);
1814                }
1815
1816                attachments.id = "attachments_" + ID;
1817                for (var i=0; i<info_msg.attachments.length; i++){
1818                        var link_attachment = document.createElement("A");
1819                        link_attachment.setAttribute("href", proxy_mensagens.link_anexo(info_msg,i));
1820//                      link_attachment.setAttribute("href", "javascript:download_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"',"+i+",'"+info_msg.attachments[i].pid+"','"+info_msg.attachments[i].encoding+"')");
1821                        link_attachment.innerHTML = url_decode(info_msg.attachments[i].name);
1822                        link_attachment.innerHTML = borkb(info_msg.attachments[i].fsize);
1823                        if((url_decode(info_msg.attachments[i].name).indexOf(".ics")!=-1) || (url_decode(info_msg.attachments[i].name).indexOf(".vcard")!=-1)){
1824                                //Link para importar calendário
1825                                var link_import_attachment = new Image();
1826                                link_import_attachment.src = "templates/"+template+"/images/new.png";
1827                                link_import_attachment.setAttribute("onclick","javascript:import_calendar('"+info_msg.msg_folder+"&msg_number="+info_msg.msg_number+"&msg_part="+info_msg.attachments[i].pid+"&idx_file="+i+"&encoding="+info_msg.attachments[i].encoding+"');");
1828                                link_import_attachment.title = get_lang("Import to calendar");
1829                                link_import_attachment.align = "top";                           
1830                                link_import_attachment.style.cursor = "pointer";
1831                                var space = document.createElement("span");
1832                                space.innerHTML = "&nbsp;";
1833                                attachments.appendChild(link_attachment);
1834                                attachments.appendChild(space);
1835                                attachments.appendChild(link_import_attachment);
1836                        }
1837                        else {
1838                                link_attachment.innerHTML += '<BR>';
1839                                attachments.appendChild(link_attachment);
1840                        }
1841                }
1842                tr6.appendChild(td6);
1843                tr6.appendChild(attachments);
1844                tbody_message_others_options.appendChild(tr6);
1845        }
1846
1847
1848        var div = document.createElement("DIV");
1849        div.id = "div_message_scroll_"+ID;
1850        div.style.background = 'WHITE';
1851        div.style.overflow = "auto";
1852        div.style.width = "100%";
1853        table_message_others_options.appendChild(tbody_message_others_options);
1854        var tr = document.createElement("TR");
1855        var td = document.createElement("TD");
1856        td.colSpan = '2';
1857        div.appendChild(table_message_others_options);
1858        var imgTag = info_msg.body.match(/(<img[^>]*src[^>=]*=['"]?[^'">]*["']?[^>]*>)|(<[^>]*(style[^=>]*=['"][^>]*background(-image)?:[^:;>]*url\()[^>]*>)/gi);
1859        var newBody = info_msg.body;
1860        if(!info_msg.showImg && imgTag)
1861        {
1862                var domains = '';
1863                var blocked = false;
1864                var forbidden = true;
1865
1866                if (preferences.notification_domains != null && typeof(preferences.notification_domains) != 'undefined')
1867                {
1868                        domains = preferences.notification_domains.split(',');
1869                        for(var j = 0; j < imgTag.length; j++)
1870                        {
1871                                for (var i = 0; i < domains.length; i++)
1872                                {
1873                                        if (imgTag[j].match(/cid:([\w\d]){5,}/) || imgTag[j].match(/src=\"\.\/inc\/show_embedded_attach\.php/g)) 
1874                                        {
1875                                                forbidden = false;
1876                                                continue;
1877                                        }
1878                                        imgSource = imgTag[j].match(/=['"](http:\/\/)+[^'"\/]*/);
1879                                        if (imgSource && imgSource.toString().substr(5).match(domains[i]))
1880                                                forbidden = false;
1881                                }
1882                                if (forbidden)
1883                                {
1884                                        newBody = newBody.replace(imgTag[j],"<img src='templates/"+template+"/images/forbidden.jpg'>");
1885                                        blocked=true;
1886                                }
1887                        }
1888                        if (blocked)
1889                        {
1890                                var showImgLink = document.createElement('DIV');
1891                                showImgLink.id="show_img_link_"+ID;
1892                                showImgLink.onclick = function(){show_msg_img(info_msg.msg_number,info_msg.msg_folder)};
1893                                showImgLink.className="show_img_link";
1894                                showImgLink.innerHTML = get_lang("Show images from")+": "+info_msg.from.email;
1895                                td.appendChild(showImgLink);
1896                        }
1897                }
1898        }
1899        td.appendChild(div);
1900        tr.appendChild(td)
1901        tbody_message.appendChild(tr);
1902
1903
1904        ////////////////////////////////////////////////////////////////////////////////////////////////////// 
1905        //Make the body message.
1906        ///////////////////////////////////////////////////////////////////////////////////////////////////////
1907        var tr = document.createElement("TR");
1908        tr.className = "tr_message_body";
1909        var td = document.createElement("TD");
1910        //td.setAttribute("colSpan","2");
1911        newBody = newBody.replace("<body","<span");
1912        newBody = newBody.replace("<BODY","<span");
1913        while ( ( /<span[^>]*><span[^>]*>/ig ).test( newBody ) )
1914                newBody = newBody.replace( /(<span[^>]*>)<span[^>]*>/ig, '$1' );
1915
1916        var _body = document.createElement( 'div' );
1917        _body.id = 'body_' + ID;
1918        _body.innerHTML = newBody;
1919
1920        var _elements = _body.getElementsByTagName( '*' );
1921        for( var i = 0; i < _elements.length; i++ )
1922                if ( _elements[ i ].attributes && _elements[ i ].attributes.getNamedItem( 'id' ) )
1923                        _elements[ i ].attributes.removeNamedItem( 'id' );
1924
1925        div.appendChild( _body );
1926
1927        function mailto( link )
1928        {
1929                var mail = link.href.substr( 7 );
1930                link.onclick = function( )
1931                {
1932                        new_message_to( mail );
1933                        return false;
1934                };
1935        }
1936        var links = div.getElementsByTagName( 'a' );
1937        for ( var i = 0; i < links.length; i++ ){
1938                try{
1939                        if ( links.item( i ).href.indexOf( 'mailto:' ) === 0 ){                         
1940                                mailto( links.item( i ) );
1941                        }
1942                        else{
1943                                if ( links.item( i ).href.indexOf( 'javascript:' ) !== 0 )
1944                                        links.item( i ).setAttribute( 'target', '_blank' );
1945                        }
1946                }catch(e){
1947                }
1948        }       
1949        ////////////////////////////////////////////////////////////////////////////////////////////////////// 
1950        //Make the thumbs of the message.
1951        //////////////////////////////////////////////////////////////////////////////////////////////////////
1952        if ((info_msg.thumbs)&&(info_msg.thumbs.length > 0)){
1953                var table_message_thumbs = document.createElement("TABLE");
1954                table_message_thumbs.width = "80%";
1955                table_message_thumbs.style.borderTop = "2px solid rgb(170, 170, 170)";
1956                var tbody_message_thumbs = document.createElement("TBODY");
1957                var tr = document.createElement("TR");
1958                tr.className = "tr_message_body";
1959                var td = document.createElement("TD");
1960                td.setAttribute("colSpan","2");
1961                td.id = "body_thumbs_"+ID;
1962                td.innerHTML += "&nbsp;<font color='DARKBLUE' size='2'><b>"+info_msg.attachments.length+" "+get_lang("attachment")+(info_msg.attachments.length > 1 ? "s" : "")+" "+get_lang("in this message")+"</font></b>";
1963                var _link_attachments = '';
1964                if(info_msg.thumbs.length > 1){
1965                        _link_attachments       = document.createElement("A");
1966                        _link_attachments.className = "message_options";
1967             if(proxy_mensagens.is_local_folder(current_folder))
1968                _link_attachments.setAttribute("href", "javascript:expresso_local_messages.download_all_local_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
1969            else
1970                _link_attachments.setAttribute("href", "javascript:download_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
1971                        _link_attachments.innerHTML = get_lang('Download all atachments');
1972                }
1973               
1974                if(_link_attachments){
1975                        td.innerHTML += " :: ";
1976                        td.appendChild(_link_attachments);
1977                }
1978               
1979                td.innerHTML += "<BR><img src='templates/"+template+"/images/menu/ktip.png'>"+get_lang("<b>Tip:</b> For faster save, click over the image with <u>right button</u>.");
1980                td.innerHTML += "<BR>";
1981
1982                for (var i=0; i<info_msg.thumbs.length; i++){
1983                        if ((i % 4) == 0)
1984                                td.innerHTML += "<BR>";
1985                        td.innerHTML += info_msg.thumbs[i];
1986                        td.innerHTML += "&nbsp;&nbsp;";
1987                }
1988                tr.appendChild(td);
1989                tbody_message_thumbs.appendChild(tr);
1990                table_message_thumbs.appendChild(tbody_message_thumbs);
1991                div.appendChild(table_message_thumbs);
1992        }
1993        //////////////////////////////////////////////////////////////////////////////////////////////////////
1994        table_message.appendChild(tbody_message);
1995        content.appendChild(table_message);
1996        resizeWindow();
1997        var msg_number = document.createElement('INPUT');
1998        msg_number.id = "msg_number_" + ID;
1999        msg_number.type = "hidden";
2000        msg_number.value = info_msg.msg_number;
2001        content.appendChild(msg_number);
2002        //////////////////////////////////////////////////////////////////////////////////////////////////////
2003}
2004function changeLinkState(el,state){
2005        el.innerHTML = get_lang(state);
2006        switch (state){
2007                case 'important':
2008                        {
2009                                el.onclick = function(){changeLinkState(el,'normal');set_messages_flag('unflagged',currentTab.substr(0,currentTab.indexOf("_r"))); write_msg(get_lang('Message marked as ')+get_lang("Normal"))}
2010                                break;
2011                        }
2012                case 'normal':
2013                        {
2014                                el.onclick = function(){  changeLinkState(el,'important');set_messages_flag('flagged',currentTab.substr(0,currentTab.indexOf("_r")));write_msg(get_lang('Message marked as ')+get_lang("Important"))}
2015                                break;
2016                        }
2017                case 'unseen':
2018                        {
2019                                el.onclick = function(){  changeLinkState(el,'seen');set_messages_flag('unseen',currentTab.substr(0,currentTab.indexOf("_r")));write_msg(get_lang('Message marked as ')+get_lang("unseen"))}
2020                                break;
2021
2022                        }
2023                case 'seen':
2024                        {
2025                                el.onclick = function(){  changeLinkState(el,'unseen');set_messages_flag('seen',currentTab.substr(0,currentTab.indexOf("_r")));write_msg(get_lang('Message marked as ')+get_lang("seen"))}
2026                                break;
2027
2028                        }
2029                default:
2030                        {
2031                                break;
2032                        }
2033        }
2034}
2035function draw_new_message(border_ID){
2036        var ID = create_border("",border_ID);
2037        if (ID == false)
2038                return false;
2039        hold_session = true;
2040       
2041        var footer_menu = Element("footer_menu");       
2042        if (footer_menu) {
2043                footer_menu.style.display = 'none';
2044        }
2045/////////////////////////////////////////////////////////////////////////////////////////////////////////
2046        var form = document.createElement("FORM");
2047        form.name = "form_message_"+ID;
2048        form.method = "POST";
2049        form.onsubmit = function(){return false;}
2050        if(!is_ie)
2051                form.enctype="multipart/form-data";
2052        else
2053                form.encoding="multipart/form-data";
2054/////////////////////////////////////////////////////////////////////////////////////////////////////////
2055        //ConstructMenuNewMessage(ID);
2056////////////////////////////////////////////////////////////////////////////////////////////////////////       
2057        var content = Element('content_id_' + ID);
2058        var table_message = document.createElement("TABLE");
2059        table_message.width = "100%";
2060        var tbody_message = document.createElement("TBODY");
2061        var tr0 = document.createElement("TR");
2062        tr0.className = "tr_message_header";
2063        var td0 = document.createElement("TD");
2064        td0.colSpan = '3';
2065       
2066        var table_menu_new_message = document.createElement("TABLE");
2067        table_menu_new_message.width = "100%";
2068        table_menu_new_message.border = '0';
2069        table_menu_new_message.className = 'table_message';
2070        var tbody_menu_new_message = document.createElement("TBODY");
2071        var tr_menu_new_message = document.createElement("TR");
2072        var td_menu_new_message = document.createElement("TD");
2073        td_menu_new_message.setAttribute("noWrap","true");
2074       
2075        if ((preferences.save_in_folder == '-1') || (preferences.save_in_folder == '')){
2076                //var option_send = '<span class="message_options" onclick=send_message("'+ID+'","null","null");>'+get_lang("Send")+'</span> | ';
2077                var option_send   = '<input type="button" id="send_button_'+ID+'" class="em_button_like_span" tabindex="1" value="'+get_lang("Send")+'" onclick=send_message("'+ID+'","null","null");>' + ' | ';
2078                if(!expresso_offline)
2079                        var option_send_and_file= '<span class="message_options" onclick=wfolders.makeWindow("'+ID+'","send_and_file");>'+get_lang("Send and file")+'</span> | ';
2080                else
2081                        var option_send_and_file='';
2082        }
2083        else{
2084                //var option_send = '<span class="message_options" onclick="send_message(\''+ID+'\',\''+preferences.save_in_folder+'\',\'null\');">'+get_lang("Send")+'</span> | ';
2085                var option_send   = '<input type="button" id="send_button_'+ID+'" class="em_button_like_span" tabindex="1" value="'+get_lang("Send")+'" onclick="send_message(\''+ID+'\',\''+preferences.save_in_folder+'\',\'null\');">' + ' | ';
2086                var option_send_and_file='';
2087                wfolders.alert = true;
2088        }
2089//      var option_save_as              = '<span class="message_options" onclick=wfolders.makeWindow("'+ID+'","save");>'+get_lang("Save as")+'</span> | ';
2090        if (!expresso_offline) {
2091                var option_save = '<span id="save_message_options_'+ID+'" class="message_options" onclick="openTab.toPreserve['+ID+'] = true; save_msg('+ID+');">'+get_lang("Save")+'</span> | ';
2092                var option_search = '<span class="message_options" onclick=openListUsers("'+ID+'");>'+get_lang("Search")+'</span>';
2093        }
2094        else {
2095                var option_save = '<input type="hidden" id="save_message_options_'+ID+'">';
2096                var option_search = '';
2097        }
2098        td_menu_new_message.innerHTML = option_send + option_send_and_file + option_save + option_search;
2099       
2100        tr_menu_new_message.appendChild(td_menu_new_message);
2101        tbody_menu_new_message.appendChild(tr_menu_new_message);
2102        table_menu_new_message.appendChild(tbody_menu_new_message);
2103       
2104        content.appendChild(table_menu_new_message);
2105        tr0.appendChild(td0);
2106        tbody_message.appendChild(tr0);
2107////////////////////////////////////////////////////////////////////////////////////////////////////////
2108        var tr1_1 = document.createElement("TR");
2109        tr1_1.style.display = 'none';
2110        var td1_1 = document.createElement("TD");
2111        td1_1.innerHTML = get_lang("From")+":";
2112        td1_1.setAttribute("noWrap","true");
2113        td1_1.style.width = "1%";
2114       
2115        var td_from = document.createElement("TD");
2116        td_from.setAttribute("noWrap","true");
2117        td_from.style.width = "100%";
2118                       
2119        var sel_from = document.createElement('SELECT');       
2120        sel_from.id = "from_"+ID;
2121        sel_from.name = "input_from";
2122        sel_from.style.width = "70%";
2123        sel_from.setAttribute("wrap","soft");
2124        td_from.appendChild(sel_from); 
2125        tr1_1.appendChild(td1_1);
2126        tr1_1.appendChild(td_from);
2127        tbody_message.appendChild(tr1_1);       
2128////////////////////////////////////////////////////////////////////////////////////////////////////////
2129        var tr1 = document.createElement("TR");
2130        var td1 = document.createElement("TD");
2131        td1.innerHTML = get_lang("To")+":";
2132        td1.setAttribute("noWrap","true");
2133        td1.style.width = "1%";
2134       
2135        var td_to = document.createElement("TD");
2136        td_to.setAttribute("noWrap","true");
2137        td_to.style.width = "100%";
2138       
2139        var input_to = document.createElement('TEXTAREA');
2140        input_to.id = "to_"+ID;
2141        input_to.name = "input_to";
2142        input_to.setAttribute("tabIndex","1"); 
2143        input_to.style.width = "100%";
2144        input_to.setAttribute("wrap","soft");
2145        input_to.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer)); search_contacts('onfocus', this.id);};
2146        input_to.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
2147        if (!is_ie)
2148        {
2149                input_to.rows = 2;
2150                input_to.onkeypress = function (e)
2151        {
2152            if ((e.keyCode) == 120) //F9
2153            {
2154                emQuickSearch(input_to.value, 'to', ID);
2155            }
2156            else
2157            {
2158                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
2159                {
2160                    e.preventDefault();
2161                    search_contacts(e.keyCode,this.id);
2162                }
2163            }
2164        }
2165        input_to.onkeyup = function (e)
2166        {
2167            if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
2168            {
2169                search_contacts(e.keyCode,this.id);
2170            }
2171        }
2172        }
2173        else
2174        {
2175                input_to.rows = 3;
2176                input_to.onkeyup = function (e)
2177        {
2178            if ((window.event.keyCode) == 120) //F9
2179            {
2180                emQuickSearch(input_to.value, 'to', ID);
2181            }
2182            else
2183            {
2184                search_contacts(window.event.keyCode,this.id);
2185            }   
2186        }
2187        }
2188        td_to.appendChild(input_to);
2189       
2190        var forwarded_local_message = document.createElement("INPUT"); //Hidden para indicar se é um forward de uma mensagem local
2191        forwarded_local_message.id = "is_local_forward"+ID;
2192        forwarded_local_message.name = "is_local_forward";
2193        forwarded_local_message.type = "HIDDEN";
2194        forwarded_local_message.value = "0";
2195        td_to.appendChild(forwarded_local_message);
2196       
2197        if (!expresso_offline) {
2198                var img_search = document.createElement("IMG");
2199                img_search.src = "./templates/"+template+"/images/search.gif";
2200                img_search.title = get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.');
2201                img_search.onclick = function () {emQuickSearch(document.getElementById('to_'+ID).value, 'to', ID);};
2202        }
2203        else {
2204                var img_search = document.createElement("SPAN");
2205        }
2206       
2207        var span_search = document.createElement("SPAN");
2208        span_search.innerHTML = get_lang('Search');
2209       
2210        var td1_img_search = document.createElement("TD");
2211        td1_img_search.setAttribute("noWrap","true");
2212        var td1_span_search = document.createElement("TD");
2213        td1_span_search.setAttribute("noWrap","true"); 
2214       
2215        td1_img_search.appendChild(img_search);
2216        td1_span_search.appendChild(span_search);
2217       
2218        tr1.appendChild(td1);
2219        tr1.appendChild(td_to);
2220        tr1.appendChild(td1_img_search);
2221
2222        tbody_message.appendChild(tr1);
2223//////////////////////////////////////////////////////////////////////////////////////////////////////
2224        var tr2 = document.createElement("TR");
2225        tr2.id = "tr_cc_"+ID;
2226        tr2.style.display = 'none';
2227        var td2 = document.createElement("TD");
2228        td2.innerHTML = "Cc:";
2229        td2.setAttribute("noWrap","true");     
2230        td2.style.width = "1%";
2231       
2232        var td_cc = document.createElement("TD");
2233        td_cc.setAttribute("noWrap","true");
2234        td_cc.style.width = "100%";
2235       
2236        var input_cc = document.createElement('TEXTAREA');
2237        input_cc.id = "cc_"+ID;
2238        input_cc.name = "input_cc";
2239        input_cc.setAttribute("tabIndex","1");
2240        input_cc.style.width = "100%";
2241        input_cc.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer)); search_contacts('onfocus',this.id);};
2242        input_cc.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
2243    if (!is_ie)
2244    {
2245        input_cc.rows = 2;
2246        input_cc.onkeypress = function (e)
2247        {
2248            if ((e.keyCode) == 120) //F9
2249            {
2250                emQuickSearch(input_cc.value, 'cc', ID);
2251            }
2252            else
2253            {
2254                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
2255                {
2256                    e.preventDefault();
2257                    search_contacts(e.keyCode,this.id);
2258                }
2259            }
2260        }
2261        input_cc.onkeyup = function (e)
2262        {
2263            if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
2264            {
2265                search_contacts(e.keyCode,this.id);
2266            }
2267        }
2268    }
2269    else if (is_ie)
2270    {
2271        input_cc.rows = 3;
2272        input_cc.onkeyup = function (e)
2273        {
2274            if ((window.event.keyCode) == 120) //F9
2275            {
2276                emQuickSearch(input_cc.value, 'cc', ID);
2277            }
2278            else
2279            {
2280                search_contacts(window.event.keyCode,this.id);
2281            }
2282        }
2283    }
2284       
2285        td_cc.appendChild(input_cc);
2286        var img_search = document.createElement("IMG");
2287        img_search.src = "./templates/"+template+"/images/search.gif";
2288        img_search.onclick = function () {emQuickSearch(document.getElementById('cc_'+ID).value, 'cc', ID)}
2289        img_search.title = get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.');
2290        var span_search = document.createElement("SPAN");
2291        span_search.innerHTML = get_lang('Search');
2292       
2293        var td2_img_search = document.createElement("TD");
2294        td2_img_search.setAttribute("noWrap","true");
2295        var td2_span_search = document.createElement("TD");
2296        td2_span_search.setAttribute("noWrap","true"); 
2297       
2298        td2_img_search.appendChild(img_search);
2299        td2_span_search.appendChild(span_search);
2300               
2301        tr2.appendChild(td2);
2302        tr2.appendChild(td_cc);
2303        tr2.appendChild(td2_img_search);
2304        tbody_message.appendChild(tr2);
2305//////////////////////////////////////////////////////////////////////////////////////////////////////
2306        var tr3 = document.createElement("TR");
2307        tr3.id = "tr_cco_"+ID;
2308        tr3.style.display = 'none';
2309        var td3 = document.createElement("TD");
2310        td3.setAttribute("noWrap","true");
2311        td3.innerHTML = get_lang("CCo")+":";
2312        td3.style.width = "1%";
2313       
2314        var td_cco = document.createElement("TD");
2315        td_cco.setAttribute("noWrap","true");
2316        td_cco.style.width = "100%";
2317       
2318        var input_cco = document.createElement('TEXTAREA');
2319        input_cco.id = "cco_"+ID;
2320        input_cco.name = "input_cco";
2321        input_cco.setAttribute("tabIndex","1");
2322        input_cco.style.width = "100%";
2323        input_cco.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer)); search_contacts('onfocus',this.id);};
2324        input_cco.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
2325       
2326        if (!is_ie)
2327    {
2328        input_cco.rows = 2;
2329        input_cco.onkeypress = function (e)
2330        {
2331            if ((e.keyCode) == 120) //F9
2332            {
2333                emQuickSearch(input_cco.value, 'cco', ID);
2334            }
2335            else
2336            {
2337                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
2338                {
2339                    e.preventDefault();
2340                    search_contacts(e.keyCode,this.id);
2341                }
2342            }
2343        }
2344        input_cco.onkeyup = function (e)
2345        {
2346            if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
2347            {
2348                search_contacts(e.keyCode,this.id);
2349            }
2350        }
2351    }
2352    else if (is_ie)
2353    {
2354        input_cco.rows = 3;
2355        input_cco.onkeyup = function (e)
2356        {
2357            if ((window.event.keyCode) == 120) //F9
2358            {
2359                emQuickSearch(input_cco.value, 'cco', ID);
2360            }
2361            else
2362            {
2363                search_contacts(window.event.keyCode,this.id);
2364            }   
2365        }
2366    }
2367       
2368        td_cco.appendChild(input_cco);
2369        var img_search = document.createElement("IMG");
2370        img_search.src = "./templates/"+template+"/images/search.gif";
2371        img_search.title = get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.');   
2372        img_search.onclick = function () {emQuickSearch(document.getElementById('cco_'+ID).value, 'cco', ID);};
2373        var span_search = document.createElement("SPAN");
2374        span_search.innerHTML = get_lang('Search');
2375
2376        var td3_img_search = document.createElement("TD");
2377        td3_img_search.setAttribute("noWrap","true");
2378        var td3_span_search = document.createElement("TD");
2379        td3_span_search.setAttribute("noWrap","true"); 
2380       
2381        td3_img_search.appendChild(img_search);
2382        td3_span_search.appendChild(span_search);
2383               
2384        tr3.appendChild(td3);
2385        tr3.appendChild(td_cco);
2386        tr3.appendChild(td3_img_search);       
2387        tbody_message.appendChild(tr3);
2388//////////////////////////////////////////////////////////////////////////////////////////////////////
2389        var tr_link = document.createElement("TR");
2390        tr_link.id = "tr_link_"+ID;             
2391        var td1_link = document.createElement("TD");
2392        var td2_link = document.createElement("TD");
2393        td1_link.innerHTML = "&nbsp;";
2394        var a_cc_link = document.createElement('A');
2395        a_cc_link.innerHTML = get_lang('Add CC');
2396        a_cc_link.id = "a_cc_link_"+ID;
2397        a_cc_link.setAttribute("href","javascript:void(0)");
2398        a_cc_link.setAttribute("tabIndex","-1");
2399        a_cc_link.onclick = function () {this.style.display='none';document.getElementById('tr_cc_'+ID).style.display='';document.getElementById('space_link_'+ID).style.display='none';input_cc.focus(); return false;}
2400        td2_link.appendChild(a_cc_link);       
2401        var space = document.createElement("span");
2402        space.id ="space_link_"+ID;
2403        space.innerHTML="&nbsp;|&nbsp;";
2404        td2_link.appendChild(space);
2405        var a_cco_link = document.createElement('A');
2406        a_cco_link.innerHTML = get_lang('Add BCC');
2407        a_cco_link.id = "a_cco_link_"+ID;
2408        a_cco_link.setAttribute("href","javascript:void(0)");
2409        a_cco_link.setAttribute("tabIndex","-1");
2410        a_cco_link.onclick = function () {this.style.display='none';document.getElementById('tr_cco_'+ID).style.display='';document.getElementById('space_link_'+ID).style.display='none';input_cco.focus(); return false;}
2411        td2_link.appendChild(a_cco_link);       
2412        tr_link.appendChild(td1_link);
2413        tr_link.appendChild(td2_link);
2414        tbody_message.appendChild(tr_link);
2415//////////////////////////////////////////////////////////////////////////////////////////////////////
2416        var tr4 = document.createElement("TR");
2417        var td4 = document.createElement("TD");
2418        //td4.setAttribute("noWrap","true");   
2419        td4.innerHTML = get_lang("Subject")+":";
2420        var td_subject = document.createElement("TD");
2421        var input_subject = document.createElement('input');
2422        input_subject.id = "subject_"+ID;
2423        input_subject.name = "input_subject";
2424        input_subject.setAttribute("tabIndex","1");
2425        input_subject.style.width = "90%";
2426        input_subject.setAttribute("autocomplete","off");
2427        td_subject.appendChild(input_subject);
2428        tr4.appendChild(td4);
2429        tr4.appendChild(td_subject);
2430        tbody_message.appendChild(tr4);
2431////////////////////////////////////////////////////////////////////////////////////////////////////// 
2432        var tr5 = document.createElement("TR");
2433        var td5 = document.createElement("TD");
2434        td5.innerHTML = "&nbsp;";
2435        var td_return_receipt = document.createElement("TD");
2436        td_return_receipt.setAttribute("noWrap","true");
2437        td_return_receipt.innerHTML = get_lang("Return receipt")+":";
2438        if (is_ie)
2439        {
2440            var input_return_receipt = document.createElement('input name=input_return_receipt');
2441        }
2442        else
2443        {
2444            var input_return_receipt = document.createElement('input');
2445            input_return_receipt.name = "input_return_receipt";
2446        }
2447        input_return_receipt.type = "checkbox";
2448        input_return_receipt.className = "checkbox";
2449        input_return_receipt.id = "return_receipt_"+ID;
2450        input_return_receipt.setAttribute("tabIndex","-1");
2451        td_return_receipt.appendChild(input_return_receipt);
2452
2453    // Workaround para resolver problema ao enviar e-mails
2454    if((preferences.use_assinar_criptografar != '0'))
2455        {
2456        if(parseInt(preferences.use_signature_digital_cripto)==1)
2457                {
2458                        td_return_receipt.innerHTML +=  "&nbsp;&nbsp;" + get_lang("Digitally sign message?")+"";
2459
2460            if (is_ie)
2461            {
2462                var input_return_digital = document.createElement('input name=input_return_digital');
2463            }
2464            else
2465            {
2466                        var input_return_digital = document.createElement('input');
2467                input_return_digital.name = "input_return_digital";
2468            }
2469
2470                        input_return_digital.type = "checkbox";
2471                        input_return_digital.className = "checkbox";
2472                        input_return_digital.id = "return_digital_"+ID;
2473                        input_return_digital.setAttribute("tabIndex","-1");
2474            if(parseInt(preferences.use_signature_digital)==1)
2475                        {
2476                                input_return_digital.defaultChecked=true;
2477                        }
2478                        td_return_receipt.appendChild(input_return_digital);
2479                        td_return_receipt.innerHTML +=  "&nbsp;&nbsp;" + get_lang("Digitally crypt message?")+"";
2480
2481            if (is_ie)
2482            {
2483                var input_return_cripto = document.createElement('input name=input_return_cripto');
2484            }
2485            else
2486            {
2487                        var input_return_cripto = document.createElement('input');
2488                input_return_cripto.name = "input_return_cripto";
2489            }
2490
2491                        input_return_cripto.type = "checkbox";
2492                        input_return_cripto.className = "checkbox";
2493                        input_return_cripto.id = "return_cripto_"+ID;
2494                        input_return_cripto.setAttribute("tabIndex","-1");
2495                        input_return_cripto.defaultChecked=false;
2496
2497            if(parseInt(preferences.use_signature_cripto)==1)
2498                        {
2499                                input_return_cripto.defaultChecked=true;
2500                        }
2501
2502                        td_return_receipt.appendChild(input_return_cripto);
2503                }
2504                td_return_receipt.innerHTML += "";
2505        }
2506
2507        tr5.appendChild(td5);
2508        tr5.appendChild(td_return_receipt);
2509        tbody_message.appendChild(tr5);
2510        if (parseInt(preferences.use_important_flag))
2511        {
2512                var trn = document.createElement("TR");
2513                var tdn = document.createElement("TD");
2514                tdn.innerHTML = "&nbsp;";
2515                var td_important_msg = document.createElement("TD");
2516                td_important_msg.setAttribute("noWrap","true");
2517                td_important_msg.innerHTML = get_lang("Important message")+":";
2518                var input_important_message = document.createElement('input');
2519                input_important_message.type = "checkbox";
2520                input_important_message.className = "checkbox";
2521                input_important_message.id = "important_message_"+ID;
2522                input_important_message.name = "input_important_message";
2523                input_important_message.setAttribute("tabIndex","-1");
2524                td_important_msg.appendChild(input_important_message); 
2525                trn.appendChild(tdn);
2526                trn.appendChild(td_important_msg);
2527                tbody_message.appendChild(trn);
2528        }
2529
2530        var add_files = document.createElement("A");
2531        add_files.setAttribute("href", "javascript:void(0)");
2532        add_files.onclick = function () { addFile(ID); return false;};
2533        add_files.innerHTML =  get_lang("Attachments: add+");
2534        add_files.setAttribute("tabIndex","-1");
2535        var divfiles = document.createElement("DIV");
2536        divfiles.id = "divFiles_"+ID;
2537        var tr5 = document.createElement("TR");
2538        var td5_link = document.createElement("TD");
2539        var td5_input = document.createElement("TD");   
2540        td5_input.innerHTML = "&nbsp;"
2541        td5_link.setAttribute("valign","top");
2542        td5_link.setAttribute("colSpan","2");
2543        td5_link.appendChild(add_files);
2544        tr5.appendChild(td5_input);
2545        tr5.appendChild(td5_link);
2546        tbody_message.appendChild(tr5);
2547        var tr6 = document.createElement("TR");
2548        var td6_link  = document.createElement("TD");
2549        var td6_input = document.createElement("TD");
2550        tr6.appendChild(td6_link);
2551        td6_input.appendChild(divfiles);
2552        tr6.appendChild(td6_input);     
2553        tbody_message.appendChild(tr6);
2554//////////////////////////////////////////////////////////////////////////////////////////////////////
2555        var tr5 = document.createElement("TR");
2556        var td5 = document.createElement("TD");
2557        td5.innerHTML = "&nbsp;";
2558        var td_body = document.createElement("TD");
2559        td_body.setAttribute("colSpan","2");
2560        var div_body_position = document.createElement("DIV");
2561        div_body_position.id = "body_position_" + ID;
2562        td_body.appendChild(div_body_position);
2563        tr5.appendChild(td5);
2564        tr5.appendChild(td_body);
2565        tbody_message.appendChild(tr5);
2566        var _div = document.createElement("DIV");
2567        _div.id = "div_message_scroll_"+ID;
2568        _div.style.overflow = "auto";
2569        _div.style.width = "100%";
2570
2571        // Hide the contac tips and re-position the pallete color.
2572        _div.onscroll = function() {
2573                var intElemScrollTop = Element("div_message_scroll_"+ID).scrollTop;
2574                if (!is_ie)
2575                        ColorPalette.repos(intElemScrollTop);
2576                Tooltip.scrollChanged();
2577        };
2578//////////////////////////////////////////////////////////////////////////////////////////////////////
2579        _div.appendChild(form);
2580        content.appendChild(_div);
2581        table_message.appendChild(tbody_message);
2582        form.appendChild(table_message);
2583        connector.loadScript("rich_text_editor");
2584        RichTextEditor.loadEditor(ID);
2585//////////////////////////////////////////////////////////////////////////////////////////////////////
2586        if(!expresso_offline)
2587                draw_from_field(sel_from,tr1_1);
2588        resizeWindow();
2589        return ID;
2590}
2591
2592//      Verify if any user is sharing his name/email address
2593//      for use in the new messages's "From " field.
2594function draw_from_field(sel_from,tr1_1){
2595
2596        var el_shared_users = Element("el_shared_users");
2597        // The element was loaded and populated...so return.
2598        if(el_shared_users){   
2599                // Nothing to work...so return.
2600                if(el_shared_users.options.length == 0)
2601                        return;
2602                tr1_1.style.display = '';
2603                for (var x = 0; x < el_shared_users.options.length; x++) {
2604                        var _option = document.createElement("OPTION");
2605                        _option.text = el_shared_users.options[x].text;
2606                        _option.value = el_shared_users.options[x].value;
2607                        sel_from.options[sel_from.options.length] = _option     ;
2608                }
2609                return;
2610        }
2611        // Get the shared folders.....
2612        var sharedFolders = new Array();
2613        for(var i = 0; i < folders.length; i++) {
2614                var x = folders[i].folder_id;
2615        if (folders[i].folder_parent == 'user'){
2616                sharedFolders[sharedFolders.length] = x;
2617        }
2618    }
2619
2620    var matchUser = '#';
2621    var sharedUsers = new Array();
2622        // Filter the shared folders (only root folders) .....
2623        for(var i = 0; i < sharedFolders.length; i++) {
2624      if(!sharedFolders[i].match(matchUser)) {
2625                matchUser = sharedFolders[i];
2626                sharedUsers[sharedUsers.length] = matchUser.substring(("user"+cyrus_delimiter).length,matchUser.length);
2627      }
2628    }
2629
2630        // Handler function for cExecute
2631        var h_user = function(data) {
2632                if(data.length > 0) {
2633                        tr1_1.style.display = '';
2634                        var _option = document.createElement("OPTION");
2635                        _option.text =  '"'+data.myname+'" <'+Element("user_email").value+'>';
2636                        _option.value  = data.myname+";"+Element("user_email").value;
2637                        sel_from.options[sel_from.options.length] = _option;
2638       
2639                        var options = '';
2640                        for (var x = 0; x < data.length; x++)   {
2641                                var _option = document.createElement("OPTION");
2642                                _option.text = '"'+data[x].cn[0] + '" <'+data[x].mail[0]+'>';
2643                                _option.value = data[x].cn[0] + ';'+data[x].mail[0]+';'+data[x].save_shared[0]+';'+data[x].uid[0];
2644                                sel_from.options[sel_from.options.length] = _option     ;
2645                        }
2646                }
2647                var shared_users_from = Element("el_shared_users");
2648                if(!shared_users_from) {
2649                        shared_users_from = sel_from.cloneNode(true);
2650                        shared_users_from.id = "el_shared_users";
2651                        shared_users_from.style.display = 'none';
2652                        document.body.appendChild(shared_users_from);
2653                }
2654        }
2655        // First time, so execute.....
2656        cExecute ("$this.ldap_functions.getSharedUsersFrom&uids="+sharedUsers.join(';'), h_user);
2657}
2658
2659function changeBgColorToON(all_messages, begin, end){
2660        for (begin; begin<=end; begin++)
2661        {
2662                add_className(all_messages[begin], 'selected_msg');
2663                Element("check_box_message_" + all_messages[begin].id).checked = true;
2664        }
2665}
2666function updateBoxBgColor(box){
2667        // Set first TR Class
2668        var _className = 'tr_msg_read2';
2669        for(var i = 0; i < box.length;i++){     
2670                if(exist_className(box[i],_className))
2671                        remove_className(box[i], _className);
2672                _className = (_className == 'tr_msg_read2' ? 'tr_msg_read' : 'tr_msg_read2');
2673                if(!exist_className(box[i],_className))
2674                        add_className( box[i], _className);
2675        }
2676}
2677
2678function changeBgColor(event, msg_number){
2679        actual_tr = Element(msg_number);
2680
2681        if (event.shiftKey)
2682        {
2683                last_tr = Element(last_message_selected);
2684                if(!last_tr)
2685                        last_tr = actual_tr;
2686
2687                all_messages = actual_tr.parentNode.childNodes;
2688               
2689                for (var i=0; i < all_messages.length; i++)
2690                {
2691                        if (actual_tr.id == all_messages[i].id)
2692                                first_order = i;
2693                        if (last_tr.id == all_messages[i].id)
2694                                last_order = i;
2695                }
2696               
2697                if (parseInt(first_order) > parseInt(last_order))
2698                        changeBgColorToON(all_messages, last_order, first_order);
2699                else
2700                        changeBgColorToON(all_messages, first_order, last_order);
2701        }
2702        else{
2703                //if ( exist_className(actual_tr, 'selected_msg') )
2704                if ( Element('check_box_message_' + msg_number).checked )
2705                        add_className(actual_tr, 'selected_msg');
2706                else
2707                        remove_className(actual_tr, 'selected_msg');
2708        }
2709        last_message_selected = msg_number;
2710}
2711
2712function build_quota(data){
2713        id = "content_quota";
2714        q_limit = data['quota_limit'];
2715        var div = document.getElementById(id);
2716        if(!q_limit){
2717            div.innerHTML = '<span><font size="2" style="color:red"><strong>'+get_lang("Without Quota")+'</strong></font></span>';
2718        }
2719        else{
2720        if(div)
2721                div.innerHTML = '';
2722        value = data['quota_percent'];
2723        q_used = data['quota_used'];
2724        table = document.getElementById("table_quota");
2725        if(table)
2726                table.parentNode.removeChild(table);
2727        table = document.createElement("TABLE");       
2728        tbody = document.createElement("TBODY");       
2729        table.appendChild(tbody);
2730        table.id = "table_quota";
2731        table.width="102";
2732        table.border="0";
2733        table.cellSpacing = 0;
2734        table.cellPadding = 0;
2735       
2736        //tr1 = document.createElement("TR");
2737        td11 = document.createElement("TD");
2738        td11.align="center";
2739        td11.setAttribute("noWrap","true");
2740        td11.innerHTML += '&nbsp;<span class="boxHeaderText">' + value+"% ("+q_used+"M/"+q_limit+"M)</span>";
2741        //tr1.appendChild(td11);
2742       
2743        tr2 = document.createElement("TR");
2744        td21 = document.createElement("TD");
2745        td21.setAttribute("noWrap","true");
2746        td21.height="15";
2747        td22 = document.createElement("TD");   
2748        td21.setAttribute("background","../phpgwapi/templates/"+template+"/images/dsunused.gif");
2749        table221 = document.createElement("TABLE");
2750        tbody221 = document.createElement("TBODY");
2751        table221.appendChild(tbody221);
2752        table221.style.width=value+"%";
2753        td21.width="102";
2754        table221.border="0";
2755        table221.cellSpacing = 0;
2756        table221.cellPadding = 0;
2757        tr221 = document.createElement("TR");
2758        td221 = document.createElement("TD");
2759        td221.height="15";
2760        if(value > 90) {
2761                if(value >= 100)
2762                        write_msg(get_lang("Your Mailbox is 100% full! You must free more space or will not receive messages."));
2763                else
2764                        write_msg(get_lang("Warning: Your Mailbox is almost full!"));
2765                td221.setAttribute("background","templates/"+template+"/images/dsalert.gif");
2766        }
2767        else if(value > 80)
2768                td221.setAttribute("background","templates/"+template+"/images/dswarn.gif");
2769        else
2770                td221.className = 'dsused';
2771       
2772        tr221.appendChild(td221);
2773        tbody221.appendChild(tr221);
2774        td21.appendChild(table221);     
2775        tr2.appendChild(td21);
2776        tr2.appendChild(td11);
2777
2778        //tr2.appendChild(td1);
2779
2780        tbody.appendChild(tr2); //Desenho
2781        //tbody.appendChild(tr1); //Letras
2782        div.appendChild(table);
2783        }
2784}
2785
2786function draw_quota(data){
2787        build_quota(data);
2788}
2789
2790function update_quota(folder_id){
2791        cExecute ("$this.imap_functions.get_quota&folder_id="+folder_id,build_quota);
2792}
2793
2794function draw_search(headers_msgs){
2795        Element("border_id_0").innerHTML = "&nbsp;&nbsp;" + get_lang('Search Result') + "&nbsp;&nbsp;";
2796
2797        var tbody = Element('tbody_box');
2798        for (var i=0; i<(headers_msgs.length); i++){
2799                var tr = this.make_tr_message(headers_msgs[i], headers_msgs[i].msg_folder);
2800                if (tr)
2801                        tbody.appendChild(tr);
2802        }
2803}
2804
2805function draw_search_header_box(){
2806        var table_message_header_box = Element("table_message_header_box");
2807        table_message_header_box.parentNode.removeChild(table_message_header_box);
2808
2809        var content_id_0 = Element("content_id_0");
2810        var table_element = document.createElement("TABLE");
2811        var tbody_element = document.createElement("TBODY");
2812        table_element.setAttribute("id", "table_message_header_box");
2813        table_element.className = "table_message_header_box";
2814        tr_element = document.createElement("TR");
2815        tr_element.className = "message_header";
2816        td_element1 = document.createElement("TD");
2817        td_element1.setAttribute("width", "1%");
2818        chk_box_element = document.createElement("INPUT");
2819        chk_box_element.id  = "chk_box_select_all_messages";
2820        chk_box_element.setAttribute("type", "checkbox");
2821        chk_box_element.className = "checkbox";
2822        chk_box_element.onclick = function(){select_all_messages(this.checked);};
2823        chk_box_element.onmouseover = function () {this.title=get_lang('Select all messages.')};
2824        chk_box_element.onkeydown = function (e){
2825                if (is_ie)
2826                {
2827                        if ((window.event.keyCode) == 46)
2828                        {
2829                                //delete_all_selected_msgs_imap();
2830                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
2831                        }
2832                }
2833                else
2834                {
2835                        if ((e.keyCode) == 46)
2836                        {
2837                                //delete_all_selected_msgs_imap();
2838                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
2839                        }
2840                }
2841        };
2842       
2843        td_element1.appendChild(chk_box_element);
2844        td_element2 = document.createElement("TD");
2845        td_element2.setAttribute("width", "3%");
2846        td_element3 = document.createElement("TD");
2847        td_element3.setAttribute("width", "30%");
2848        td_element3.id = "message_header_SORTFROM";
2849        td_element3.align = "left";
2850        td_element3.innerHTML = get_lang("From");
2851        td_element4 = document.createElement("TD");
2852        td_element4.setAttribute("width", "49%");
2853        td_element4.id = "message_header_SORTSUBJECT";
2854        td_element4.align = "left";
2855        td_element4.innerHTML = get_lang("Subject");   
2856        td_element5 = document.createElement("TD");
2857        td_element5.setAttribute("width", "10%");
2858        td_element5.id = "message_header_SORTARRIVAL";
2859        td_element5.align = "center";
2860        td_element5.innerHTML = "<B>"+get_lang("Date")+"</B>"; 
2861        td_element5.innerHTML += "<img src ='templates/"+template+"/images/arrow_descendant.gif'>";
2862        td_element6 = document.createElement("TD");
2863        td_element6.setAttribute("width", "10%");
2864        td_element6.id = "message_header_SORTSIZE";
2865        td_element6.align = "right";
2866        td_element6.innerHTML = get_lang("Size");
2867        tr_element.appendChild(td_element1);
2868        tr_element.appendChild(td_element2);
2869        tr_element.appendChild(td_element3);
2870        tr_element.appendChild(td_element4);
2871        tr_element.appendChild(td_element5);
2872        tr_element.appendChild(td_element6);
2873       
2874        tbody_element.appendChild(tr_element);
2875        table_element.appendChild(tbody_element);
2876        content_id_0.appendChild(table_element);
2877}
2878
2879function draw_search_division(msg){
2880        var tbody = Element('tbody_box');
2881        var tr = document.createElement("TR");
2882        var td = document.createElement("TD");
2883        td.colSpan = '7';
2884        td.width = '100%';
2885
2886        var action_info_table = document.createElement("TABLE");
2887        var action_info_tbody = document.createElement("TBODY");
2888       
2889        action_info_table.className = "action_info_table";
2890        action_info_table.width = "100%";
2891       
2892        var action_info_tr = document.createElement("TR");
2893       
2894        var action_info_th1 = document.createElement("TH");
2895        action_info_th1.width = "40%";
2896        action_info_th1.innerHTML = "&nbsp;";
2897
2898        var action_info_th2 = document.createElement("TH");
2899       
2900        action_info_th2.innerHTML = msg;
2901        action_info_th2.className = "action_info_th";
2902        action_info_th2.setAttribute("noWrap", "true");
2903       
2904        var action_info_th3 = document.createElement("TH");
2905        action_info_th3.width = "40%";
2906        action_info_th3.innerHTML = "&nbsp;";
2907       
2908        action_info_tr.appendChild(action_info_th1);
2909        action_info_tr.appendChild(action_info_th2);
2910        action_info_tr.appendChild(action_info_th3);
2911        action_info_tbody.appendChild(action_info_tr);
2912        action_info_table.appendChild(action_info_tbody);
2913
2914        td.appendChild(action_info_table);
2915        tr.appendChild(td);
2916        tbody.appendChild(tr);
2917}
2918
2919function draw_search_box(){
2920        var content_id_0 = Element("content_id_0");
2921        var table = document.createElement("TABLE");
2922        table.id = "table_box";
2923        table.width = 'auto';
2924        var tbody = document.createElement("TBODY");
2925        tbody.id = "tbody_box";
2926
2927        table.className = "table_box";
2928        table.setAttribute("frame", "below");
2929        table.setAttribute("rules", "none");
2930        table.setAttribute("cellpadding", "0");
2931        table.onkeydown = function (e){
2932                if (is_ie)
2933                {
2934                        if ((window.event.keyCode) == 46)
2935                        {
2936                                //delete_all_selected_msgs_imap();
2937                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
2938                        }
2939                }
2940                else
2941                {
2942                        if ((e.keyCode) == 46)
2943                        {
2944                                //delete_all_selected_msgs_imap();
2945                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
2946                        }
2947                }
2948        };
2949        if (is_ie)
2950                table.style.cursor = "hand";
2951       
2952        table.appendChild(tbody);
2953        content_id_0.appendChild(table);
2954}
2955        var idx_cc = 0;
2956function draw_plugin_cc(ID, addrs)
2957{
2958        connector.loadScript("ccQuickAdd");
2959
2960        var array_addrs = '';
2961        var array_name  = '';   
2962        var cc_data = new Array();
2963        if(typeof(addrs.name) != 'undefined') {
2964                array_name      = LTrim(addrs.name).split(" ");
2965                array_addrs = new Array(addrs.email);           
2966        }
2967        else {
2968                array_addrs = (typeof addrs == 'object' ? addrs.toString().split("\" ") : addrs.split("\" "));
2969                array_name      = LTrim(array_addrs[0]).replace('"','').split(" ");     
2970        }
2971
2972        var _split = array_name[0].split('@');
2973        cc_data[0] = _split[0];
2974        cc_data[1] = _split[0];
2975        cc_data[2] = '';
2976
2977        for (i=1; i < array_name.length; i++)
2978                cc_data[2] += array_name[i] + " ";                     
2979       
2980
2981        if(array_addrs.length > 1)                     
2982                cc_data[3] = array_addrs[1] ? array_addrs[1].replace("&lt;",'').replace("&gt;",'') : '';               
2983        else
2984                cc_data[3] = array_addrs[0];
2985       
2986        var sm_envelope_img1 = '<img style="cursor:'+ (is_ie ? 'hand' : 'pointer') +'" title="' + get_lang("Add Contact") +
2987        '" onclick="ccQuickAddOne.showList(\''+cc_data+'\')" src="./templates/'+template+'/images/user_card.png">';
2988        var to_addybook_add = "<SPAN id='insert_plugin_"+idx_cc+"_"+ID+"'>";
2989        to_addybook_add += addrs;
2990        to_addybook_add +=  sm_envelope_img1;
2991        idx_cc++;
2992        to_addybook_add += "</SPAN>";
2993        return to_addybook_add;
2994}
2995function deny_email(email){
2996        connector.loadScript("filter");
2997        connector.loadScript("filters");
2998        var dn_em       = document.createElement("SPAN");
2999                dn_em.id = "tt_d";
3000                dn_em.onclick = function(){filter_rules.new_rule(email);};
3001                dn_em.setAttribute("title",get_lang("Block Sender"));
3002                dn_em.style.cursor = "pointer";         
3003                dn_em.innerHTML = "<img align='top' onclick=filter.new_rule('"+email+"') src='./templates/"+template+"/images/deny.gif'>";
3004        return dn_em;
3005       
3006}
3007function show_div_address_full(id, type) {
3008        var div_address_full = Element("div_"+type+"address_full_"+id);
3009        if(!div_address_full) {
3010                div_address_full = document.createElement("SPAN");
3011                div_address_full.id = "div_"+type+"address_full_"+id;   
3012                div_address_full.style.display="none"; 
3013                var _address = eval(type+"address_array['"+id+"']");
3014                var isOverLimit = (_address.length > 100);
3015               
3016                if(isOverLimit) {
3017                        alert("Esse campo possui muitos endereços ("+_address.length+" destinatários).\r\n"+
3018                        "Para evitar o travamento do navegador, o botão 'Adicionar Contato' foi desabilitado!");
3019                }
3020
3021                for(var idx = 1 ; idx  < _address.length;idx++) {
3022                        div_address_full.innerHTML += isOverLimit ?  '<br>'+_address[idx] : ','+draw_plugin_cc(id,_address[idx]);
3023                }               
3024                div_address_full.innerHTML += " (<a STYLE='color: RED;' onclick=document.getElementById('div_"+type+"address_full_"+id+"').style.display='none';document.getElementById('div_"+type+"address_"+id+"').style.display='';>"+get_lang('less')+"</a>)";
3025                Element(type+"_"+id).appendChild(div_address_full);
3026        }
3027        Element('div_'+type+'address_'+id).style.display='none';
3028        div_address_full.style.display='';
3029}
3030function draw_footer_box(num_msgs){
3031        folder = get_current_folder();
3032        var span_R = Element("table_message"); 
3033        var span_options = Element("span_options");     
3034        if(!span_options) {
3035                span_options = document.createElement("TD");   
3036                span_options.style.fontSize = "12";
3037                span_options.id = "span_options";
3038                span_R.appendChild(span_options);
3039        }
3040
3041        var change_font_color = 'onmouseover="var last_class = this.className;'+
3042                                'if (this.className != \'message_options_over\')'+
3043                                'this.className=\'message_options_active\'; '+
3044                                'this.onmouseout=function(){this.className=last_class;}"';
3045
3046        span_options.innerHTML =
3047                '<span class="message_options_trash"><span ' + change_font_color + ' title="'+get_lang("Delete")+'" class="message_options" onclick=proxy_mensagens.delete_msgs(\'null\',\'selected\',\'null\')>'+get_lang("Delete")+'</span></span>'+
3048                '<span class="message_options_move"><span ' + change_font_color + ' title="'+get_lang("Move")+'" class="message_options" onclick=wfolders.makeWindow(\"\",\"move_to\")>'+get_lang("Move")+'</span></span>'+
3049                ((expresso_offline)?" ":'<span class="message_options_print"><span ' + change_font_color + ' title="'+get_lang("Print")+'" class="message_options" onclick=print_all()>'+get_lang("Print")+'</span></span>')+
3050//              '<span class="message_options_print"><span ' + change_font_color + ' title="'+get_lang("Print")+'" class="message_options" onclick=print_all()>'+get_lang("Print")+'</span></span>'+
3051        ((expresso_offline)?" ":'<span class="message_options_export"><span ' + change_font_color + ' title="'+get_lang("Export")+'" class="message_options" onclick="proxy_mensagens.export_all_messages()">'+get_lang("Export")+'</span></span>') +
3052                ((expresso_offline)?" ":'<span class="message_options_import"><span ' + change_font_color + ' title="'+get_lang("Import")+'" class="message_options" onclick="import_window()">'+get_lang("Import")+'</span></span>');
3053    if(preferences.use_local_messages==1 && !expresso_offline)
3054                if(proxy_mensagens.is_local_folder(current_folder))
3055                        span_options.innerHTML += '&nbsp; <span title="'+get_lang("Unarchive")+'" class="message_options" onclick="expresso_local_messages.unarchive_msgs(\''+folder+'\',null)">'+get_lang("Unarchive")+'</span>';
3056                else
3057                        span_options.innerHTML += '&nbsp; <span title="'+get_lang("Archive")+'" class="message_options" onclick="archive_msgs(\''+folder+'\',null)">'+get_lang("Archive")+'</span>';
3058        if (use_spam_filter) {
3059                if ( current_folder == 'INBOX'+cyrus_delimiter+'Spam' ) {
3060                        span_options.innerHTML += ' | <span ' + change_font_color + ' title="'+get_lang("Not Spam")+'" class="message_options" onclick="nospam(\'selected\',\'null\',\'null\')">'+get_lang("Not Spam")+'</span>';
3061                }
3062                else {
3063                        span_options.innerHTML += ' | <span ' + change_font_color + ' title="'+get_lang("Mark as Spam")+'" class="message_options" onclick="spam(\'null\', \'selected\',\'null\')">'+get_lang("Mark as Spam")+'</span>';
3064                }
3065        }
3066        var span_D = Element("span_D");
3067        if(!span_D){
3068                span_D = document.createElement("TD"); 
3069                span_D.align = "right";
3070                span_D.style.fontSize = "12";
3071                span_D.id = "span_D";
3072                span_R.appendChild(span_D);
3073        }
3074        span_D.innerHTML =
3075                 get_lang("List")+': '+
3076        '<span ' + change_font_color + ' id="span_flag_SORTARRIVAL" class="'+(search_box_type == 'ALL' ? 'message_options_over' : 'message_options')+'" title="'+get_lang("All")+'" onclick="if(\'ALL\' == \''+search_box_type+'\') return false;sort_box(\'ALL\',\''+sort_box_type+'\')">'+get_lang("All")+'</span>, '+
3077        '<span ' + change_font_color + ' id="span_flag_UNSEEN" class="'+(search_box_type == 'UNSEEN' ? 'message_options_over' : 'message_options')+'" title="'+get_lang("l_unseen")+'" onclick="if(\'UNSEEN\' == \''+search_box_type+'\') return false;sort_box(\'UNSEEN\',\''+sort_box_type+'\')">'+get_lang("l_unseen")+'</span>, '+
3078        '<span ' + change_font_color + ' id="span_flag_SEEN" class="'+(search_box_type == 'SEEN' ? 'message_options_over' : 'message_options')+'" title="'+get_lang("l_seen")+'" onclick="if(\'SEEN\' == \''+search_box_type+'\') return false;sort_box(\'SEEN\',\''+sort_box_type+'\')">'+get_lang("l_seen")+'</span>, '+
3079        '<span ' + change_font_color + ' id="span_flag_ANSWERED" class="'+(search_box_type == 'ANSWERED' ? 'message_options_over' : 'message_options')+'" title="'+get_lang("l_answered")+'" onclick="if(\'ANSWERED\' == \''+search_box_type+'\') return false;sort_box(\'ANSWERED\',\''+sort_box_type+'\')">'+get_lang("l_answered")+'</span>, '+
3080        '<span ' + change_font_color + ' id="span_flag_FLAGGED" class="'+(search_box_type == 'FLAGGED' ? 'message_options_over' : 'message_options')+'" title="'+get_lang("l_important")+'" onclick="if(\'FLAGGED\' == \''+search_box_type+'\') return false;sort_box(\'FLAGGED\',\''+sort_box_type+'\')">'+get_lang("l_important")+'</span>&nbsp;&nbsp;';
3081        draw_paging(num_msgs);
3082        Element("tot_m").innerHTML = num_msgs; 
3083}
Note: See TracBrowser for help on using the repository browser.