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

Revision 1912, 119.2 KB checked in by valmir.sena, 14 years ago (diff)

Ticket #858 - Alterar o comportamento do envio de mensagens por um usuário de uma conta compartilhada

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