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

Revision 3157, 117.2 KB checked in by amuller, 14 years ago (diff)

Ticket #898 - Implementa no branches 2.2 a funcionalidade de quota

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