source: branches/2.1/expressoMail1_2/js/draw_api.js @ 2524

Revision 2524, 120.1 KB checked in by niltonneto, 14 years ago (diff)

Ticket #1038 - Corrigido exibição de mensagem no Internet Explorer.

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