source: trunk/expressoMail1_2/js/draw_api.js @ 1121

Revision 1121, 115.9 KB checked in by eduardoalex, 15 years ago (diff)

Ticket #548 - Implementação do Expresso (Mail) Offline

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