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

Revision 1964, 120.0 KB checked in by eduardoalex, 14 years ago (diff)

Ticket #894 - Resolvendo o problema descrito no ticket em questao

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