source: branches/2.0/expressoMail1_2/js/draw_api.js @ 2693

Revision 2693, 115.4 KB checked in by niltonneto, 14 years ago (diff)

Ticket #1050 - Estilo entre msgs lidas e não-lidas alterado para melhorar distinção.

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