source: branches/2.2/expressoMail1_2/js/draw_api.js @ 3271

Revision 3271, 119.0 KB checked in by rafaelraymundo, 14 years ago (diff)

Ticket #1315 - Corrigida a exibição dos icones indicativos de msg assinada dig./criptografa .

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