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

Revision 1747, 117.1 KB checked in by rafaelraymundo, 15 years ago (diff)

Ticket #605 - Implementação de preferência sobre uid ou cn nas pastas compratilhadas.

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