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

Revision 5456, 177.6 KB checked in by gustavo, 12 years ago (diff)

Ticket #2462 - Melhorias na tela de composição de mensagens do ExpressoMail?

  • 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        'condition' : [] // Will store the search condition if the tab is the result of a search
10};
11var tabTypes = {
12        'new':4,
13        'forward':6,
14        'reply_with_history':7,
15        'reply_to_all_with_history':8,
16        'reply_without_history':9,
17        'reply_to_all_without_history':10,
18        'edit':5
19        }
20
21var currentTab,numBox = 0; // Open Tab and num of mailboxes opened at context
22// Objeto Map, talvez o ideal fosse adicionar este objeto à Api do egroupware, e carregá-lo
23// aqui no expressoMail.
24
25function draw_tree_folders(folders){
26       
27        // Check if the tree folders alredy exist.
28        if (Element('dftree_tree_folders')){
29                if (!expresso_offline) {
30                        var update_tree_folders = function(data){
31                                build_quota(data);
32                                var unseen_in_mailbox = 0;
33                                var unseen_in_shared_folders = 0;
34                                for (var i=0; i<data.length; i++){
35                                        if ( data[i].folder_unseen > 0 )
36                                        {
37                                                unseen_in_mailbox = parseInt( unseen_in_mailbox + data[ i ].folder_unseen );
38                                                if ( data[i].folder_id.indexOf( 'INBOX' ) !== 0 )
39                                                        unseen_in_shared_folders = parseInt( unseen_in_shared_folders + data[ i ].folder_unseen );
40                                        }
41
42                                        var folder_unseen = Element('dftree_'+data[i].folder_id+'_unseen');
43
44                                        if ((folder_unseen) && (data[i].folder_unseen > 0))
45                                        {
46                                                folder_unseen.innerHTML = data[i].folder_unseen;
47                                        }
48                                        else if (data[i].folder_unseen > 0)
49                                        {
50                                                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>'});
51                                                tree_folders.getNodeById(data[i].folder_id)._refresh();
52                                        }
53                                        else if (data[i].folder_unseen <= 0)
54                                        {
55                                                if(tree_folders.getNodeById(data[i].folder_id)){
56                                                tree_folders.getNodeById(data[i].folder_id).alter({caption:lang_folder(data[i].folder_name)});
57                                                tree_folders.getNodeById(data[i].folder_id)._refresh();
58                                        }
59                                        }
60
61                                        if(data[i].folder_id == current_folder){
62                                                var old_new_m = isNaN(parseInt(Element('new_m').innerHTML)) ? parseInt(Element('new_m').firstChild.innerHTML) : parseInt(Element('new_m').innerHTML);
63                                                Element('new_m').innerHTML = data[i].folder_unseen ? '<font color="RED">'+data[i].folder_unseen+'</font>' : 0;
64                                                draw_paging(Element('tot_m').innerHTML);
65                                        }
66                                }
67
68                                var display_unseen_in_mailbox = tree_folders.getNodeById( 'root' );
69                                display_unseen_in_mailbox.alter({caption:get_lang("My Folders")});
70                                display_unseen_in_mailbox._refresh();
71
72                                var display_unseen_in_shared_folders = tree_folders.getNodeById( 'user' );
73                                if ( display_unseen_in_shared_folders )
74                                {
75                                        if ( unseen_in_shared_folders )
76                                                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")});
77                                        else
78                                                display_unseen_in_shared_folders.alter({caption:get_lang("Shared folders")});
79                                        display_unseen_in_shared_folders._refresh();
80                                }
81                        }
82                        cExecute ("$this.imap_functions.get_folders_list&folder="+current_folder, update_tree_folders);
83                }
84
85                return;
86        }
87        else{
88                if (!expresso_offline) {
89                        tree_folders = new dFTree({name: 'tree_folders'});
90
91                        var n_root = new dNode({id:'root', caption: get_lang("My Folders")});
92                        tree_folders.add(n_root,'anything'); //Places the root; second argument can be anything.
93
94                        var unseen_in_mailbox = 0;
95                        var unseen_in_shared_folders = 0;
96                        for (var i=0; i<folders.length; i++){
97                                if (folders[i].folder_unseen > 0)
98                                {
99                                        unseen_in_mailbox = parseInt( unseen_in_mailbox + folders[ i ].folder_unseen );
100                                        if ( folders[i].folder_id.indexOf( 'INBOX' ) !== 0 )
101                                                unseen_in_shared_folders = parseInt( unseen_in_shared_folders + folders[ i ].folder_unseen );
102
103                                        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});
104
105                                        if( folders[i].folder_name.toLowerCase() == 'inbox' )
106                                                Element('new_m').innerHTML = '<font style="color:red">' + folders[i].folder_unseen + '</font>';
107                                }
108                                else
109                                        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});
110
111                                if (folders[i].folder_parent == '')
112                                        folders[i].folder_parent = 'root';
113                                else if (folders[i].folder_parent == 'user'){
114
115                                        if (!tree_folders.getNodeById('user')){
116                                                tmpFolderId = folders[i].folder_id.split(cyrus_delimiter).pop();
117                                                var n_root_shared_folders = new dNode({id:'user', caption:get_lang("Shared folders"), plusSign:true});
118                                                tree_folders.add(n_root_shared_folders,'root');
119                                        }
120                                }
121                                tree_folders.add(nn,folders[i].folder_parent);
122                        }
123                }
124
125
126
127                var handlerChannel = function(data){
128                        if (data == null || typeof(data) == 'string')
129                                return;
130                        /*
131                        *  RSS NEWS
132                        */
133                        var root_rss = new dNode({
134                                id: "news_root",
135                                caption: get_lang('News')
136                        });
137                        tree_folders.add(root_rss, "root");
138                        for(i=0; i < data.length; i++)
139                        {
140                                var nodeNews = new dNode({
141                                        id: "NEWS/"+data[i].name,
142                                        caption: data[i].name,
143                                        onClick: "open_rss('"+data[i].rss_url+"')",
144                                        plusSign: 0
145                                });
146                                tree_folders.add(nodeNews,"news_root");
147                        }
148                        var noden=document.getElementById('lnews_roottree_folders');
149                        noden.style.backgroundImage="url(templates/"+template+"/images/menu/rss.png)";
150                }
151//              cExecute('$this.rss.getChannels',handlerChannel);
152
153
154                /**
155                 * Pastas locais
156                 */
157                if (preferences.use_local_messages==1 || expresso_offline) {
158                            //verifica se gears esta installado ou o offline
159                        if( (!window.google || !google.gears) &&
160                             !expresso_local_messages.installGears() ){
161                                preferences.use_local_messages = 0;
162                        }
163                        else if( !expresso_local_messages.is_offline_installed() )
164                                preferences.use_local_messages = 0;
165                        else{
166                                if (expresso_offline)
167                                        tree_folders = new dFTree({
168                                                name: 'tree_folders'
169                                        });
170                                var root_local = new dNode({
171                                        id: "local_root",
172                                        caption: get_lang('local folders')
173                                });
174                                tree_folders.add(root_local, "root"); //coloca root local
175                                var local_folders = expresso_local_messages.list_local_folders();
176                                for (var i in local_folders) { //Coloca as pastas locais.
177                                        var node_root = "local_root";
178                                        var new_caption = local_folders[i][0];
179                                        if (local_folders[i][0].indexOf("/") != "-1") {
180                                                final_pos = local_folders[i][0].lastIndexOf("/");
181                                                node_root = "local_" + local_folders[i][0].substr(0, final_pos);
182                                                new_caption = local_folders[i][0].substr(final_pos + 1);
183                                        }
184                                        if (local_folders[i][1] > 0)
185                                                var nodeLocal = new dNode({
186                                                        id: "local_" + local_folders[i][0],
187                                                        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>',
188                                                        onClick: "change_folder('local_" + local_folders[i][0] + "','" + new_caption + "')",
189                                                        plusSign: local_folders[i][2]
190                                                });
191                                        else
192                                                var nodeLocal = new dNode({
193                                                        id: "local_" + local_folders[i][0],
194                                                        caption: lang_folder(new_caption),
195                                                        onClick: "change_folder('local_" + local_folders[i][0] + "','" + new_caption + "')",
196                                                        plusSign: local_folders[i][2]
197                                                });
198                                                tree_folders.add(nodeLocal, node_root);
199                                        }
200                                }
201                        }
202
203                tree_folders.draw(Element('content_folders'));
204                if (!expresso_offline) {
205                        n_root.changeState();
206                        tree_folders.getNodeById('INBOX')._select();
207                }
208                else {
209                        root_local.changeState();
210                        tree_folders.getNodeById('local_Inbox')._select();
211                }
212
213                var trash_span = document.getElementById(mount_url_folder(["lINBOX",special_folders["Trash"]])  + 'tree_folders');
214                var draft_span = document.getElementById(mount_url_folder(["lINBOX",special_folders["Drafts"]]) + 'tree_folders');
215                var sent_span  = document.getElementById(mount_url_folder(["lINBOX",special_folders["Sent"]]) + 'tree_folders');
216                var spam_span  = document.getElementById(mount_url_folder(["lINBOX",special_folders["Spam"]]) + 'tree_folders');
217                //local folders
218                var sent_local_conf = this.preferences.save_in_folder.replace(mount_url_folder(["INBOX",""]),"local_");
219                var sent_local_conf_span=document.getElementById('l'+sent_local_conf+'tree_folders');
220                var trash_local_span=document.getElementById('llocal_'+special_folders['Trash']+'tree_folders');
221                var draft_local_span=document.getElementById('llocal_'+special_folders['Drafts']+'tree_folders');
222                var sent_span_default=document.getElementById('llocal_'+special_folders['Sent']+'tree_folders');
223
224
225                if (trash_span)
226                        trash_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_trash.png)";
227
228                if (draft_span)
229                        draft_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_draft.png)"
230
231                if (sent_span)
232                        sent_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_sent.png)";
233                if (spam_span)
234                        spam_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_spam.png)";
235
236                if (sent_span_default)
237                        sent_span_default.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_sent.png)";
238                //Local folders
239
240                if (sent_local_conf_span)
241                        sent_local_conf_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_sent.png)";
242                if (trash_local_span)
243                        trash_local_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_trash.png)";
244                if (draft_local_span)
245                        draft_local_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_draft.png)"
246                if (sent_span_default)
247                        sent_span_default.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_sent.png)";
248
249
250                draw_paging(Element('tot_m').innerHTML);
251                if(document.getElementById(mount_url_folder(["nINBOX",special_folders["Trash"]])+"tree_folders"))
252                {
253                        var trash = document.createElement("SPAN");
254                        trash.id = 'empty_trash';
255                        trash.className = 'clean_folder';
256                        trash.style.cursor = 'pointer';
257                        trash.onclick = function () {empty_trash_imap();};
258                        trash.innerHTML = "["+get_lang("Clean")+"]";
259                        trash.title=get_lang("Empty trash");
260                        trash.onmouseover = function() {trash.style.color="red";};
261                        trash.onmouseout= function() {trash.style.color="#666666";};
262                        document.getElementById(mount_url_folder(["nINBOX",special_folders["Trash"]])+"tree_folders").appendChild(trash);
263                }
264                if(document.getElementById(mount_url_folder(["nINBOX",special_folders["Spam"]])+"tree_folders"))
265                {
266                                                var spam = document.createElement("SPAN");
267                                                spam.id = 'empty_spam';
268                                                spam.className = 'clean_folder';
269                                                spam.style.cursor = 'pointer';
270                                                spam.style.padding = '0 0 0 6px';
271                                                spam.onclick = function () {empty_spam_imap();};
272                                                spam.innerHTML = "["+get_lang("Clean")+"]";
273                                                spam.title=get_lang("Empty Spam Folder");
274                                                spam.onmouseover = function() {spam.style.color="red";};
275                                                spam.onmouseout= function() {spam.style.color="#666666";};
276                                                document.getElementById(mount_url_folder(["nINBOX",special_folders["Spam"]])+"tree_folders").appendChild(spam);
277                           }
278
279                if(!expresso_offline)
280                        var display_unseen_in_mailbox = tree_folders.getNodeById( 'root' );
281                else
282                        var display_unseen_in_mailbox = tree_folders.getNodeById( 'local_root' );
283                display_unseen_in_mailbox.alter({caption:get_lang("My Folders")});
284                display_unseen_in_mailbox._refresh();
285
286                var display_unseen_in_shared_folders = tree_folders.getNodeById( 'user' );
287                if ( display_unseen_in_shared_folders )
288                {
289                        if ( unseen_in_shared_folders )
290                                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")});
291                        else
292                                display_unseen_in_shared_folders.alter({caption:get_lang("Shared folders")});
293                        display_unseen_in_shared_folders._refresh();
294                }
295        }
296
297        if (!expresso_offline) {
298                var folder_create = "";
299                var nm1 = "";
300                if(tree_folders._folderPr.length > 0){
301                        var nm_folder = "";
302                        for(var i=0; i < tree_folders._folderPr.length; i++){
303                                nm_folder = tree_folders._folderPr[i].split(cyrus_delimiter);
304                                if(nm_folder[0] == "INBOX"){
305                                        if(nm1 == ""){
306                                                nm1 = nm_folder[1];
307                                                folder_create = "INBOX" + cyrus_delimiter + nm_folder[1] + ";";
308                                        }else{
309                                                if( nm1 != nm_folder[1]){
310                                                        folder_create += "INBOX" + cyrus_delimiter + nm_folder[1] + ";";
311                                                        nm1 = nm_folder[1];
312                                                }
313                                        }
314                                }
315                        }
316                }
317                if(folder_create != ""){
318                        if(confirm(get_lang("There are folders with invalid format. Do you want to fix them?"))){
319                                var handler_correct_folders = function(data){
320                                        //Timeout to release HTTPRequest , loadScript and update tree folders.
321                                        if(data)
322                                                setTimeout("connector.loadScript('TreeShow');ttreeBox.update_folder();",500);
323                                }
324                                cExecute("$this.imap_functions.create_extra_mailbox",handler_correct_folders,"nw_folders="+folder_create);
325                        }
326                }
327        }
328
329}
330
331function draw_tree_local_folders() {
332        /**
333         * Pastas locais
334         */
335                if(preferences.use_local_messages==1 || expresso_offline) {
336                        var local_folders = expresso_local_messages.list_local_folders();
337                        var has_changes = false;
338                        for (var i in local_folders) { //Coloca as pastas locais.
339
340                                var new_caption = local_folders[i][0];
341                                if(local_folders[i][0].indexOf("/")!="-1") {
342                                        final_pos = local_folders[i][0].lastIndexOf("/");
343                                        new_caption = local_folders[i][0].substr(final_pos+1);
344                                }
345
346                                var folder_unseen = Element('dftree_local_'+local_folders[i][0]+'_unseen');
347
348                                if ((folder_unseen) && (local_folders[i][1] > 0))
349                                {
350                                        folder_unseen.innerHTML = local_folders[i][1];
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) + '<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>'});
356                                        tree_folders.getNodeById("local_"+local_folders[i][0])._refresh();
357                                        has_changes = true;
358                                }
359                                else if (local_folders[i][1] <= 0)
360                                {
361                                        tree_folders.getNodeById("local_"+local_folders[i][0]).alter({caption:lang_folder(new_caption)});
362                                        tree_folders.getNodeById("local_"+local_folders[i][0])._refresh();
363                                        has_changes = true;
364                                }
365
366                        if("local_"+local_folders[i][0] == get_current_folder()){
367                                        var old_new_m = isNaN(parseInt(Element('new_m').innerHTML)) ? parseInt(Element('new_m').firstChild.innerHTML) : parseInt(Element('new_m').innerHTML);
368                                        if(!isNaN(old_new_m) && old_new_m < local_folders[i][1]){
369                                                Element('tot_m').innerHTML = parseInt(Element('tot_m').innerHTML) + (parseInt(local_folders[i][1])-old_new_m);
370                                        }
371                                        Element('new_m').innerHTML = local_folders[i][1] ? '<font color="RED">'+local_folders[i][1]+'</font>' : 0;
372                                        draw_paging(Element('tot_m').innerHTML);
373                                        has_changes = true;
374                        }
375                }
376                        if(has_changes)
377                                tree_folders.getNodeById("local_root").open();
378        }
379}
380
381
382function update_local_box(){
383    msg_range_end = (current_page*preferences.max_email_per_page);
384    msg_range_begin = (msg_range_end-(preferences.max_email_per_page)+1);
385    folder=get_current_folder();
386    var msgs  = expresso_local_messages.get_local_range_msgs(folder.substr(6),msg_range_begin,preferences.max_email_per_page,sort_box_type,sort_box_reverse,search_box_type,preferences.preview_msg_subject,preferences.preview_msg_tip);
387    alternate_border(0);
388    draw_box(msgs, folder, true);
389    draw_paging(msgs.num_msgs);
390    Element("tot_m").innerHTML = msgs.num_msgs;
391    update_menu();
392}
393
394function update_menu(data){
395                /*
396                 * @AUTHOR Rodrigo Souza dos Santos
397                 * @DATE 2008/09/15
398                 * @BRIEF When occurs a error in imap server show the message that is in file "error.html".
399                 */
400                if ( data && data.imap_error )
401                {
402                        if(preferences.use_local_messages==1 && expresso_local_messages.is_offline_installed){
403                                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?"));
404                                if(conf) {
405                                        window.onresize = function() {
406                                                var target = document.getElementById('divAppbox');
407                                                target.style.height= document.body.clientHeight - 83;
408                                        }
409                                        var target = document.getElementById('divAppbox');
410                                        document.getElementById("divAppboxHeader").innerHTML="";
411                                        target.style.height= document.body.clientHeight - 83;
412                                        expresso_local_messages.set_as_logged(account_id,0,true);
413                                        target.innerHTML = "<iframe src='offline.php?inside=1' width='100%' height='100%' frameBorder='0'></iframe>";
414                                        return false;
415                                }
416                        }
417                        connector.newRequest('error.html', 'templates/'+template+'/error.html', 'GET',
418                                function(data)
419                                {
420                                        var target = document.getElementById('divAppbox');
421                                        if ( target )
422                                                target.innerHTML = data;
423                                }
424                        );
425                        return false;
426                }
427
428                draw_tree_folders(data);
429                if(data) {
430
431                        build_quota(data);
432                        var f_unseen = Element('dftree_'+current_folder+'_unseen');
433                        if(f_unseen && f_unseen.innerHTML)
434                                Element('new_m').innerHTML = '<font face="Verdana" size="1" color="RED">'+f_unseen.innerHTML+'</font>';
435                        else
436                        {
437                                if( parseInt(Element('new_m').innerHTML) == 0 )
438                                        Element('new_m').innerHTML = 0;
439                        }
440                        folders = data;
441                }
442}
443
444var handler_draw_box = function(data){
445        draw_box(data, 'INBOX', true);
446        //alternate_border(0);
447}
448
449// Action on change folders.
450function change_folder(folder, folder_name){
451        if (openTab.imapBox[0] != folder)
452        {
453                current_folder = folder;
454                var handler_draw_box = function(data)
455                {
456                        if(!verify_session(data))
457                                return;
458                        alternate_border(0);
459                        var title = lang_folder(folder_name);
460                        if (title.length > 18) title = title.substring(0,18) + "...";
461                        Element("border_id_0").innerHTML = "&nbsp;" + title + '&nbsp;<font face="Verdana" size="1" color="#505050">[<span id="new_m">&nbsp;</span> / <span id="tot_m"></span>]</font>';
462                        draw_box(data, folder, true);
463                        draw_paging(data.num_msgs);
464                        Element("tot_m").innerHTML = data.num_msgs;
465                        update_menu();
466                        return true;
467                }
468                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);
469        }
470        else
471                alternate_border(0);
472}
473
474function open_folder(folder, folder_name){
475        if (current_folder!= folder) {
476                current_folder = folder;
477                var handler_draw_box = function(data){
478                        if(!verify_session(data))
479                                return false;
480                        numBox++;
481                        create_border(folder_name,numBox.toString());
482                        draw_box(data, current_folder, false);
483                        alternate_border(numBox);
484                        return true;
485                }
486                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);
487        }
488        else
489                alternate_border(numBox);
490        return true;
491}
492
493var lastPage = 1;
494var numPages = 5;
495var last_folder = 'INBOX';
496function draw_paging(num_msgs){
497        num_msgs = parseInt(num_msgs);
498        total_pages = 1;
499
500        if(last_folder != current_folder){
501                lastPage = 1;
502                current_page = 1;
503                last_folder = current_folder;
504        }
505
506        if(num_msgs > parseInt(preferences.max_email_per_page)) {
507                total_pages = parseInt(num_msgs/preferences.max_email_per_page);
508                if((num_msgs/preferences.max_email_per_page) > total_pages)
509                        total_pages++;
510        }
511
512        if(total_pages == 1) {
513                if(span_paging = document.getElementById("span_paging")) {
514                        span_paging.parentNode.removeChild(span_paging);
515                }
516                return;
517        }
518        span_paging = document.getElementById("span_paging");
519        if(!span_paging){
520                span_paging = document.createElement("DIV");
521                span_paging.id = "span_paging";
522                span_paging.className = "boxHeaderText";
523                span_paging.align="right";
524                document.getElementById("div_menu_c3").appendChild(span_paging);
525        }
526        span_paging.style.width="100%";
527        span_paging.innerHTML="";
528        msg_range_begin = 1;
529        msg_range_end = preferences.max_email_per_page;
530        if(current_page != 1) {
531                lnk_page = document.createElement("A");
532                //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){alternate_border(0); draw_box(data, get_current_folder());});");
533                lnk_page.setAttribute("href", "javascript:current_page=1; 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){alternate_border(0); draw_box(data, get_current_folder());});");
534        }
535        else {
536                lnk_page = document.createElement("SPAN");
537        }
538        span_paging.appendChild(lnk_page);
539
540        lnk_page.innerHTML = "&lt;&lt;";
541        lnk_page.title = get_lang("First");
542        span_paging.innerHTML += "&nbsp;";
543
544        if(current_page == lastPage + numPages)
545                lastPage = current_page - 1;
546        else if((lastPage != 1 && lastPage == current_page) || current_page == total_pages)
547                lastPage = current_page - (numPages - 1);
548        else if(current_page == 1)
549                lastPage = 1;
550
551        if(lastPage < 1)
552                lastPage = 1;
553        else if(lastPage > 1 && (lastPage > (total_pages -(numPages - 1))))
554                lastPage = total_pages -(numPages - 1);
555
556        var     hasMarked = false;
557
558        for(i = lastPage; i <= total_pages; i++) {
559
560                if(current_page == i || (i == total_pages && !hasMarked)) {
561                        lnk_page = document.createElement("SPAN");                     
562                        span_paging.appendChild(lnk_page);
563                        lnk_page.style.color = "red";                   
564                        lnk_page.innerHTML = "&nbsp;<b>"+i+"</b>&nbsp;";
565                        hasMarked = true;
566                        continue;
567                }
568                else{
569                        lnk_page = document.createElement("A");
570                        span_paging.appendChild(lnk_page);
571                        msg_range_begin = ((i*preferences.max_email_per_page)-(preferences.max_email_per_page-1));
572                        msg_range_end = (i*preferences.max_email_per_page);
573                        //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){alternate_border(0); draw_box(data, get_current_folder());});");
574                        lnk_page.setAttribute("href", "javascript:current_page="+i+"; 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){alternate_border(0); draw_box(data, get_current_folder());});");
575                }
576                lnk_page.innerHTML = "&nbsp;...&nbsp;";
577                if(i == (lastPage + numPages))
578                                break;
579                else if(lastPage == 1 || i != lastPage)
580                        lnk_page.innerHTML = "&nbsp;"+i+"&nbsp;";
581                span_paging.innerHTML += "&nbsp;";
582        }
583
584        if(current_page != total_pages) {
585                lnk_page = document.createElement("A");
586                msg_range_begin = ((total_pages*preferences.max_email_per_page)-(preferences.max_email_per_page-1));
587                msg_range_end = (total_pages*preferences.max_email_per_page);
588                //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){alternate_border(0); draw_box(data, get_current_folder());});");
589                lnk_page.setAttribute("href", "javascript:current_page="+total_pages+"; 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){alternate_border(0); draw_box(data, get_current_folder());});");
590        }
591        else {
592                lnk_page = document.createElement("SPAN");
593        }
594        span_paging.innerHTML += "&nbsp;";
595        span_paging.appendChild(lnk_page);
596
597        lnk_page.title = get_lang("Last");
598        lnk_page.innerHTML = "&gt;&gt;";
599}
600
601// stores the percentages of the cells
602//var colSizes = [ ["24","24","12","12","12","16","16","20%","58%","11%","11%"], ["16","16","12","12","12","20%","20%","*","10%","10%"] ];
603var colSizes = [ ["2%","2%","1%","1%","1%","1%","2%","20%","48%","11%","11%"], ["16","16","12","12","12","20%","20%","*","10%","10%"] ];
604// stores the alignments of the cells
605var colAligns = [ ['','','','','','','','left','left','center','center'], ['','','','','','left','left','left','center','center'] ];
606var objCell = null;
607var adjCell = null;
608var cellClick = null;
609var cellResized = false;
610var maxWidth=0;
611var minWidth=0;
612var bodyWidth=0;
613var cssForResizing=false;
614
615function changeCursorState(ev) {
616        if (cellResized)
617                cellResized = false;
618        var el = ev.target||ev.srcElement;
619        if (el.tagName != "TD")
620                el=getFirstParentOfType(el, "TD")
621        el.style.cursor ="hand";
622        el.style.cursor ="pointer";
623        if (!cssForResizing)
624                return;
625        var cellMouseX = (ev.clientX-parseInt(getColumnPosition(el, ev)));
626        var cellWidth = el.offsetWidth;
627        var tbl = getFirstParentOfType(el,"TABLE");
628        if (tbl.emptyBody)
629                return;
630        if ((((cellWidth-cellMouseX)<15)||((el.style.cursor=="col-resize")&&(detectLeftButton())))&&((el.className=="th_resizable")&&(el.cellIndex+1<el.parentNode.cells.length))){
631                if (tbl) tbl.style.cursor = "col-resize";
632                el.style.cursor ="col-resize";
633        }
634        else{
635                if (tbl) tbl.style.cursor = "pointer";
636                el.style.cursor ="hand";
637                el.style.cursor ="pointer";
638        }
639}
640
641function getStyle(el,styleProp) {
642        var x = document.getElementById(el);
643        if (x.currentStyle)
644                var y = x.currentStyle[styleProp];
645        else if (window.getComputedStyle)
646                var y = document.defaultView.getComputedStyle(x,null).getPropertyValue(styleProp);
647        return y;
648}
649
650function resizeColumn(ev) {
651        if (!objCell || !adjCell) {
652                stopColResize(ev);
653                return;
654        }
655        if (document.getElementById("table_message_header_box_"+numBox).emptyBody)
656                return;
657        if (objCell.style.cursor == "col-resize" && detectLeftButton(ev)) {
658                var cellIndex = objCell.cellIndex;
659                var adjIndex = adjCell.cellIndex;
660                var cellOffset = parseInt(getColumnPosition(objCell, ev));
661                var cellWidth = (ev.clientX-cellOffset);
662
663                var tbl = getMessagesTable(objCell);
664                var trM = tbl.rows;
665                var tblType = ( (tbl.id=="table_box") ? 0 : 1);
666
667                if (cellWidth < minWidth)
668                        cellWidth = minWidth;
669                var adjWidth = maxWidth - cellWidth;
670                if (adjWidth < minWidth) {
671                        cellWidth = (cellWidth+adjWidth)-minWidth;
672                        adjWidth = minWidth;
673                }
674
675                colSizes[tblType][adjIndex] = (colSizes[tblType][adjIndex]=="*" ? "*" : getPct(is_ie ? adjWidth : adjWidth-2));
676                colSizes[tblType][cellIndex] = (colSizes[tblType][cellIndex]=="*" ? "*" : getPct(cellWidth));
677
678                document.getElementById("table_message_ruler").style.left = cellOffset+cellWidth;
679        }
680        ev.returnValue = false;
681        return (false);
682}
683
684function getPct(tdWidth) {
685        var suf = tdWidth.toString().substr(tdWidth.length-1,1);
686        if ( suf != "%" && suf != "*")
687                return (Math.round((tdWidth/bodyWidth)*10000)/100).toString()+"%";
688        else
689                return tdWidth;
690}
691
692function detectLeftButton(ev) {
693    ev = ev || window.event;
694    var button = ev.which || ev.button;
695    return (button == 1);
696}
697
698function startColResize(ev) {
699        var el = ev.target||ev.srcElement;
700        if (el.tagName != "TD")
701                el=getFirstParentOfType(el, "TD")
702        if (is_ie)
703                ev.cancelBubble = true;
704        else
705                ev.stopPropagation();
706        if (!el) return;
707        if (!is_ie) ev.preventDefault();
708        if (document.getElementById("table_message_header_box_"+numBox).emptyBody)
709                return;
710        if (el.style.cursor == "col-resize" && detectLeftButton(ev)) {
711                var incIndex = ( (el.parentNode.cells.length > el.cellIndex + 1) ? 1 : -1 );
712                var msgTable = getMessagesTable(el);
713                var bodyRows = msgTable.rows;
714                objCell = el;
715                adjCell = el.parentNode.cells[el.cellIndex+incIndex];
716                var tbl = getFirstParentOfType(el, "TABLE");
717                if (is_ie) {
718                        tbl.detachEvent("onmousemove",changeCursorState);
719                        document.attachEvent("onmousemove",resizeColumn);
720                        document.attachEvent("onmouseup",stopColResize);
721                        document.attachEvent("onselect",selectCancel);
722                        tbl.attachEvent("onselectstart",selectCancel);
723                }
724                else {
725                        tbl.removeEventListener("mousemove",changeCursorState,false);
726                        document.addEventListener("mousemove",resizeColumn,false);
727                        document.addEventListener("mouseup",stopColResize,false);
728                        document.addEventListener("select",selectCancel,false);
729                        tbl.addEventListener("selectstart",selectCancel,false);
730                }
731                cellClick = objCell.onclick;
732                objCell.onclick = "";
733                maxWidth = objCell.offsetWidth+adjCell.offsetWidth;
734                        bodyWidth = msgTable.offsetWidth;
735                minWidth = Math.round(bodyWidth/80);
736                document.getElementById("table_message_ruler").style.display = "block";
737                document.getElementById("table_message_ruler").style.left = ev.clientX;
738                if (document.getElementById("content_id_"+numBox)==null)
739                        document.getElementById("table_message_ruler").style.height = document.getElementById("content_id_"+currentTab).offsetHeight;
740                else
741                        document.getElementById("table_message_ruler").style.height = document.getElementById("content_id_"+numBox).offsetHeight;
742        }
743}
744
745function stopColResize(ev) {
746        if (!objCell)
747                return;
748        if (is_ie)
749                ev.cancelBubble = true;
750        else
751                ev.stopPropagation();
752        var tbl = getFirstParentOfType(objCell, "TABLE");
753        if (is_ie) {
754                tbl.detachEvent("onselectstart",selectCancel);
755                document.detachEvent("onselect",selectCancel);
756                document.detachEvent("onmousemove",resizeColumn);
757                document.detachEvent("onmouseup",stopColResize);
758                tbl.attachEvent("onmousemove",changeCursorState);
759        }
760        else {
761                tbl.removeEventListener("selectstart",selectCancel,false);
762                document.removeEventListener("select",selectCancel,false);
763                document.removeEventListener("mousemove",resizeColumn,false);
764                document.removeEventListener("mouseup",stopColResize,false);
765                tbl.addEventListener("mousemove",changeCursorState,false);
766        }
767        var trM = getMessagesTable(objCell).rows;
768        var adjIndex = adjCell.cellIndex;
769        document.getElementById("table_message_ruler").style.display = "none";
770        maxWidth = 0;
771        objCell.onclick = cellClick;
772        objCell = null;
773        adjCell = null;
774        cellResized = true;
775        setColSizesCookie();
776        syncColumns();
777}
778
779function getMessagesTable(el) {
780        var hT;
781        if (el.tagName == "TABLE")
782                hT = el;
783        else
784                hT = getFirstParentOfType(el,"TABLE");
785        return (hT.parentNode.nextSibling.childNodes[0].className !== "local-messages-search-warning"?
786                hT.parentNode.nextSibling.childNodes[0] : hT.parentNode.nextSibling.childNodes[1]);
787}
788
789function getColumnPosition(oNode, pNode){
790        if (!pNode && !is_webkit){
791                var pos = getOffset(oNode);
792                return [pos.left, pos.top];
793        }
794        pNode = pNode||document.body;
795
796        var oCurrentNode = oNode;
797        var iLeft = 0;
798        var iTop = 0;
799
800        while ((oCurrentNode)&&(oCurrentNode != pNode)){
801                iLeft+=oCurrentNode.offsetLeft-oCurrentNode.scrollLeft;
802                iTop+=oCurrentNode.offsetTop-oCurrentNode.scrollTop;
803                oCurrentNode=oCurrentNode.offsetParent;
804        }
805
806        return [iLeft, iTop];
807}
808
809function getFirstParentOfType(obj, tag){
810        while (obj&&obj.tagName != tag&&obj.tagName != "BODY"){
811                obj=obj.parentNode;
812        }
813        return obj;
814}
815
816function syncColumns() {
817        var thisCell;
818        var tbl = (document.getElementById("content_id_"+numBox)==null ? 1 : 0);
819        if (objCell)
820                thisCell = objCell;
821        else
822                thisCell = document.getElementById("table_message_header_box_"+numBox).rows[0].cells[0];
823        var emptyBody = document.getElementById("table_message_header_box_"+numBox).emptyBody;
824        var tbH = getFirstParentOfType(thisCell,"TABLE");
825        var tbM = getMessagesTable(thisCell);
826        var trM = tbM.rows;
827        var _mouse_over;
828        var _mouse_out;
829        var _cell;
830        for (var r=0;r<trM.length;r++) {
831                for (var c=0;c<trM[r].cells.length;c++) {
832                        _cell = trM[r].cells[c];
833                        _cell.setAttribute("width",colSizes[tbl][c]);
834                        if (is_mozilla && !is_webkit) {
835                                if (!emptyBody) {
836                                        document.getElementById("colgroup_main_"+numBox).childNodes[c].setAttribute("width",colSizes[tbl][c]);
837                                }
838                                document.getElementById("colgroup_head_"+numBox).childNodes[c].setAttribute("width",colSizes[tbl][c]);
839                                if (tbH.rows[0].cells[c].className=="th_resizable") {
840                                        // lots of stupid fixes for FF to redraw cell content
841                                        if (_cell.childNodes && _cell.childNodes.length>1) {
842                                                _mouse_over = _cell.childNodes[1].onmouseover;
843                                                _mouse_out = _cell.childNodes[1].onmouseout;
844                                        }
845                                        _cell.innerHTML = trM[r].cells[c].innerHTML;
846                                        if (_cell.childNodes && _cell.childNodes.length>1) {
847                                                _cell.childNodes[1].onmouseover = _mouse_over;
848                                                _cell.childNodes[1].onmouseout = _mouse_out;
849                                        }
850                                        tbH.rows[0].cells[c].innerHTML = tbH.rows[0].cells[c].innerHTML;
851                                }
852                        }
853                        else {
854                                tbH.rows[0].cells[c].setAttribute("width",_cell.offsetWidth);
855                        }
856                }
857        }
858         //bug do firefox ao redefinir os tamanhos das colunas
859         if (is_mozilla && !is_webkit){ 
860           var colgr = document.getElementById("colgroup_main_"+ (parseInt(numBox,10) + 1));
861           if ( (colgr != null) && (colgr != undefined) ){
862             tbM.removeChild(colgr);
863           for (var c=0;c<trM[r].cells.length;c++) {
864                         document.getElementById("colgroup_main_"+numBox).childNodes[c].setAttribute("width",colSizes[tbl][c]);
865          }
866       }
867         }
868}
869
870function resizeMailList() {
871        if (document.getElementById("table_message_header_box_"+numBox)==null)
872                return false;
873        var innerWidth = (window.innerWidth?window.innerWidth:document.body.clientWidth);
874        var scrollWidth = (innerWidth - 20 - getColumnPosition(Element("exmail_main_body"),"BODY")[0]);
875        document.getElementById("table_message_header_box_"+numBox).style.width = (scrollWidth-2)+'px';
876        if (document.getElementById("table_resultsearch_"+numBox)==null)
877                document.getElementById("table_box").style.width = scrollWidth+'px';
878        else
879                document.getElementById("table_resultsearch_"+numBox).style.width = scrollWidth+'px';
880        syncColumns();
881}
882
883function selectCancel(ev) {
884        return (false);
885}
886
887function buildColGroup(tbl) {
888        var col_element;
889        var colgr_element = document.createElement("COLGROUP");
890        if (tbl==null) tbl = 0;
891        for (i=0;i<colSizes[tbl].length;i++) {
892                col_element = document.createElement("COL");
893                col_element.setAttribute("align", colAligns[tbl][i]);
894                colgr_element.appendChild(col_element);
895        }
896        return (colgr_element);
897}
898
899function createTDElement(table_list,col_index,class_name,td_align,td_id) {
900        var td_element = document.createElement("TD");
901        td_element.setAttribute("width",colSizes[table_list][col_index]);
902        if (class_name) td_element.className = class_name;
903        if (td_align) td_element.align = td_align;
904        if (td_id) td_element.id = td_id;
905        return (td_element);
906}
907
908function prepareColSizesArray() {
909        var colSizesCookie = getColSizesCookie();
910        if (colSizesCookie) {
911                try {
912                        var colSizesA = colSizesCookie.split(":");
913                        colSizes = [colSizesA[0].split(","),colSizesA[1].split(",")];
914                }
915                catch(e) {}
916        }
917}
918
919function setColSizesCookie() {
920        var str = "maillist_colsizes=" + colSizes[0].join() + ":" + colSizes[1].join();
921        var date = new Date();
922        date.setTime(date.getTime()+(365*24*60*60*1000));
923        str += ("; expires="+date.toGMTString());
924        document.cookie = str;
925}
926
927function getColSizesCookie() {
928        var search = "maillist_colsizes=";
929        if (document.cookie.length > 0) {
930                var offset = document.cookie.indexOf(search);
931                if (offset != -1) {
932                        offset += search.length;
933                        var end = document.cookie.indexOf(";", offset);
934                        if (end == -1)
935                                end = document.cookie.length;
936                        return document.cookie.substring(offset, end);
937                }
938        }
939        return null;
940}
941
942// Draw the inbox and another folders
943function draw_box(headers_msgs, msg_folder, alternate){
944        /*
945         * When the paging response is not in the correct folder you need to change folder
946         * This occurs when the Ajax response is not fast enough and the user click in outher
947         * folder before finishing the Ajax request
948         */
949        if (msg_folder != headers_msgs['folder']) {
950
951                if (headers_msgs['folder']) {
952                        array_folder = headers_msgs['folder'].split('/');
953
954                        if (array_folder.length > 1) {
955                                name_folder = array_folder[1];
956                        }
957                        else {
958                                name_folder = headers_msgs['folder'];
959                        }
960                        current_folder = headers_msgs['folder'];
961                        Element("border_id_0").innerHTML = "&nbsp;" + lang_folder(name_folder) + '&nbsp;<font face="Verdana" size="1" color="#505050">[<span id="new_m">&nbsp;</span> / <span id="tot_m"></span>]</font>';
962
963                        Element('new_m').innerHTML = headers_msgs['tot_unseen'] ? '<font color="RED">'+headers_msgs['tot_unseen']+'</font>' : 0;
964                        Element("tot_m").innerHTML = headers_msgs['num_msgs'];
965
966                        tree_folders.getNodeById(headers_msgs['folder'])._select();
967                }
968        }
969        /* --- */
970
971        if (alternate)
972                kill_current_box();
973
974        if(is_ie)
975                document.getElementById("border_table").width = "99.5%";
976
977        numBox = 0; //As pastas sempre estarão na aba 0
978       
979        openTab.content_id[numBox] = document.getElementById("content_id_"+numBox);
980        openTab.content_id[numBox].innerHTML = "";
981        openTab.imapBox[numBox] = msg_folder;
982        openTab.type[numBox] = 0;
983
984        table_message_header_box = document.getElementById("table_message_header_box_"+numBox);
985        if (table_message_header_box == null) {
986                var table_element = document.createElement("TABLE");
987                var colgr_element = buildColGroup();
988                colgr_element.setAttribute("id","colgroup_head_"+numBox);
989                var tbody_element = document.createElement("TBODY");
990                //add events for column resizing
991                if (is_ie) {
992                        table_element.attachEvent("onmousemove",changeCursorState);
993                        table_element.attachEvent("onmousedown",startColResize);
994                }
995                else {
996                        table_element.addEventListener("mousemove",changeCursorState,false);
997                        table_element.addEventListener("mousedown",startColResize,false);
998                }
999                table_element.setAttribute("id", "table_message_header_box_"+numBox);
1000                table_element.className = "table_message_header_box";
1001                if (!is_ie)
1002                        table_element.style.width = "98.8%";
1003                //if table is empty
1004                table_element.emptyBody = false;
1005
1006                tr_element = document.createElement("TR");
1007                tr_element.className = "message_header";
1008
1009                td_element1 = createTDElement(0,0);
1010                chk_box_element = document.createElement("INPUT");
1011                chk_box_element.id  = "chk_box_select_all_messages";
1012                chk_box_element.setAttribute("type", "checkbox");
1013                chk_box_element.className = "checkbox";
1014                chk_box_element.onclick = function(){select_all_messages(this.checked);};
1015                chk_box_element.onmouseover = function () {this.title=get_lang('Select all messages.')};
1016                chk_box_element.onkeydown = function (e){
1017                        if (is_ie)
1018                        {
1019                                if ((window.event.keyCode) == 46)
1020                                        proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
1021                        }
1022                        else
1023                        {
1024                                if ((e.keyCode) == 46)
1025                                        proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
1026                        }
1027                };
1028
1029                td_element1.appendChild(chk_box_element);
1030
1031                td_element2 = createTDElement(0,1);
1032                td_element3 = createTDElement(0,7,"th_resizable","left","message_header_SORTFROM_"+numBox);
1033                td_element3.onclick = function () {sort_box(search_box_type,'SORTFROM');};
1034                td_element3.innerHTML = get_lang("From");
1035
1036                td_element4 = createTDElement(0,8,"th_resizable","left","message_header_SORTSUBJECT_"+numBox);
1037                td_element4.onclick = function () {sort_box(search_box_type,'SORTSUBJECT');};
1038                td_element4.innerHTML = get_lang("Subject");
1039
1040                td_element5 = createTDElement(0,9,"th_resizable","center","message_header_SORTARRIVAL_"+numBox);
1041                td_element5.onclick = function () {sort_box(search_box_type,'SORTARRIVAL');};
1042                td_element5.innerHTML = get_lang("Date");
1043
1044                td_element6 = createTDElement(0,10,"th_resizable","left","message_header_SORTSIZE_"+numBox);
1045                td_element6.onclick = function () {sort_box(search_box_type,'SORTSIZE');}
1046                td_element6.innerHTML = get_lang("Size");
1047
1048                tr_element.appendChild(td_element1);
1049                tr_element.appendChild(td_element2);
1050
1051                var td_element21 = createTDElement(0,2);
1052                td_element21.innerHTML = "&nbsp;";
1053
1054                var td_element22 = createTDElement(0,3);
1055                td_element22.innerHTML = "&nbsp;";
1056
1057                var td_element23 = createTDElement(0,4);
1058                td_element23.innerHTML = "&nbsp;";
1059
1060                var td_element24 = createTDElement(0,5);
1061                td_element24.innerHTML = "&nbsp;";
1062
1063                var td_element25 = createTDElement(0,6);
1064                td_element25.innerHTML = "&nbsp;";
1065
1066                tr_element.appendChild(td_element21);
1067                tr_element.appendChild(td_element22);
1068                tr_element.appendChild(td_element23);
1069                tr_element.appendChild(td_element24);
1070                tr_element.appendChild(td_element25);
1071                tr_element.appendChild(td_element3);
1072                tr_element.appendChild(td_element4);
1073                tr_element.appendChild(td_element5);
1074                tr_element.appendChild(td_element6);
1075
1076                tbody_element.appendChild(tr_element);
1077                table_element.appendChild(tbody_element);
1078                table_element.appendChild(colgr_element);
1079
1080                var _divScroll = document.getElementById("divScrollHead_"+numBox);
1081
1082                if(!_divScroll){
1083                        _divScroll = document.createElement("DIV");
1084                        _divScroll.id = "divScrollHead_"+numBox;
1085                }
1086
1087                _divScroll.style.overflowY = "hidden";
1088                _divScroll.style.overflowX = "hidden";
1089                _divScroll.style.width  ="100%";
1090
1091                if (is_mozilla){
1092                        _divScroll.style.width  ="99.3%";
1093                }
1094
1095                _divScroll.appendChild(table_element);
1096                openTab.content_id[numBox].appendChild(_divScroll);
1097
1098                var table_layout = (getStyle("table_message_header_box_"+numBox,"table-layout") || getStyle("table_message_header_box_"+numBox,"tableLayout"));
1099                cssForResizing = (table_layout=="fixed");
1100                if (cssForResizing)
1101                        prepareColSizesArray();
1102        }
1103        draw_header_box();
1104        var table_element = document.createElement("TABLE");
1105        var colgr_element = buildColGroup();
1106        colgr_element.setAttribute("id","colgroup_main_"+numBox);
1107
1108        var tbody_element = document.createElement("TBODY");
1109        table_element.id = "table_box";
1110        table_element.className = "table_box";
1111        table_element.borderColorDark = "#bbbbbb";
1112        table_element.frame = "void";
1113        table_element.rules = "rows";
1114        table_element.cellPadding = "0";
1115        table_element.cellSpacing = "0";
1116
1117        table_element.onkeydown = function (e){
1118                if (is_ie)
1119                {
1120                        if ((window.event.keyCode) == 46)
1121                        {
1122                                //delete_all_selected_msgs_imap();
1123                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
1124                        }
1125                }
1126                else
1127                {
1128                        if ((e.keyCode) == 46)
1129                        {
1130                                //delete_all_selected_msgs_imap();
1131                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
1132                        }
1133                }
1134        };
1135        if (is_ie)
1136                table_element.style.cursor = "hand";
1137
1138        tbody_element.setAttribute("id", "tbody_box");
1139        table_element.appendChild(tbody_element);
1140        table_element.appendChild(colgr_element);
1141
1142        var _divScroll = document.getElementById("divScrollMain_"+numBox);
1143
1144        if(!_divScroll){
1145                _divScroll = document.createElement("DIV");
1146                _divScroll.id = "divScrollMain_"+numBox;
1147        }
1148
1149        _divScroll.style.overflowY = "scroll";
1150        _divScroll.style.overflowX = "hidden";
1151        _divScroll.style.width  ="100%";
1152
1153        if (is_mozilla){
1154                _divScroll.style.overflow = "-moz-scrollbars-vertical";
1155                _divScroll.style.width  ="100%";
1156        }
1157        _divScroll.appendChild(table_element);
1158        openTab.content_id[numBox].appendChild(_divScroll);
1159
1160        var f_unseen = 0;
1161
1162        document.getElementById("table_message_header_box_"+numBox).emptyBody = false;
1163
1164        if (headers_msgs.num_msgs == 0)
1165                showEmptyBoxMsg(tbody_element);
1166
1167        for (var i=0; i < headers_msgs.length; i++){
1168                        if ((headers_msgs[i].Unseen == 'U') || (headers_msgs[i].Recent == 'N'))
1169                                f_unseen++;
1170                        tr_element = make_tr_message(headers_msgs[i], msg_folder, headers_msgs.offsetToGMT);
1171                        if (tr_element){
1172                                tbody_element.appendChild(tr_element);
1173                                add_className(tr_element, i%2 != 0 ? 'tr_msg_read2' : 'tr_msg_read');
1174                        }
1175                        _dragArea.makeDragged(tr_element, headers_msgs[i].msg_number, headers_msgs[i].subject, true);
1176        }
1177
1178        if ((preferences.use_shortcuts == '1') && (headers_msgs[0]))
1179                select_msg(headers_msgs[0].msg_number, 'null', true);
1180               
1181
1182        var tdFolders  =  Element("folderscol");
1183        tdFolders.style.display = preferences.hide_folders == '1'  ? "none" : "";
1184        if ( !currentTab )
1185                alternate_border(numBox);
1186        draw_footer_box(headers_msgs.num_msgs);
1187        Element('main_table').style.display = '';
1188        if(is_ie6)        // Stupid Fixing on IE6.
1189                setTimeout("resizeWindow()",1);
1190        else
1191                resizeWindow();
1192        if(debug) {
1193                var _eTime = new Date();
1194                _eTime = _eTime.getTime();
1195                alert("Carregou em "+(_eTime - _bTime)+" ms");
1196        }
1197        var msg_folder = Element('msg_folder').value;
1198        var msg_number = Element('msg_number').value;
1199        if(!msg_folder && msg_number) {
1200                new_message('new','null');
1201        }
1202        else if(msg_folder && msg_number){
1203                cExecute("$this.imap_functions.get_info_msg&msg_number="+ msg_number + "&msg_folder=" + url_encode(msg_folder), show_msg);
1204                Element('msg_folder').value = '';
1205                Element('msg_number').value = '';
1206        }
1207        var scripts = new Array("InfoContact",
1208                                                        "TreeShow");
1209        connector.loadAllScripts(scripts);
1210        // Loading Quota View Folder Component (if exists...)
1211        if(Element("table_quota"))
1212                connector.loadScript("InfoQuota");
1213
1214        // creates the dotted ruler which helps user to visualize resizing of columns
1215        var ruler_element = document.getElementById("table_message_ruler");
1216        if (ruler_element == null) {
1217                ruler_element = document.createElement("DIV");
1218                ruler_element.setAttribute("id", "table_message_ruler");
1219                ruler_element.className = "table_message_ruler";
1220                ruler_element.style.top = getColumnPosition(document.getElementById("content_id_0"),"BODY")[1];
1221                document.getElementById("exmail_main_body").appendChild(ruler_element);
1222    }
1223
1224}
1225
1226function showEmptyBoxMsg(tbody_element) {
1227        document.getElementById("table_message_header_box_"+numBox).emptyBody = true;
1228        var div_pasta = document.getElementById("div_msg_info");
1229        if (!div_pasta){
1230            div_info = document.createElement("div");
1231            div_info.setAttribute("id", "div_msg_info");
1232            div_info.setAttribute("background", "#FFF");
1233            h3_info = document.createElement("h3");
1234            h3_info.style.padding = "10px";
1235            h3_info.setAttribute("id", "msg_info");
1236            h3_info.align = "center";
1237            h3_info.innerHTML = get_lang("This mail box is empty");
1238            div_info.appendChild(h3_info);
1239            tbody_element.parentNode.parentNode.appendChild(div_info);
1240        }
1241}
1242
1243// Passar o parâmetro offset para esta função
1244function make_tr_message(headers_msgs, msg_folder, offsetToGMT){
1245                if (typeof offsetToGMT == 'undefined')
1246                {
1247                    // In older local messages headers_msgs.offsetToGMT is undefined.
1248                    offsetToGMT = typeof headers_msgs.offsetToGMT != 'undefined'?headers_msgs.offsetToGMT:0;
1249                }
1250                var tr_element = document.createElement('tr');
1251                if(typeof(preferences.line_height) != 'undefined')
1252                        tr_element.style.height = preferences.line_height;
1253                tr_element.id = headers_msgs.msg_number;
1254
1255                tr_element.msg_sample = "";
1256                //if(headers_msgs.msg_sample && headers_msgs.msg_sample.preview_msg_subject != "")
1257                if(headers_msgs.msg_sample && preferences.preview_msg_subject == "1" && headers_msgs.msg_sample.body !== "")
1258                {
1259                        if (cssForResizing) //Colunas redimensionaveis - nao trunca
1260                                tr_element.msg_sample = Base64.decode(headers_msgs.msg_sample.body).substr(0,180) + "..."; //trecho do body que sera exibido com o assunto;
1261                        else
1262                                tr_element.msg_sample = Base64.decode(headers_msgs.msg_sample.body).substr(0,120) + "..."; //trecho do body que sera exibido com o assunto;
1263                }
1264
1265                tr_element.tip = "";
1266                if(headers_msgs.msg_sample && preferences.preview_msg_tip == "1" && headers_msgs.msg_sample.body !== "")
1267                {
1268                        tr_element.tip = Base64.decode(headers_msgs.msg_sample.body).substr(3,300) + "..."; //trecho do body que sera exibido no tool-tip;
1269                }
1270
1271                if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N')){
1272                        if ((headers_msgs.Flagged == 'F') || headers_msgs.Importance.toLowerCase().indexOf("high")!=-1 )
1273                                add_className(tr_element, 'flagged_msg');
1274                        add_className(tr_element, 'tr_msg_unread');
1275                }
1276                else{
1277                        if ((headers_msgs.Flagged == 'F') || ( headers_msgs.Importance !== undefined && headers_msgs.Importance.toLowerCase().indexOf("high")!=-1 ) )
1278                                add_className(tr_element,'flagged_msg');
1279                }
1280
1281                if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N'))
1282                        add_className(tr_element, 'tr_msg_unread');
1283
1284                if (headers_msgs.Flagged == 'F')
1285                        add_className(tr_element,'flagged_msg');
1286
1287                td_element1 = createTDElement(0,0,"td_msg");
1288                chk_box_element = document.createElement("INPUT");
1289                chk_box_element.setAttribute("type", "checkbox");
1290                chk_box_element.className = "checkbox";
1291                chk_box_element.setAttribute("id", "check_box_message_"+headers_msgs.msg_number);
1292                chk_box_element.onclick = function(e){
1293                        if (is_ie)
1294                                changeBgColor(window.event,headers_msgs.msg_number);
1295                        else
1296                                changeBgColor(e,headers_msgs.msg_number);
1297                };
1298                td_element1.appendChild(chk_box_element);
1299
1300                td_element2 = createTDElement(0,1,"td_msg");
1301                if (headers_msgs.attachment == 1)
1302                        td_element2.innerHTML = "<img src ='templates/"+template+"/images/clip.gif' >";
1303
1304                td_element21 = createTDElement(0,2,"td_msg",null,"td_message_answered_"+headers_msgs.msg_number);
1305
1306                if ((headers_msgs.Forwarded == 'F')  || (headers_msgs.Draft == 'X' && headers_msgs.Answered == 'A')){
1307                        td_element21.onclick=function(){search_emails(headers_msgs.subject.replace(/^(re: ?|fw: ?|enc: ?|res: ?|fwd: ?)*/gi,''),true);};
1308                        td_element21.innerHTML = "<img src ='templates/"+template+"/images/forwarded.gif' title='"+get_lang('Forwarded')+"'>";
1309                        headers_msgs.Draft = ''
1310                        headers_msgs.Answered = '';
1311                        headers_msgs.Forwarded = 'F';
1312                }
1313                else if (headers_msgs.Draft == 'X')
1314                        td_element21.innerHTML = "<img src ='templates/"+template+"/images/draft.gif' title='"+get_lang('Draft')+"'>";
1315                else if (headers_msgs.Answered == 'A'){
1316                        td_element21.onclick=function(){search_emails(headers_msgs.subject.replace(/^(re: ?|fw: ?|enc: ?|res: ?|fwd: ?)*/gi,''),true);};
1317                        td_element21.innerHTML = "<img src ='templates/"+template+"/images/answered.gif' title='"+get_lang('Answered')+"'>";
1318                    }else
1319                        td_element21.innerHTML = "&nbsp;&nbsp;&nbsp;";
1320
1321                td_element22 = createTDElement(0,1,"td_msg",null,"td_message_signed_"+headers_msgs.msg_number);
1322                switch(headers_msgs.ContentType)
1323                {
1324                        case "signature":
1325                        {
1326                                td_element22.innerHTML = "<img src ='templates/"+template+"/images/signed_msg.gif' title='" + get_lang('Signed message') + "'>";
1327                                break;
1328                        }
1329                        case "cipher":
1330                        {
1331                                td_element22.innerHTML = "<img src ='templates/"+template+"/images/lock.gif' title='" + get_lang('Crypted message') + "'>";
1332                                break;
1333                        }
1334                        default:
1335                        {
1336                                break;
1337                        }
1338                }
1339
1340                td_element23 = createTDElement(0,4,"td_msg",null,"td_message_important_"+headers_msgs.msg_number);
1341
1342                if ( (headers_msgs.Flagged == 'F') || ( headers_msgs.Importance !== undefined && headers_msgs.Importance.toLowerCase().indexOf("high") != -1 ))
1343                {
1344                        td_element23.innerHTML = "<img src ='templates/"+template+"/images/important.gif' title='"+get_lang('Important')+"'>";
1345                }
1346                else
1347                        td_element23.innerHTML = "&nbsp;&nbsp;&nbsp;";
1348
1349                td_element24 = createTDElement(0,5,"td_msg",null,"td_message_sent_"+headers_msgs.msg_number);
1350                td_element24.innerHTML = "&nbsp;&nbsp;&nbsp;";
1351                // preload image
1352                var _img_sent = new Image();
1353                _img_sent.src    = "templates/"+template+"/images/sent.gif";
1354
1355
1356
1357                td_element25 = createTDElement(0,6,"td_msg",null,"td_message_unseen_"+headers_msgs.msg_number);
1358                if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N'))
1359                        td_element25.innerHTML = "<img src ='templates/"+template+"/images/unseen.gif' title='"+get_lang('Unseen')+"'>";
1360                else
1361                        td_element25.innerHTML = "<img src ='templates/"+template+"/images/seen.gif' title='"+get_lang('Seen')+"'>";
1362
1363
1364                td_element3 = createTDElement(0,7,"td_msg td_resizable","left","td_from_"+ headers_msgs.msg_number);
1365                var _onclick = function(){InfoContact.hide();proxy_mensagens.get_msg(headers_msgs.msg_number, msg_folder,true, show_msg);};
1366                td_element3.onclick = _onclick;
1367                td_element3.innerHTML = '&nbsp;';
1368
1369                test = true;
1370                if(msg_folder.indexOf(special_folders['Sent']) !=-1 ||msg_folder.indexOf(preferences.save_in_folder) !=-1 || msg_folder.replace("local_","INBOX"+cyrus_delimiter).indexOf(preferences.save_in_folder) !=-1)
1371                    test = false;
1372               
1373                if( (msg_folder.indexOf(special_folders['Sent']) !=-1) && (headers_msgs.from != undefined) && headers_msgs.from.email.toLowerCase() == Element("user_email").value.toLowerCase() && (preferences.from_to_sent == "1") && !(msg_folder.substr(0,5) == "user/"))
1374                {
1375                        td_element3.onmouseover = function () {this.title=headers_msgs.to.email;};
1376                        if (headers_msgs.Draft == 'X')
1377                                td_element3.innerHTML += "<span style=\"color:red\">("+get_lang("Draft")+") </span>";
1378                        else{
1379                                if(headers_msgs.to.email != null && headers_msgs.to.email.toLowerCase() != Element("user_email").value)
1380                                        td_element24.innerHTML = "<img valign='center' src ='templates/"+template+"/images/sent.gif' title='"+get_lang('Sent')+"'>";
1381
1382                                if (headers_msgs.to) {
1383                                        if (headers_msgs.to.name != null)
1384                                                td_element3.innerHTML += headers_msgs.to.name;
1385                                        else if(headers_msgs.to.email != null) {
1386                                                td_element3.innerHTML += headers_msgs.to.email;
1387                                        }
1388                                        else {
1389                                                td_element3.innerHTML += get_lang("without destination");
1390                                        }
1391                                }
1392                        }
1393                }
1394                else{
1395                        if (headers_msgs.Draft == 'X'){
1396                                td_element3.innerHTML = "<span style=\"color:red\">("+get_lang("Draft")+") </span>";
1397                        }
1398                        else{
1399                                var spanSender = document.createElement("SPAN");
1400                                spanSender.onmouseover = function (event) {this.style.textDecoration = "underline";try {InfoContact.begin(this,headers_msgs.from.email)} catch(e){};};
1401                                spanSender.onmouseout = function (){try {this.style.textDecoration = "none";clearTimeout(InfoContact.timeout);} catch(e){}};
1402                                folder = special_folders['Sent'];
1403                                current = get_current_folder();
1404                                if ((preferences.from_to_sent == "1") && (current.substr(current.length - folder.length, folder.length) == folder)){
1405                                        if (headers_msgs.to) {
1406                                                if (headers_msgs.to.name != null){
1407                                                        spanSender.innerHTML += headers_msgs.to.name;
1408                                                }else if(headers_msgs.to.email != null) {
1409                                                        spanSender.innerHTML += headers_msgs.to.email;
1410                                                }
1411                                        }
1412                                }else if(headers_msgs.from !== undefined){
1413                                spanSender.innerHTML =  headers_msgs.from.name != null ? headers_msgs.from.name : headers_msgs.from.email;
1414                                }
1415                                if (spanSender.innerHTML.indexOf(" ") == '-1' && spanSender.innerHTML.length > 25){
1416                                        spanSender.innerHTML = spanSender.innerHTML.substring(0,25) + "...";
1417                                }
1418                                else if (spanSender.innerHTML.length > 40 ){
1419                                        spanSender.innerHTML = spanSender.innerHTML.substring(0,40) + "...";
1420                                }
1421                                td_element3.appendChild(spanSender);
1422                        }
1423                }
1424
1425                td_element4 = createTDElement(0,8,"td_msg td_resizable","left");
1426                td_element4.onclick = _onclick;
1427                td_element4.innerHTML = !is_ie ? "<a nowrap id='a_message_"+tr_element.id+"'>&nbsp;" : "&nbsp;";
1428
1429                if ((headers_msgs.subject)&&(headers_msgs.subject.length > 50))
1430                {
1431                        if (cssForResizing)
1432                                //Colunas redimensionaveis - nao trunca
1433                                td_element4.innerHTML += headers_msgs.subject + "<span style=\"color:#b3b3b3;\">  " + tr_element.msg_sample +"</span>";
1434                        else {
1435                                //Modificacao para evitar que o truncamento do assunto quebre uma NCR - #1189
1436                                pos = headers_msgs.subject.indexOf("&",45);
1437                                if ((pos > 0) && (pos <= 50) && ((headers_msgs.subject.charAt(pos+5) == ";") || (headers_msgs.subject.charAt(pos+6) == ";")))
1438                                        td_element4.innerHTML += headers_msgs.subject.substring(0,pos+6) + "..." + "<span style=\"color:#b3b3b3;\">  " + tr_element.msg_sample +"</span>";
1439                                else
1440                                        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;
1441                        }
1442                }
1443                else
1444                {
1445                        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;
1446                }
1447
1448                td_element4.title=tr_element.tip;
1449                if(!is_ie){
1450                        td_element4.innerHTML += "</a>";
1451                }
1452
1453
1454                td_element5 = createTDElement(0,9,"td_msg td_resizable","center");
1455                td_element5.onclick = _onclick;
1456
1457                var norm = function (arg) {return (arg < 10 ? '0'+arg : arg);};
1458                var weekDays = ['Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday'];
1459
1460                var today = new Date();
1461                today.setHours(23);
1462                today.setMinutes(59);
1463                today.setSeconds(59);
1464                today.setMilliseconds(999)
1465
1466                var udate_local = null;
1467                var date_msg = null;
1468
1469                // old local messages can capture headers_msgs.udate as "hh:mm" or "dd/mm/yyyy"
1470                if ( (headers_msgs.udate !== undefined) && (headers_msgs.udate.toString().match(/\d{2}:\d{2}/) || headers_msgs.udate.toString().match(/\d{2}\/\d{2}\/\d{4}/)) )
1471                {
1472                    temp_msg_day = headers_msgs.msg_day.split('/');
1473                    temp_msg_hour = headers_msgs.msg_hour.split(':');
1474                    date_msg = new Date(temp_msg_day[2], temp_msg_day[1]-1, temp_msg_day[0], temp_msg_hour[0], temp_msg_hour[1]);
1475                }
1476                else
1477                    {
1478                        // The new date implementation
1479                        // Using offset between user defined timezone and GMT
1480                        // Date object converts time to local timezone, so we have to adjust it
1481                        udate_local = headers_msgs.udate*1000 + offsetToGMT*1000 + today.getTimezoneOffset()*60*1000;
1482                        date_msg = new Date(udate_local);
1483                    }
1484
1485                if (today.getTime() - date_msg.getTime() < 86400000)
1486                        td_element5.innerHTML = norm(date_msg.getHours()) + ':' + norm(date_msg.getMinutes());
1487                else
1488                        if (today.getTime() - date_msg.getTime() < 172800000)
1489                                td_element5.innerHTML = get_lang('Yesterday');
1490                        else
1491                                if (today.getTime() - date_msg.getTime() < 259200000)
1492                                        td_element5.innerHTML = get_lang(weekDays[date_msg.getDay()]);
1493                                else
1494                                        td_element5.innerHTML = norm(date_msg.getDate()) + '/' + norm(date_msg.getMonth()+1) + '/' +date_msg.getFullYear();
1495                td_element5.title = norm(date_msg.getDate()) + '/' + norm(date_msg.getMonth()+1) + '/' +date_msg.getFullYear();
1496                td_element5.alt = td_element5.title;
1497
1498                td_element6 = createTDElement(0,10,"td_msg td_resizable","center");
1499                td_element6.onclick = _onclick;
1500                td_element6.setAttribute("noWrap","true");
1501                td_element6.innerHTML = borkb(headers_msgs.Size);
1502
1503                tr_element.appendChild(td_element1);
1504                tr_element.appendChild(td_element2);
1505                tr_element.appendChild(td_element21);
1506                tr_element.appendChild(td_element22);
1507                tr_element.appendChild(td_element23);
1508                        tr_element.appendChild(td_element24);
1509                tr_element.appendChild(td_element25);
1510                tr_element.appendChild(td_element3);
1511                tr_element.appendChild(td_element4);
1512                tr_element.appendChild(td_element5);
1513                tr_element.appendChild(td_element6);
1514                return tr_element;
1515}
1516
1517function sort_box(search, sort){
1518        if (cellResized)
1519                return;
1520        var message_header = Element("message_header_"+search);
1521        var handler_draw_box = function(data){
1522                draw_box(data, current_folder,true);
1523                //Mostrar as msgs nao lidas de acordo com o filtro de relevancia
1524        var msgs_unseen = 0;
1525                draw_paging(data.num_msgs);
1526                Element("new_m").innerHTML = '<font style="color:'+(data.tot_unseen == 0 ? '': 'red')+'">' + data.tot_unseen + '</font>';
1527                Element("tot_m").innerHTML = data.num_msgs;
1528        }
1529
1530        if(sort_box_type == sort && search_box_type == search){
1531                sort_box_reverse = sort_box_reverse ? 0 : 1;
1532        }
1533        else if(sort_box_type != sort){
1534                if ( (sort == 'SORTFROM') || (sort == 'SORTSUBJECT') )
1535                        sort_box_reverse = 0;
1536                else
1537                        sort_box_reverse = 1;
1538        }
1539
1540        // Global variable.
1541        sort_box_type = sort;
1542        search_box_type = search;
1543
1544        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);
1545        current_page = 1;
1546        //Comentado para nao sobrepor o numero de msgs nao lidas ao utilizar os filtros
1547        //update_menu();
1548}
1549
1550function draw_header_box(){
1551        switch(sort_box_type){
1552                case 'SORTFROM':
1553                        type_name = get_lang("From");
1554                        break;
1555                case 'SORTSUBJECT':
1556                        type_name = get_lang("Subject");
1557                        break;
1558                case 'SORTARRIVAL':
1559                        type_name = get_lang("Date");
1560                        break;
1561                case 'SORTSIZE':
1562                        type_name = get_lang("Size");
1563                        break;
1564                default:
1565                        type_name = get_lang("Date");
1566                        break;
1567        }
1568        folder = special_folders['Sent'];
1569        current = get_current_folder();
1570        if ((preferences.from_to_sent == "1") && (current.substr(current.length - folder.length, folder.length) == folder)) {
1571        document.getElementById("message_header_SORTFROM_"+numBox).innerHTML    = get_lang("To");
1572    }else{
1573        document.getElementById("message_header_SORTFROM_"+numBox).innerHTML    = get_lang("From");
1574    }
1575        document.getElementById("message_header_SORTSUBJECT_"+numBox).innerHTML = get_lang("Subject");
1576        document.getElementById("message_header_SORTARRIVAL_"+numBox).innerHTML = get_lang("Date");
1577        document.getElementById("message_header_SORTSIZE_"+numBox).innerHTML    = get_lang("Size");
1578        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'>";
1579}
1580function verifyOption(name, id){
1581        var str = name + '' + id;
1582        if(!Element(str).style.display == ""){
1583                var option_reply_options = document.getElementById('msg_opt_reply_options_'+id);
1584                option_reply_options.value = 'show';
1585                option_reply_options.src= '../expressoMail1_2/templates/default/images/down.png';
1586                Element('tr_other_options_'+id).style.display = 'none';
1587                var option_more_options = document.getElementById('msg_opt_more_options_'+id);
1588                option_more_options.value = 'show';
1589                option_more_options.src= '../expressoMail1_2/templates/default/images/down.png';
1590                Element('tr_other_more_options_'+id).style.display = 'none';
1591                var option_mark_as_options = document.getElementById('msg_opt_mark_options_'+id);
1592                option_mark_as_options.value = 'show';
1593                option_mark_as_options.src= '../expressoMail1_2/templates/default/images/down.png';
1594                Element('tr_other_mark_options_'+id).style.display = 'none';
1595        }
1596}
1597
1598/*Busca a primeira mensagem na pagina*/
1599function firstRow(){
1600        var thisCell;
1601    if (objCell)
1602        thisCell = objCell;
1603    else
1604            thisCell = document.getElementById("table_message_header_box_0").rows[0].cells[0];
1605    var tbM = getMessagesTable(thisCell);
1606        proxy_mensagens.get_msg(tbM.rows[0].getAttribute('id'),get_current_folder(),true,show_msg);
1607}
1608
1609/*Busca a ultima mensagem na pagina*/
1610function lastRow(){
1611        var thisCell;
1612    if (objCell)
1613        thisCell = objCell;
1614    else
1615            thisCell = document.getElementById("table_message_header_box_0").rows[0].cells[0];
1616    var tbM = getMessagesTable(thisCell);
1617        proxy_mensagens.get_msg(tbM.rows[tbM.rows.length - 1].getAttribute('id'),get_current_folder(),true,show_msg);
1618}
1619
1620var msg_selected;
1621function draw_message(info_msg, ID){
1622        var content = document.getElementById('content_id_' + ID);
1623
1624        var menuHidden = Element("folderscol").style.display == 'none' ? true : false;
1625         //////////////////////////////////////////////////////////////////////////////////////////////////////
1626        //Make the next/previous buttom.
1627        //////////////////////////////////////////////////////////////////////////////////////////////////////
1628        var next_previous_msg_td = document.createElement("TD");
1629        next_previous_msg_td.setAttribute("noWrap","true");
1630        next_previous_msg_td.align = "right";
1631        next_previous_msg_td.width = "40px";
1632        var img_next_msg = document.createElement("IMG");
1633        img_next_msg.id = 'msg_opt_next_' + ID;
1634        img_next_msg.src = './templates/'+template+'/images/down.button.png';
1635        if(preferences.use_shortcuts == '1')
1636            img_next_msg.title = get_lang('Next Shortcut:Control + Down');
1637        else
1638            img_next_msg.title = get_lang('Next');
1639        img_next_msg.style.cursor = 'pointer';
1640
1641        var folder_id = ID.match(/\d+/)[0];
1642        var folder;
1643
1644        //Correção para fazer funcionar e-mails assinados no formato encapsulado.
1645       // folder_id = info_msg.original_ID ? info_msg.original_ID: info_msg.msg_number;
1646        //if ((folder = document.getElementById(info_msg.msg_number)) == null)
1647        if ((folder = Element(info_msg.original_ID)) == null)
1648                folder = Element(info_msg.msg_number);
1649               
1650
1651        if (folder){ // mensagem local criptografada nao tem ID da pasta local
1652                if (folder.nextSibling){
1653                        var nextMsgBox = folder.nextSibling.name?folder.nextSibling.name:info_msg.msg_folder;
1654
1655                        if (nextMsgBox == "INBOX" + cyrus_delimiter + "decifradas")// teste para ver se a mensagem vem da pasta oculta decifradas
1656                                        nextMsgBox = get_current_folder();
1657
1658                        img_next_msg.onclick = function()
1659                        {
1660                                currentTab = ID;
1661                                openTab.type[ID] = 2;
1662                                proxy_mensagens.get_msg(folder.nextSibling.id,nextMsgBox,true,show_msg);
1663                                //select_msg('null', 'down', true);
1664                                if (!msg_selected){
1665                                        select_msg('null', 'down', true);
1666                                        msg_selected = true;
1667                                }
1668                        };
1669                }
1670                /*Ultima mensagem de cada página, exceto a ultima*/
1671        else if( (current_page < total_pages) ){
1672                   
1673                   img_next_msg.onclick = function()
1674                        {
1675
1676                           current_page++;
1677                           var tot_msgs = parseInt(Element("tot_m").innerHTML);
1678                           var range_begin = preferences.max_email_per_page*( current_page - 1 ) + 1;
1679                           var range_end;
1680                           if ( range_begin + parseInt(preferences.max_email_per_page - 1) > tot_msgs )
1681                                range_end = tot_msgs;
1682                           else     
1683                                range_end = range_begin + parseInt(preferences.max_email_per_page  - 1); 
1684                           var creatBoxProximo = function (data){
1685                                            draw_box(data, get_current_folder());
1686                                            firstRow();
1687                                };                               
1688                       proxy_mensagens.messages_list(get_current_folder(),range_begin,range_end,sort_box_type,search_box_type,sort_box_reverse,'','', creatBoxProximo);
1689                       
1690                        };         
1691                }
1692                else
1693                {
1694                        img_next_msg.src = "./templates/"+template+"/images/down.gray.button.png";
1695                        img_next_msg.style.cursor = 'default';
1696
1697                }
1698        }
1699        else
1700        {
1701                img_next_msg.src = "./templates/"+template+"/images/down.gray.button.png";
1702                img_next_msg.style.cursor = 'default';
1703                // testa se a mensagem e local
1704            if (!proxy_mensagens.is_local_folder(get_current_folder()) && !(info_msg.msg_folder == "INBOX" + cyrus_delimiter + "decifradas")) // testa se a mensagem e local
1705                {
1706                        img_next_msg.onclick = function()
1707                                {
1708                                        delete_border(ID);
1709                                };
1710                }
1711        }
1712        var img_space = document.createElement("SPAN");
1713        img_space.innerHTML = "&nbsp;";
1714        var img_previous_msg = document.createElement("IMG");
1715        img_previous_msg.id = 'msg_opt_previous_' + ID;
1716        img_previous_msg.src = './templates/'+template+'/images/up.button.png';
1717        if(preferences.use_shortcuts == '1')
1718            img_previous_msg.title = get_lang('Previous Shortcut:Control + Up');
1719        else
1720            img_previous_msg.title = get_lang('Previous');
1721        img_previous_msg.style.cursor = 'pointer';
1722
1723
1724        if (folder){ // mensagem local criptografada nao tem ID da pasta local
1725                if (folder.previousSibling)
1726                {
1727                        var previousMsgBox = folder.previousSibling.name?folder.previousSibling.name:info_msg.msg_folder;
1728
1729                        if (previousMsgBox == "INBOX" + cyrus_delimiter + "decifradas") // teste para ver se a mensagem vem da pasta oculta decifradas
1730                                        previousMsgBox = get_current_folder();
1731
1732                        img_previous_msg.onclick = function()
1733                        {
1734                                currentTab = ID;
1735                                openTab.type[ID] = 2;
1736                                proxy_mensagens.get_msg(folder.previousSibling.id,previousMsgBox,true,show_msg);
1737                                //select_msg('null', 'up', false);
1738                                if (!msg_selected){
1739                                        select_msg('null', 'up', true);
1740                                        msg_selected = true;
1741                                }
1742                        };
1743                }
1744                //primeira mensagem de cada página, exceto a primeira
1745                else if(current_page > 1){
1746                     
1747                      img_previous_msg.onclick = function()
1748                      {
1749                             
1750                             current_page--;
1751                             var range_begin = (current_page - 1)*preferences.max_email_per_page + 1;
1752                             var range_end = current_page*preferences.max_email_per_page;                                   
1753                             var creatBoxAnterior = function (data){
1754                                          draw_box(data, get_current_folder());
1755                                              lastRow();
1756                                         };                               
1757                         proxy_mensagens.messages_list(get_current_folder(),range_begin,range_end,sort_box_type,search_box_type,sort_box_reverse,'','', creatBoxAnterior);               
1758                  };
1759            }
1760                else
1761                {
1762                        img_previous_msg.src = "./templates/"+template+"/images/up.gray.button.png";
1763                        img_previous_msg.style.cursor = 'default';
1764                }
1765        }
1766        else
1767        {
1768                img_previous_msg.src = "./templates/"+template+"/images/up.gray.button.png";
1769                img_previous_msg.style.cursor = 'default';
1770                // testa se a mensagem e local
1771            if (!proxy_mensagens.is_local_folder(get_current_folder()) && !(info_msg.msg_folder == "INBOX" + cyrus_delimiter + "decifradas")) // testa se a mensagem e local
1772                {
1773                        img_previous_msg.onclick = function()
1774                        {
1775                                delete_border(ID);
1776                        };
1777                }
1778        }
1779        next_previous_msg_td.appendChild(img_previous_msg);
1780        next_previous_msg_td.appendChild(img_space);
1781        next_previous_msg_td.appendChild(img_next_msg);
1782        //////////////////////////////////////////////////////////////////////////////////////////////////////
1783        //Make the header message.
1784        //////////////////////////////////////////////////////////////////////////////////////////////////////
1785        var table_message = document.createElement("TABLE");
1786        var tbody_message = document.createElement("TBODY");
1787        table_message.border = "0";
1788        //table_message.width = "100%";
1789        //k!
1790        table_message.setAttribute("class", "expressomail-message-body");
1791        table_message.setAttribute("className", "expressomail-message-body");
1792        //////////////////////////////////////////////////////////////////////////////////////////////////////
1793        //Make the options message.
1794        //////////////////////////////////////////////////////////////////////////////////////////////////////
1795        var tr0 = document.createElement("TR");
1796        tr0.className = "tr_message_header";
1797        var td0 = document.createElement("TD");
1798        var table_message_options = document.createElement("TABLE");
1799        table_message_options.width = "100%";
1800        table_message_options.border = '0';
1801        table_message_options.className = 'table_message';
1802        var tbody_message_options = document.createElement("TBODY");
1803        var tr = document.createElement("TR");
1804        var td = document.createElement("TD");
1805        td.setAttribute("noWrap","true");
1806        var _name = '';
1807        var _maxChar = menuHidden ? 40 : 15;
1808
1809        if (info_msg.from.name)
1810        {
1811                var spanName = document.createElement("SPAN");
1812                        spanName.innerHTML = info_msg.from.name;
1813                _name = spanName.innerHTML.length > _maxChar ? spanName.innerHTML.substring(0,_maxChar) + "..." : spanName.innerHTML;
1814        }
1815        else
1816                _name = info_msg.from.email.length > _maxChar ? info_msg.from.email.substring(0,_maxChar) + "..." : info_msg.from.email;
1817
1818        td.innerHTML = _name.bold() + ', ' + info_msg.smalldate;
1819        //k!
1820        if (info_msg.attachments && info_msg.attachments.length > 0)
1821                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[0].name+"'>";
1822
1823        if (typeof(info_msg.signature) == 'string')
1824        {
1825                if (info_msg.signature != "void")
1826                        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">';
1827                else
1828                        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'>";
1829        }
1830
1831        if (info_msg.DispositionNotificationTo)
1832        {
1833                td.innerHTML += '&nbsp;<img id="disposition_notification_'+ID+'" style="cursor:pointer" alt="'+ get_lang('Message with read notification') + '" title="'+ get_lang('Message with read notification') + '" src="templates/'+template+'/images/notification.gif">';
1834        }
1835
1836        if (info_msg.Flagged == 'F')
1837        {
1838                td.innerHTML += '&nbsp;<img id="disposition_important_'+ID+'" style="cursor:pointer" alt="'+ get_lang('Important message') + '" title="'+ get_lang('Important message') + '" src="templates/'+template+'/images/important.gif">';
1839        }
1840        // NORMAL MSG
1841        if(info_msg.Draft != 'X')
1842        {
1843        var options = document.createElement("TD");
1844        options.width = "30%";
1845        options.setAttribute("noWrap","true");
1846               
1847                //BEGIN: DESENHA MOSTRA DETALHES, OCULTAR DETALHES
1848        var option_hide_more = document.createElement("SPAN");
1849        option_hide_more.className = 'message_options';
1850        option_hide_more.onmouseover=function () {this.className='message_options_active';};
1851        option_hide_more.onmouseout=function () {this.className='message_options'};
1852        options.align = 'right';
1853        option_hide_more.value = 'more_options';
1854        option_hide_more.id = 'option_hide_more_'+ID;
1855        option_hide_more.onclick = function(){
1856                if (this.value == 'more_options'){
1857                        this.innerHTML = "<b><u>"+get_lang('Hide details')+"</u></b>";
1858                        this.value = 'hide_options';
1859                        Element('table_message_others_options_'+ID).style.display = '';
1860                }
1861                else{
1862                        this.innerHTML = get_lang('Show details');
1863                        this.value = 'more_options';
1864                        Element('table_message_others_options_'+ID).style.display = 'none';
1865                }
1866                resizeWindow();
1867        };
1868                //END: DESENHA MOSTRA DETALHES, OCULTAR DETALHES
1869               
1870                //OPCAO PARA MARCAR COMO
1871                var option_mark_as = document.createElement("SPAN");
1872                option_mark_as.innerHTML = "<b>"+get_lang('Mark as')+"</b>";
1873                option_mark_as.className = 'message_options';
1874                option_mark_as.onmouseover=function () {this.className='message_options_active';};
1875                option_mark_as.onmouseout=function () {this.className='message_options'};
1876                option_mark_as.onclick = function(){
1877                        verifyOption('tr_other_mark_options_', ID);
1878                        var thi = document.getElementById('msg_opt_mark_options_'+ID);
1879                        if (thi.value != 'hide'){
1880                                thi.value = 'hide';
1881                                option_mark_as_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
1882                                Element('tr_other_mark_options_'+ID).style.display = '';
1883
1884                        }
1885                        else{
1886                                thi.value = 'show';
1887                                option_mark_as_options.src= '../expressoMail1_2/templates/default/images/down.png';
1888                                Element('tr_other_mark_options_'+ID).style.display = 'none';
1889                        }
1890                };
1891                //DESENHA OPCOES DO MARCAR COMO
1892        var option_mark_as_unseen = document.createElement("SPAN");
1893                option_mark_as_unseen.className = "reply_options";
1894        option_mark_as_unseen.onclick = function () {changeLinkState(this,'seen');
1895                proxy_mensagens.proxy_set_message_flag(folder_id,'unseen');
1896                write_msg(get_lang('Message marked as ')+get_lang("Unseen"));
1897        };
1898                option_mark_as_unseen.onmouseover=function () {this.className='reply_options_active'};
1899                option_mark_as_unseen.onmouseout=function () {this.className='reply_options'};
1900        option_mark_as_unseen.innerHTML = get_lang("Unseen");
1901
1902        var option_mark_important = document.createElement("SPAN");
1903                option_mark_important.className = 'reply_options';             
1904                option_mark_important.onmouseover=function () {this.className='reply_options_active';};
1905                option_mark_important.onmouseout=function () {this.className='reply_options'};
1906
1907        if (info_msg.Flagged == "F"){
1908                option_mark_important.onclick = function() {
1909                        var _this = this;
1910                        proxy_mensagens.proxy_set_message_flag(folder_id,'unflagged', function(success){
1911                                if (success) {
1912                                        changeLinkState(_this, 'important');
1913                                        write_msg(get_lang('Message marked as ') + get_lang("Normal"));
1914                                }
1915                        } );
1916
1917                };
1918                option_mark_important.innerHTML = get_lang("Normal");
1919        }
1920        else{
1921                option_mark_important.onclick = function() {changeLinkState(this,'normal');
1922                        proxy_mensagens.proxy_set_message_flag(folder_id,'flagged');
1923                        write_msg(get_lang('Message marked as ')+get_lang("Important"));
1924                };
1925                option_mark_important.innerHTML = get_lang("Important");
1926        }
1927                //option_mark.appendChild(option_mark_as_unseen);
1928                //option_mark.appendChild(option_mark_important);
1929
1930               
1931        option_hide_more.innerHTML = get_lang('Show details');
1932                option_hide_more.title = (preferences.use_shortcuts == '1') ? get_lang('Shortcut: %1', 'O') : get_lang('Show details');
1933       
1934                var space3 = document.createElement("SPAN");
1935                space3.innerHTML = '&nbsp;|&nbsp;';
1936               
1937                var option_mark_as_options = document.createElement('IMG');
1938                option_mark_as_options.id = 'msg_opt_mark_options_'+ID;
1939                option_mark_as_options.src = '../expressoMail1_2/templates/default/images/down.png';
1940                option_mark_as_options.value = 'show';
1941
1942                option_mark_as_options.onmouseover = function(){
1943                        option_mark_as_options.src= '../expressoMail1_2/templates/default/images/over.png';
1944                        option_mark_as.className = 'message_options_active';
1945                };
1946                option_mark_as_options.onmouseout = function(){
1947                        option_mark_as.className = 'message_options';
1948                        if (this.value == 'show')
1949                        {
1950                                option_mark_as_options.src= '../expressoMail1_2/templates/default/images/down.png';
1951                        }
1952                        else
1953                        {
1954                                option_mark_as_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
1955                        }
1956                };
1957                option_mark_as_options.onclick = function(){
1958                        verifyOption('tr_other_mark_options_', ID);
1959                        if (this.value != 'hide'){
1960                                this.value = 'hide';
1961                                option_mark_as_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
1962                                Element('tr_other_mark_options_'+ID).style.display = '';
1963
1964                        }
1965                        else{
1966                                this.value = 'show';
1967                                option_mark_as_options.src= '../expressoMail1_2/templates/default/images/down.png';
1968                                Element('tr_other_mark_options_'+ID).style.display = 'none';
1969                        }
1970                };
1971               
1972        options.appendChild(option_hide_more);
1973                options.appendChild(space3);
1974                options.appendChild(option_mark_as_options);                           
1975                options.appendChild(option_mark_as);
1976                //FIM OPCAO PARA MARCAR COMO
1977
1978        var space0 = document.createElement("SPAN");
1979        space0.innerHTML = '&nbsp;|&nbsp;';
1980        var space1 = document.createElement("SPAN");
1981        space1.innerHTML = '&nbsp;|&nbsp;';
1982        var space2 = document.createElement("SPAN");
1983        space2.innerHTML = '&nbsp;|&nbsp;';
1984
1985                //OPCAO PARA MAIS ACOES
1986                var option_more = document.createElement("SPAN");
1987                option_more.id = 'msg_opt_more_actions_'+ID;
1988                option_more.className = 'message_options';
1989                //option_more.onclick = function(){new_message('forward', ID);};
1990                option_more.onmouseover=function () {this.className='message_options_active';};
1991        option_more.onmouseout=function () {this.className='message_options'};
1992                option_more.onclick = function(){
1993                        verifyOption('tr_other_more_options_', ID);
1994                        if (option_more_options.value != 'hide'){
1995                                option_more_options.value = 'hide';
1996                                option_more_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
1997                                Element('tr_other_more_options_'+ID).style.display = '';
1998
1999                        }
2000                        else{
2001                                option_more_options.value = 'show';
2002                                option_more_options.src= '../expressoMail1_2/templates/default/images/down.png';
2003                                Element('tr_other_more_options_'+ID).style.display = 'none';
2004                        }
2005                };
2006                option_more.innerHTML = get_lang('More Actions');
2007               
2008                //CRIA IMG DE MAIS ACOES
2009                var option_more_options = document.createElement('IMG');
2010                option_more_options.id = 'msg_opt_more_options_'+ID;
2011                option_more_options.src = '../expressoMail1_2/templates/default/images/down.png';
2012                option_more_options.value = 'show';
2013
2014                option_more_options.onmouseover = function(){
2015                        option_more.className = 'message_options_active';
2016                        option_more_options.src= '../expressoMail1_2/templates/default/images/over.png';
2017                };
2018                option_more_options.onmouseout = function(){
2019                        option_more.className = 'message_options';
2020                        if (this.value == 'show')
2021                        {
2022                                option_more_options.src= '../expressoMail1_2/templates/default/images/down.png';
2023                        }
2024                        else
2025                        {
2026                                option_more_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
2027                        }
2028                };
2029                option_more_options.onclick = function(){
2030                        verifyOption('tr_other_more_options_',ID);
2031                       
2032                        if (this.value != 'hide'){
2033                                this.value = 'hide';
2034                                option_more_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
2035                                Element('tr_other_more_options_'+ID).style.display = '';
2036
2037                        }
2038                        else{
2039                                this.value = 'show';
2040                                option_more_options.src= '../expressoMail1_2/templates/default/images/down.png';
2041                                Element('tr_other_more_options_'+ID).style.display = 'none';
2042                        }
2043                };
2044        options.appendChild(space1);
2045                options.appendChild(option_more_options);
2046                options.appendChild(option_more);
2047                //FIM OPCAO PARA MAIS ACOES
2048               
2049                //OPCAO PARA RESPONDER
2050        var option_reply = document.createElement("SPAN");
2051        option_reply.id = 'msg_opt_reply_'+ID;
2052        option_reply.className = 'message_options';
2053        option_reply.onclick = function(){new_message('reply_with_history', ID);};
2054        option_reply.innerHTML = get_lang('Reply');
2055        option_reply.onmouseover=function () {this.className='message_options_active';};
2056        option_reply.onmouseout=function () {this.className='message_options'};
2057                option_reply.title = (preferences.use_shortcuts == '1') ? get_lang('Shortcut: %1', 'R') : get_lang('Reply');
2058
2059        options.appendChild(space2);
2060
2061        var option_reply_options = document.createElement('IMG');
2062        option_reply_options.id = 'msg_opt_reply_options_'+ID;
2063        option_reply_options.src = '../expressoMail1_2/templates/default/images/down.png';
2064        option_reply_options.value = 'show';
2065
2066        option_reply_options.onmouseover = function(){
2067                option_reply_options.src= '../expressoMail1_2/templates/default/images/over.png';
2068        };
2069        option_reply_options.onmouseout = function(){
2070                if (this.value == 'show')
2071                {
2072                        option_reply_options.src= '../expressoMail1_2/templates/default/images/down.png';
2073                }
2074                else
2075                {
2076                        option_reply_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
2077                }
2078        };
2079        option_reply_options.onclick = function(){
2080                        verifyOption('tr_other_options_', ID);
2081                if (this.value != 'hide'){
2082                        this.value = 'hide';
2083                        option_reply_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
2084                        Element('tr_other_options_'+ID).style.display = '';
2085
2086                }
2087                else{
2088                        this.value = 'show';
2089                        option_reply_options.src= '../expressoMail1_2/templates/default/images/down.png';
2090                        Element('tr_other_options_'+ID).style.display = 'none';
2091                }
2092        };
2093        options.appendChild(option_reply_options);
2094        options.appendChild(option_reply);
2095                //FIM OPCAO PARA RESPONDER
2096               
2097                //OPCAO PARA ENCAMINHAR
2098                var option_forward = document.createElement("SPAN");
2099                option_forward.id = 'msg_opt_forward_'+ID;
2100                option_forward.className = 'message_options';
2101                option_forward.innerHTML = get_lang('Forward');
2102                option_forward.onclick = function(){new_message('forward', ID);};
2103                option_forward.onmouseover=function () {this.className='message_options_active';};
2104        option_forward.onmouseout=function () {this.className='message_options'};
2105                option_forward.title = (preferences.use_shortcuts == '1') ? get_lang('Shortcut: %1', 'E') : get_lang('Forward');
2106               
2107                var space9 = document.createElement("SPAN");
2108                space9.innerHTML = '&nbsp;|&nbsp;';
2109               
2110                options.appendChild(space9);
2111                options.appendChild(option_forward);
2112                //FIM DA OPCAO PARA ENCAMINHAR
2113               
2114                //OPCAO PARA DELETAR
2115                var option_delete = document.createElement("SPAN");
2116                option_delete.id = 'msg_opt_delete_'+ID;
2117                option_delete.className = 'message_options';
2118                option_delete.onclick = function(){proxy_mensagens.delete_msgs('null','selected','null');};
2119                option_delete.innerHTML = get_lang('Delete');
2120                option_delete.onmouseover=function () {this.className='message_options_active';};
2121                option_delete.onmouseout=function () {this.className='message_options'};
2122                option_delete.title = (preferences.use_shortcuts == '1') ? get_lang('Shortcut: %1', 'Delete') : get_lang('Delete');
2123
2124                var space6 = document.createElement("SPAN");
2125                space6.innerHTML = '&nbsp;|&nbsp;';
2126               
2127                options.appendChild(space6);
2128                options.appendChild(option_delete);
2129                //FIM OPCAO PARA DELETAR
2130
2131        tr.appendChild(td);
2132                //tr.appendChild(option_mark);
2133        tr.appendChild(options);
2134        tr.appendChild(next_previous_msg_td);
2135        tbody_message_options.appendChild(tr);
2136
2137        ////////// OTHER OPTIONS ////////////////////
2138        var tr_other_options = document.createElement("TR");
2139                var tr_other_mark_options = document.createElement("TR");
2140                var tr_other_more_options = document.createElement("TR");
2141               
2142                tr_other_mark_options.id = 'tr_other_mark_options_' + ID;
2143                tr_other_mark_options.style.display = 'none';
2144                tr_other_mark_options.style.backgroundColor = '#205C8E';
2145        tr_other_options.id = 'tr_other_options_' + ID;
2146        tr_other_options.style.display = 'none';
2147                tr_other_options.style.backgroundColor = '#205C8E';
2148                tr_other_more_options.id = 'tr_other_more_options_' + ID;
2149                tr_other_more_options.style.display = 'none';
2150                tr_other_more_options.style.backgroundColor = '#205C8E';               
2151
2152        var td_other_options = document.createElement("TD");
2153                var td_other_mark_options = document.createElement("TD");
2154                var td_other_more_options = document.createElement("TD");
2155               
2156        td_other_options.colSpan = '3';
2157                td_other_mark_options.colSpan = '3';
2158                td_other_more_options.colSpan = '3';
2159
2160        var div_other_options = document.createElement("DIV");
2161                var div_other_mark_options = document.createElement("DIV");
2162                var div_other_more_options = document.createElement("DIV");
2163
2164                //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>, ';
2165                //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>, ';
2166                //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> | ';
2167                var block_user = '<span onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options" onclick ="filter.new_rule(\''+info_msg.from.email+'\');">'+get_lang("Block Sender")+'</span> | ';     
2168                //var option_forward = '<span onclick="new_message(\'forward\',\''+ ID+'\');" onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options">'+get_lang("Forward")+'</span> | ';
2169                var option_move = '<span onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options" onclick=wfolders.makeWindow("'+ID+'","move_to");>'+get_lang("Move")+'</span> | ';
2170                var option_print = '<span onclick="print_all()" onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options">'+get_lang("Print")+'</span> | ';
2171                var option_export = '<span onclick="proxy_mensagens.export_all_messages()" onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options">'+get_lang("Export")+'</span> | ';
2172
2173                option_reply_to_all__title = (preferences.use_shortcuts == '1') ? get_lang('Shortcut: %1', 'T') : '';
2174                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+'\');" title="'+option_reply_to_all__title+'">'+get_lang("Reply to all")+'</span> | ';
2175        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> | ';
2176                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>  | ';
2177
2178                var report_error        = '<span onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options" onclick=reports_window("'+currentTab+'");>'+get_lang("Report error")+'</span> | ';
2179
2180                div_other_more_options.innerHTML += option_move + option_print + option_export + block_user + report_error;
2181               
2182                div_other_options.innerHTML += option_reply_without_history + option_reply_to_all_without_history + option_reply_to_all;
2183        if (use_spam_filter) {
2184                        if(info_msg.msg_folder == 'INBOX'+cyrus_delimiter+'Spam' || (info_msg.msg_folder.match(/^user/) && info_msg.msg_folder.match(/Spam$/))){
2185                                div_other_mark_options.innerHTML += '<span onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options" onclick="nospam('+info_msg.msg_number+',\'null\', \''+info_msg.msg_folder+'\');">'+get_lang("Not Spam")+'</span> | ';
2186        }
2187                        else{
2188                                div_other_mark_options.innerHTML += '<span onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options" onclick="spam(\''+info_msg.msg_folder+'\', '+info_msg.msg_number+',\'null\');">'+get_lang("Is Spam")+'</span> | ';
2189                        }
2190                }
2191                var space5 = document.createElement("SPAN");
2192                space5.innerHTML = '&nbsp;|&nbsp;';
2193       
2194                div_other_mark_options.appendChild(option_mark_as_unseen);
2195                var space4 = document.createElement("SPAN");
2196                space4.innerHTML = '&nbsp;|&nbsp;';
2197                div_other_mark_options.appendChild(space4);
2198                div_other_mark_options.appendChild(option_mark_important);
2199                var space7 = document.createElement("SPAN");
2200                space7.innerHTML = '&nbsp;|&nbsp;';
2201                div_other_mark_options.appendChild(space7);
2202       
2203        td_other_options.align = 'right';
2204        td_other_options.style.paddingTop = '3px';
2205        td_other_options.appendChild(div_other_options);
2206
2207                td_other_mark_options.align = 'right';
2208                td_other_mark_options.style.paddingTop = '3px';
2209                td_other_mark_options.appendChild(div_other_mark_options);
2210               
2211                td_other_more_options.align = 'right';
2212                td_other_more_options.style.paddingTop = '3px';
2213                td_other_more_options.appendChild(div_other_more_options);
2214
2215
2216        tr_other_options.appendChild(td_other_options);
2217        tbody_message_options.appendChild(tr_other_options);
2218               
2219                tr_other_more_options.appendChild(td_other_more_options);
2220                tbody_message_options.appendChild(tr_other_more_options);
2221               
2222                tr_other_mark_options.appendChild(td_other_mark_options);
2223                tbody_message_options.appendChild(tr_other_mark_options);
2224        ////////// END OTHER OPTIONS ////////////////
2225
2226                ////////// BEGIN SIGNATURE //////////////////
2227        if (info_msg.signature && info_msg.signature.length > 0)
2228        {
2229            var tr_signature = document.createElement("TR");
2230            var td_signature = document.createElement("TD");
2231            td_signature.className = 'tr_message_header';
2232            tr_signature.id = 'tr_signature_'+ID;
2233            td_signature.colSpan = "5";
2234            tr_signature.style.display = 'none';
2235            for (i in info_msg.signature)
2236                {
2237                    if(typeof(info_msg.signature[i]) == 'object')
2238                        {
2239                            var aux = '';
2240                            for (ii in info_msg.signature[i])
2241                                {
2242                                    if(info_msg.signature[i][ii].indexOf("###") > -1)
2243                                        {
2244                                         aux += get_lang(info_msg.signature[i][ii].substring(0,info_msg.signature[i][ii].indexOf("###"))) + info_msg.signature[i][ii].substring(info_msg.signature[i][ii].indexOf("###")+3);
2245                                        }
2246                                    else
2247                                        {
2248                                         aux += info_msg.signature[i][ii];
2249                                        }
2250                                }
2251                            td_signature.innerHTML += "<a onclick=\"javascript:alert('" + aux + "')\"><b><font color=\"#0000FF\">" + get_lang("More") + "...</font></b></a>";
2252                            continue;
2253                        }
2254                    if(info_msg.signature[i].indexOf("#@#") > -1)
2255                        {
2256                         td_signature.innerHTML += '<span style=color:red><strong>'+get_lang(info_msg.signature[i].substring(0,info_msg.signature[i].indexOf("#@#")))+'</strong> '+info_msg.signature[i].substring(info_msg.signature[i].indexOf("#@#")+3)+'</span> <br /> ';
2257                        }
2258                            if(info_msg.signature[i].indexOf("###") > -1)
2259                                {
2260                                    td_signature.innerHTML += '<span><strong>'+get_lang(info_msg.signature[i].substring(0,info_msg.signature[i].indexOf("###")))+'</strong> '+info_msg.signature[i].substring(info_msg.signature[i].indexOf("###")+3)+'</span> <br /> ';
2261                                }
2262                }
2263            var signature_status_pos = info_msg.signature[0].indexOf('Message untouched');
2264            td_signature.id = "td_signature_"+ID;
2265            if(signature_status_pos < 0 )
2266                {
2267                    td.innerHTML += '&nbsp;<img style="cursor:pointer" src="templates/'+template+'/images/signed_error.gif" title="'+get_lang("Details")+'">';
2268                    tr_signature.style.display = '';
2269                }
2270            else
2271                {
2272                    td.innerHTML += '&nbsp;<img style="cursor:pointer" src="templates/'+template+'/images/signed_table.gif" title="'+get_lang("Details")+'">';
2273                }
2274            td.onclick = function(){
2275            var _height = Element("div_message_scroll_"+ID).style.height;
2276            _height = parseInt(_height.replace("px",""));
2277            var _offset = 130;
2278            if (this.value == 'more_cert'){
2279                this.value = 'hide_cert';
2280                Element("div_message_scroll_"+ID).style.height = (_height + _offset)+"px";
2281                Element('tr_signature_'+ID).style.display = 'none';
2282                Element('td_signature_'+ID).style.display = 'none';
2283
2284            }
2285            else{
2286                this.value = 'more_cert';
2287                Element("div_message_scroll_"+ID).style.height = (_height - _offset)+"px";
2288                Element('tr_signature_'+ID).style.display = '';
2289                Element('td_signature_'+ID).style.display = '';
2290            }
2291        };
2292
2293            tr_signature.appendChild(td_signature);
2294            tbody_message_options.appendChild(tr_signature);
2295        }
2296        //////////// END SIGNATURE ////////////////
2297
2298        table_message_options.appendChild(tbody_message_options);
2299        td0.appendChild(table_message_options);
2300        tr0.appendChild(td0);
2301        tbody_message.appendChild(tr0);
2302        }
2303        // IF DRAFT
2304        else
2305        {
2306                var options = document.createElement("TD");
2307                //options.width = "1%";
2308                options.setAttribute("noWrap","true");
2309                var option_edit   = ' | <span class="message_options" onclick="new_message(\'edit\',\''+ID+'\');">'+get_lang('Edit')+'</span>';
2310                var option_print = ' | <span class="message_options" onclick="print_msg(\''+info_msg.msg_folder+'\',\''+info_msg.msg_number+'\',\''+ID+'\');">'+get_lang('Print')+'</span>';
2311                var option_hide_more = document.createElement("SPAN");
2312                option_hide_more.className = 'message_options';
2313                options.align = 'right';
2314                option_hide_more.value = 'more_options';
2315                option_hide_more.id = 'option_hide_more_'+ID;
2316                option_hide_more.innerHTML = get_lang('Show details');
2317                option_hide_more.onclick = function(){
2318                        var _height = Element("div_message_scroll_"+ID).style.height;
2319                        _height = parseInt(_height.replace("px",""));
2320                        var _offset = 35;
2321                        if (this.value == 'more_options'){
2322                                this.innerHTML = "<b><u>"+get_lang('Hide details')+"</u></b>";
2323                                this.value = 'hide_options';
2324                                Element("div_message_scroll_"+ID).style.height = (_height - _offset)+"px";
2325                                Element('table_message_others_options_'+ID).style.display = '';
2326                        }
2327                        else{
2328                                this.innerHTML = get_lang('Show details');
2329                                this.value = 'more_options';
2330                                Element("div_message_scroll_"+ID).style.height = (_height + _offset)+"px";
2331                                Element('table_message_others_options_'+ID).style.display = 'none';
2332                        }
2333                };
2334                options.appendChild(option_hide_more);
2335                options_actions = document.createElement('SPAN');
2336                options_actions.innerHTML = option_edit + option_print;
2337                options.appendChild(options_actions);
2338                tr.appendChild(td);
2339                tr.appendChild(options);
2340                tr.appendChild(next_previous_msg_td);
2341                tbody_message_options.appendChild(tr);
2342                table_message_options.appendChild(tbody_message_options);
2343                td0.appendChild(table_message_options);
2344                tr0.appendChild(td0);
2345                tbody_message.appendChild(tr0);
2346
2347                var important_message = document.createElement("INPUT");
2348                important_message.id = "is_important_"+ID;
2349                important_message.name = "is_important";
2350                important_message.type = "HIDDEN";
2351                important_message.value = (info_msg.Importance == "" || info_msg.Importance == "Normal") ? "0": "1";
2352
2353                options.appendChild(important_message);
2354        }
2355        //////////////////////////////////////////////////////////////////////////////////////////////////////
2356        // END options message.
2357        //////////////////////////////////////////////////////////////////////////////////////////////////////
2358
2359        var table_message_others_options = document.createElement("TABLE");
2360        table_message_others_options.id = 'table_message_others_options_' + ID;
2361        table_message_others_options.width = "100%";
2362        table_message_others_options.style.display = 'none';
2363        if(navigator.appName.indexOf('Internet Explorer')>0){
2364                table_message_others_options.className = "table_message_options_ie";
2365        }else{
2366                table_message_others_options.className = "table_message_options";
2367        }
2368       
2369        var tbody_message_others_options = document.createElement("TBODY");
2370        var tr1 = document.createElement("TR");
2371        tr1.className = "tr_message_header";
2372        var td1 = document.createElement("TD");
2373        td1.innerHTML = get_lang("From: ");
2374        td1.appendChild(deny_email(info_msg.from.email));
2375        td1.width = "7%";
2376
2377        if (info_msg.sender){
2378                var tr111 = document.createElement("TR");
2379                tr111.className = "tr_message_header";
2380                var td111 = document.createElement("TD");
2381                td111.innerHTML = get_lang("Sent by")+": ";
2382                td111.appendChild(deny_email(info_msg.sender.email));
2383                td111.setAttribute("noWrap","true");
2384                var sender = document.createElement("TD");
2385                sender.id = "sender_"+ID;
2386                var sender_values = document.createElement("INPUT");
2387                sender_values.id = "sender_values_"+ID;
2388                sender_values.type = "HIDDEN";
2389                sender_values.value = info_msg.sender.full; //Veio do IMAP, sem images nem links.
2390                sender.innerHTML += draw_plugin_cc(ID, info_msg.sender.full);
2391                sender.className = "header_message_field";
2392                tr111.appendChild(td111);
2393                tr111.appendChild(sender);
2394                tr111.appendChild(sender_values);
2395                tbody_message_others_options.appendChild(tr111);
2396        }
2397
2398        var from = document.createElement("TD");
2399        from.id = "from_"+ID;
2400        from.innerHTML = info_msg.from.full;
2401        if (info_msg.Draft != "X"){
2402                from.innerHTML += draw_plugin_cc(ID, info_msg.from);
2403                tbody_message_others_options.appendChild(tr1);
2404        }
2405        from.className = "header_message_field";
2406        var from_values = document.createElement("INPUT");
2407        from_values.id = "from_values_"+ID;
2408        from_values.type = "HIDDEN";
2409        from_values.value = info_msg.from.full; //Veio do IMAP, sem images nem links.
2410
2411        var local_message = document.createElement("INPUT");
2412        local_message.id = "is_local_"+ID;
2413        local_message.name = "is_local";
2414        local_message.type = "HIDDEN";
2415        local_message.value = (info_msg.local_message)?"1":"0";
2416
2417        tr1.appendChild(td1);
2418        tr1.appendChild(from);
2419        tr1.appendChild(from_values);
2420        tr1.appendChild(local_message);
2421
2422        if (info_msg.reply_to){
2423                var tr11 = document.createElement("TR");
2424                tr11.className = "tr_message_header";
2425                var td11 = document.createElement("TD");
2426                td11.innerHTML = get_lang("Reply to")+": ";
2427                td11.setAttribute("noWrap","true");
2428                var reply_to = document.createElement("TD");
2429                reply_to.id = "reply_to_"+ID;
2430
2431                var reply_to_values = document.createElement("INPUT");
2432                reply_to_values.id = "reply_to_values_"+ID;
2433                reply_to_values.type = "HIDDEN";
2434                reply_to_values.value = info_msg.reply_to; //Veio do IMAP, sem images nem links.
2435                reply_to.innerHTML = draw_plugin_cc(ID, info_msg.reply_to);
2436                reply_to.className = "header_message_field";
2437                tr11.appendChild(td11);
2438                tr11.appendChild(reply_to);
2439                tr11.appendChild(reply_to_values);
2440                tbody_message_others_options.appendChild(tr11);
2441        }
2442        //////////////////////////////////////////////////////////////////////////////////////////////////////
2443        var tr2 = document.createElement("TR");
2444        tr2.className = "tr_message_header";
2445        var td2 = document.createElement("TD");
2446        td2.width = "7%";
2447        td2.innerHTML = get_lang("To: ");
2448        var to = document.createElement("TD");
2449        to.id = "to_"+ID;
2450
2451        var to_values = document.createElement("INPUT");
2452        to_values.id = "to_values_"+ID;
2453        to_values.type = "HIDDEN";
2454        to_values.value = info_msg.toaddress2; //Veio do IMAP, sem images nem links.
2455        // Salva a pasta da mensagem
2456        var input_current_folder = document.createElement('input');
2457        input_current_folder.id = "input_folder_"+ID;
2458        input_current_folder.name = "input_folder";
2459        input_current_folder.type = "hidden";
2460        input_current_folder.value = info_msg.msg_folder;
2461        td2.appendChild(input_current_folder);
2462        // fim
2463        // ALEXANDRE LUIZ CORREIA
2464        if(info_msg.toaddress2 != null )
2465        {
2466                toaddress_array[ID] = info_msg.toaddress2.split(",");
2467
2468                if (toaddress_array[ID].length > 1)
2469                {
2470                        to.innerHTML += draw_plugin_cc(ID, toaddress_array[ID][0]);
2471                        var div_toaddress = document.createElement("SPAN");
2472                        div_toaddress.id = "div_toaddress_"+ID;
2473                        div_toaddress.style.display="";
2474                        div_toaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','to');>"+get_lang('more')+"</a>)";
2475                        to.appendChild(div_toaddress);
2476                }
2477                else
2478                {
2479                        toAdd = toaddress_array[ID].toString()
2480                        if( trim(toAdd) != "" ) {
2481                                toAdd = toAdd.replace("<","&lt;").replace(">","&gt;");
2482                        } else {
2483                                toAdd = get_lang("without destination");
2484                        }
2485
2486                        to.innerHTML += draw_plugin_cc(ID,toAdd);
2487                }
2488
2489                to.className = "header_message_field";
2490                tr2.appendChild(td2);
2491                tr2.appendChild(to);
2492                tr2.appendChild(to_values);
2493        }
2494
2495        tbody_message_others_options.appendChild(tr2);
2496
2497        if (info_msg.cc){
2498                var tr3 = document.createElement("TR");
2499                tr3.className = "tr_message_header";
2500                var td3 = document.createElement("TD");
2501                td3.innerHTML = "CC: ";
2502                var cc = document.createElement("TD");
2503                cc.id = "cc_"+ID;
2504
2505                var cc_values = document.createElement("INPUT");
2506                cc_values.id = "cc_values_"+ID;
2507                cc_values.type = "HIDDEN";
2508                cc_values.value = info_msg.cc;
2509
2510                ccaddress_array[ID] = info_msg.cc.split(",");
2511                if (ccaddress_array[ID].length > 1){
2512                        var div_ccaddress = document.createElement("SPAN");
2513                        div_ccaddress.id = "div_ccaddress_"+ID;
2514                        var div_ccaddress_full = document.createElement("SPAN");
2515                        div_ccaddress_full.id = "div_ccaddress_full_"+ID;
2516                        div_ccaddress.style.display="";
2517                        cc.innerHTML = draw_plugin_cc(ID, ccaddress_array[ID][0]);
2518                        div_ccaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','cc');>"+get_lang('more')+"</a>)";
2519                        cc.appendChild(div_ccaddress);
2520                }
2521                else{
2522                        cc.innerHTML = draw_plugin_cc(ID, info_msg.cc);
2523                }
2524                cc.className = "header_message_field";
2525                tr3.appendChild(td3);
2526                tr3.appendChild(cc);
2527                tr3.appendChild(cc_values);
2528                tbody_message_others_options.appendChild(tr3);
2529        }
2530
2531        /*
2532         * @AUTHOR Rodrigo Souza dos Santos
2533         * @MODIFY-DATE 2008/09/11
2534         * @BRIEF Adding routine to create bcc field if there is one.
2535         */
2536        if (info_msg.bcc)
2537        {
2538                var tr3 = document.createElement("tr");
2539                tr3.className = "tr_message_header";
2540                var td3 = document.createElement("td");
2541                td3.innerHTML = get_lang("BCC") + " : ";
2542                var cco = document.createElement("td");
2543                cco.id = "cco_"+ID;
2544
2545                var cco_values = document.createElement("input");
2546                cco_values.id = "cco_values_"+ID;
2547                cco_values.type = "hidden";
2548                cco_values.value = info_msg.bcc;
2549
2550                ccoaddress_array[ID] = info_msg.bcc.split(",");
2551                if (ccoaddress_array[ID].length > 1){
2552                        var div_ccoaddress = document.createElement("SPAN");
2553                        div_ccoaddress.id = "div_ccoaddress_"+ID;
2554                        var div_ccoaddress_full = document.createElement("SPAN");
2555                        div_ccoaddress_full.id = "div_ccoaddress_full_"+ID;
2556                        div_ccoaddress.style.display="";
2557
2558                        //cco.innerHTML = draw_plugin_cc(ID, ccoaddress_array[ID][0]);
2559                        cco.innerHTML = ccoaddress_array[ID][0];
2560                        div_ccoaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','cco');>"+get_lang('more')+"</a>)";
2561                        cco.appendChild(div_ccoaddress);
2562                }
2563                else{
2564                        //cco.innerHTML = draw_plugin_cc(ID, info_msg.cco);
2565                        cco.innerHTML = info_msg.bcc;
2566                }
2567                cco.className = "header_message_field";
2568                tr3.appendChild(td3);
2569                tr3.appendChild(cco);
2570                tr3.appendChild(cco_values);
2571                tbody_message_others_options.appendChild(tr3);
2572        }
2573
2574        var tr4 = document.createElement("TR");
2575        tr4.className = "tr_message_header";
2576        var td4 = document.createElement("TD");
2577        td4.innerHTML = get_lang("Date: ");
2578        var date = document.createElement("TD");
2579        date.id = "date_"+ID;
2580        date.innerHTML = info_msg.fulldate;
2581        var date_day = document.createElement("INPUT");
2582        date_day.id = "date_day_"+ID;
2583        date_day.type = "HIDDEN";
2584        date_day.value = info_msg.msg_day;
2585        var date_hour = document.createElement("INPUT");
2586        date_hour.id = "date_hour_"+ID;
2587        date_hour.type = "HIDDEN";
2588        date_hour.value = info_msg.msg_hour
2589        date.className = "header_message_field";
2590        tr4.appendChild(td4);
2591        tr4.appendChild(date);
2592        tr4.appendChild(date_day);
2593        tr4.appendChild(date_hour);
2594        tbody_message_others_options.appendChild(tr4);
2595
2596        var tr5 = document.createElement("TR");
2597        tr5.className = "tr_message_header";
2598        var td5 = document.createElement("TD");
2599        td5.innerHTML = get_lang("Subject");
2600        var subject = document.createElement("TD");
2601        subject.id = "subject_"+ID;
2602        subject.innerHTML = info_msg.subject;
2603        subject.className = "header_message_field";
2604        if(new_agenda == "True" && $("#expressoCalendarid")[0]){
2605                var new_event_logo = document.createElement("IMG");
2606                new_event_logo.title = "Criar evento a partir deste email";
2607                new_event_logo.alt = "Criar evento a partir deste email";
2608                new_event_logo.src = "./templates/default/images/calendar_add.png";
2609                new_event_logo.style.cursor = "pointer";
2610                new_event_logo.style.marginLeft = "5px";
2611                new_event_logo.onclick = function(){
2612                        DataLayer.dispatchPath = "../prototype/";
2613                        var path = "../prototype/modules/calendar/";
2614                       
2615                        var startEvent = new Date(); 
2616                        if(startEvent.toString('mm') < 30)
2617                                startEvent.add({minutes: (30 - parseInt(startEvent.toString('mm')))});
2618                        else
2619                                startEvent.add({hours: 1, minutes: '-'+startEvent.toString('mm')});
2620                        var endEvent = function(date){
2621                                if(!!User.preferences.defaultCalendar){
2622                                        return  parseInt(date.getTime()) +
2623                                                (       !!Calendar.signatureOf[User.preferences.defaultCalendar].calendar.defaultDuration ? 
2624                                                        (Calendar.signatureOf[User.preferences.defaultCalendar].calendar.defaultDuration * 60000) :
2625                                                        (User.preferences.defaultDuration * 60000)
2626                                                );
2627                                }else
2628                                        return parseInt(date.getTime()) + (User.preferences.defaultDuration * 60000);
2629                        };       
2630                        eventDetails({
2631                                        summary : $("#subject_"+ID).text(),
2632                                        description : $("#body_" + ID).text(),
2633                                        startTime: startEvent.getTime(),
2634                                        endTime: endEvent(startEvent)
2635                        }, true, path);
2636                       
2637                        //TimePicker Não está funcionando corretamente, o motivo ainda é desconhecido.
2638                        /*
2639                        $(".new-event-win").find('input.time').timepicker({
2640                                closeText: 'Ok',
2641                                hourGrid: 4,
2642                                minuteGrid: 10,
2643                                //ampm : ((User.preferences.hourFormat.length > 5) ? true: false),
2644                                timeFormat: "hh:mm tt",
2645                                onSelect: function (selectedDateTime){
2646                                        if(!(User.preferences.hourFormat.length == 5))
2647                                                $(this).val(selectedDateTime.replace(/[\.]/gi, ""));                                                           
2648                                },
2649                                onClose : function (selectedDateTime){
2650                                        if(!(User.preferences.hourFormat.length == 5))
2651                                                $(this).val(selectedDateTime.replace(/[\.]/gi, ""));
2652                                }
2653                        });
2654                        */
2655                       
2656                        var emails = $("#to_values_"+ID).val();
2657                        emails = emails.split(",");
2658                        var blkAddAtendee = UI.dialogs.addEvent.find('#calendar_addevent_details6');
2659                        var onShowToolTip = function(arg0) {
2660                                $('.qtip-active .button.close').button({
2661                                        icons: {primary: "ui-icon-close"},
2662                                        text: false
2663                                });
2664                                $('.qtip-active .button').button()
2665                                .filter('.save').click(function(event, ui) {
2666                                        if (saveContact()) {                                           
2667                                                lastEditAttendeeToolTip.qtip("destroy");
2668                                        } else {
2669                                                return false;
2670                                        }
2671                                }).end()
2672                                .filter('.cancel').click(function(event, ui) {
2673                                        lastEditAttendeeToolTip.qtip("destroy");
2674                                })
2675
2676                                /**
2677                                 * Trata o ENTER no campo da tooltip, equivalente a salvar
2678                                 * o novo convidado.
2679                                 */
2680                                $('.qtip-active input').keydown(function(event) {
2681                                        if (event.keyCode == '13') {                                           
2682                                                if (saveContact()) {                                           
2683                                                        lastEditAttendeeToolTip.qtip("destroy");
2684                                                }
2685
2686                                                lastEditAttendeeToolTip.qtip("destroy");
2687                                                event.preventDefault();
2688                                        }
2689                                })
2690                                .filter('[name="name"]').Watermark("informe o nome do contato").end()
2691                                .filter('[name="mail"]').Watermark("informe o email do contato");
2692                        }
2693                                       
2694                        $.each(emails, function(index, value) {
2695                                var decoded =  Encoder.htmlDecode(value);
2696                                var newAttendeeName = "";
2697                                if(decoded.match(/<([^<]*)>[\s]*$/)){
2698                                        var user = DataLayer.get('user', ["=", "mail", decoded.match(/<([^<]*)>[\s]*$/)[1].toLowerCase()], true);
2699                                        if(!(!!user)){
2700                                                newAttendeeName = decoded.match(/"([^"]*)"/)[1];
2701                                                var newAttendeeEmail = decoded.match(/<([^<]*)>[\s]*$/)[1];
2702                                        }
2703                                }
2704                                else{
2705                                        var user = DataLayer.get('user', ["=", "mail", decoded], true);
2706                                        if(!(!!user)){
2707                                                if(decoded.match(/^[\w!#$%&'*+\/=?^`{|}~-]+(\.[\w!#$%&'*+\/=?^`{|}~-]+)*@(([\w-]+\.)+[A-Za-z]{2,6}|\[\d{1,3}(\.\d{1,3}){3}\])$/))
2708                                                        var newAttendeeEmail = decoded;
2709                                                else{
2710                                                        var newAttendeeEmail = "";
2711                                                        newAttendeeName = decoded;
2712                                                }
2713                                        }
2714                                }
2715                                       
2716                                var isExternal = (!!user && !(!!user.isExternal)) ? 0 : 1;
2717                                var add = false;
2718                                if(user){
2719                                        if(!(blkAddAtendee.find('label.mail[title="' + user[0].mail + '"]').length)){
2720                                                user[0].id =  DataLayer.put('participant', {user: user[0].id, isExternal: isExternal});
2721                                                blkAddAtendee.find('dd.attendee-list ul.attendee-list').append(
2722                                                        DataLayer.render(path+'templates/participants_add_itemlist.ejs', user)
2723                                                )
2724                                                .find('.button.close').addClass('small').button({text:false, icons:{primary:'ui-icon-close'}}).click(function() {
2725                                                        DataLayer.remove('participant', $(this).parent().find('[type=checkbox]').val());
2726                                                        $(this).parent().remove();
2727                                                }).end()
2728                                                .scrollTo('max');
2729                                                add = true;
2730                                        }
2731                                }else{
2732                                        userId = DataLayer.put('user', {name: newAttendeeName, mail: newAttendeeEmail, isExternal: isExternal});
2733                                        newAttendeeId = DataLayer.put('participant', {user: userId, isExternal: isExternal});
2734                                       
2735                                        blkAddAtendee.find('dd.attendee-list ul.attendee-list').append(
2736                                                DataLayer.render(path+'templates/participants_add_itemlist.ejs', [{id:newAttendeeId, name: newAttendeeName, mail: newAttendeeEmail, isExternal: 1}])
2737                                        ).find('.button.close').addClass('small').button({text:false, icons:{primary:'ui-icon-close'}}).click(function() {
2738                                                DataLayer.remove('participant', $(this).parent().find('[type=checkbox]').val());
2739                                                $(this).parent().remove();
2740                                        }).end()
2741                                        .scrollTo('max');
2742                                        add = true;
2743                                }
2744                                if(add){
2745                                        lastEditAttendeeToolTip = blkAddAtendee.find('dd.attendee-list li:last');
2746                                        lastEditAttendeeToolTip.qtip({
2747                                                show: {ready: false, solo: true, when: {event: 'click'}},
2748                                                hide: false,
2749                                                content: {
2750                                                        text: $('<div></div>').html( DataLayer.render( path+'templates/attendee_quick_edit.ejs', {attendee:{name:( (!!user ? (!!user[0] ? (!!user[0].name ? user[0].name : newAttendeeName): newAttendeeName) : newAttendeeName)), mail:(!!user ? (!!user[0] ? (!!user[0].mail ? user[0].mail : newAttendeeEmail): newAttendeeEmail) : newAttendeeEmail)}} ) ),
2751                                                        title: {
2752                                                                text:'Detalhes do participante',
2753                                                                button: '<a class="button close" href="#">close</a>'
2754                                                        }
2755                                                },
2756                                                style: {name: 'blue', tip: {corner: 'leftMiddle'}, border: {width: 4, radius: 8}, width: {min: 230, max:230}},
2757                                                position: {
2758                                                        corner: {
2759                                                                target: 'rightMiddle',
2760                                                                tooltip: 'leftMiddle'
2761                                                        },
2762                                                        adjust: {x:0, y:0}
2763                                                }
2764                                        });
2765                                        lastEditAttendeeToolTip.qtip("api").onShow = onShowToolTip;
2766                                }
2767                        });                                             
2768                }
2769                subject.appendChild(new_event_logo);
2770        }
2771        tr5.appendChild(td5);
2772        tr5.appendChild(subject);
2773        tbody_message_others_options.appendChild(tr5);
2774        //k!
2775        if ( info_msg.attachments && info_msg.attachments.length > 0 )
2776        {
2777                //Código no padrão expresso 2.2
2778        var tr6 = document.createElement("TR");
2779                tr6.className = "tr_message_header";
2780                var td6 = document.createElement("TD");
2781                td6.innerHTML = get_lang("Attachments: ");
2782               
2783               
2784                var attachments = document.createElement("TD");
2785                td6.valign = "top";
2786                attachments.align = 'left';
2787                if(info_msg.attachments.length >= 1){
2788                        if(info_msg.attachments.length > 1) {
2789                                var link_attachment      = document.createElement("A");
2790                                 if(proxy_mensagens.is_local_folder(current_folder))
2791                                        link_attachment.setAttribute("href", "javascript:expresso_local_messages.download_all_local_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
2792                                else
2793                                        link_attachment.setAttribute("href", "javascript:download_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
2794                                link_attachment.innerHTML = " "+info_msg.attachments.length+' '+get_lang('files')+' :: '+get_lang('Download all atachments');
2795                    attachments.appendChild(link_attachment);
2796                        }
2797                        if(parseInt(preferences.remove_attachments_function))
2798                        {
2799                    attachments.appendChild(document.createTextNode('  '));
2800                    var del_attachments = document.createElement("A");
2801                    del_attachments.setAttribute("href", "javascript:remove_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
2802                    del_attachments.innerHTML = get_lang('remove all attachments');
2803                    attachments.appendChild(del_attachments);
2804                        }
2805                attachments.appendChild(document.createElement('BR'));
2806        }
2807                attachments.id = "attachments_" + ID;
2808                for (var i=0; i<info_msg.attachments.length; i++)
2809                {
2810                        var link_attachment = document.createElement("a");
2811                        link_attachment.setAttribute("href", proxy_mensagens.link_anexo(info_msg,i));
2812                        link_attachment.innerHTML = url_decode(info_msg.attachments[i].name) + " ("+borkb(info_msg.attachments[i].fsize)+")";
2813                        //link_attachment.innerHTML += " ("+borkb(info_msg.attachments[i].fsize)+")";
2814
2815                        //k trocar por match???
2816                        if((url_decode(info_msg.attachments[i].name).indexOf(".ics")!=-1) || (url_decode(info_msg.attachments[i].name).indexOf(".vcard")!=-1))
2817                        {
2818                                //Link para importar calendário
2819                                var link_import_attachment = new Image();
2820                                link_import_attachment.src = "templates/"+template+"/images/new.png";
2821                                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+"'); return false;");
2822                                link_import_attachment.title = get_lang("Import to calendar");
2823                                link_import_attachment.align = "top";
2824                                link_import_attachment.style.marginLeft = "5px";
2825                                link_import_attachment.style.cursor = "pointer";
2826                                link_attachment.appendChild(link_import_attachment);
2827                        }
2828
2829                        if((url_decode(info_msg.attachments[i].name).indexOf(".eml") != -1))
2830                        {
2831                                //Link para importar calendário
2832                                var link_open_msg = new Image();
2833                                link_open_msg.src = "templates/"+template+"/images/email.png";
2834                                //link_open_msg.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+"'); return false;");
2835                                link_open_msg.setAttribute("onclick","javascript:open_msg_part('"+info_msg.msg_folder+"&msg_number="+info_msg.msg_number+"&msg_part="+info_msg.attachments[i].pid+"'); return false;");
2836                                link_open_msg.title = get_lang("Open message");
2837                                link_open_msg.align = "top";
2838                                link_open_msg.style.marginLeft = "5px";
2839                                link_open_msg.style.cursor = "pointer";
2840                                link_attachment.appendChild(link_open_msg);
2841                }
2842               
2843            link_attachment.innerHTML += '<br/>';
2844            attachments.appendChild(link_attachment);
2845            }
2846                tr6.appendChild(td6);
2847            tr6.appendChild(attachments);
2848                tbody_message_others_options.appendChild(tr6);
2849        }
2850
2851        //k!!
2852        var div = document.createElement("DIV");
2853        div.id = "div_message_scroll_"+ID;
2854        div.style.background = 'WHITE';
2855        div.style.overflow = "auto";
2856        table_message_others_options.appendChild(tbody_message_others_options);
2857        var tr = document.createElement("TR");
2858                tr.className = "tr_message_header";
2859        var td = document.createElement("TD");
2860                td.colspan = '2';
2861        td.style.fontSize = '10pt';
2862        td.style.fontFamily = 'Arial,Verdana';
2863        td.style.verticalAlign = 'top';
2864        td.style.height = '100%';
2865        div.appendChild(table_message_others_options);
2866        var imgTag = info_msg.body.match(/(<img[^>]*src[^>=]*=['"]?[^'">]*["']?[^>]*>)|(<[^>]*(style[^=>]*=['"][^>]*background(-image)?:[^:;>]*url\()[^>]*>)/gi);
2867        var newBody = info_msg.body;
2868        if(!info_msg.showImg && imgTag)
2869        {
2870                var domains = '';
2871                var blocked = false;
2872                var forbidden = true;
2873
2874                if (preferences.notification_domains != null && typeof(preferences.notification_domains) != 'undefined')
2875                {
2876                        domains = preferences.notification_domains.split(',');
2877                        for(var j = 0; j < imgTag.length; j++)
2878                        {
2879                                for (var i = 0; i < domains.length; i++)
2880                                {
2881                                        if (imgTag[j].match(/cid:([\w\d]){5,}/) || imgTag[j].match(/src=\"\.\/inc\/get_archive\.php/g))
2882                                        {
2883                                                forbidden = false;
2884                                                continue;
2885                                        }
2886                                        imgSource = imgTag[j].match(/=['"](http:\/\/)+[^'"\/]*/);
2887                                        if (imgSource && imgSource.toString().substr(5).match(domains[i]))
2888                                                forbidden = false;
2889                                }
2890                                if (forbidden)
2891                                {
2892                                        newBody = newBody.replace(imgTag[j],"<img src='templates/"+template+"/images/forbidden.png'>");
2893                                        blocked=true;
2894                                }
2895                        }
2896                        if (blocked)
2897                        {
2898                                var showImgLink = document.createElement('DIV');
2899                                showImgLink.id="show_img_link_"+ID;
2900                                showImgLink.onclick = function(){show_msg_img(info_msg.msg_number,info_msg.msg_folder)};
2901                                showImgLink.className="show_img_link";
2902                                showImgLink.innerHTML = get_lang("Show images from")+": "+info_msg.from.email;
2903                                td.appendChild(showImgLink);
2904                        }
2905                }
2906        }
2907        td.appendChild(div);
2908        tr.appendChild(td)
2909        tbody_message.appendChild(tr);
2910
2911
2912        //////////////////////////////////////////////////////////////////////////////////////////////////////
2913        //Make the body message.
2914        ///////////////////////////////////////////////////////////////////////////////////////////////////////
2915        var tr = document.createElement("TR");
2916        tr.className = "tr_message_body";
2917        var td = document.createElement("TD");
2918        //td.setAttribute("colSpan","2");
2919       
2920        //Comentado pois estes replaces e a tentativa de remover as tags <span> vazias faz com que seja
2921        //eliminado os estilos aplicados no corpo do texto quando utilizado o Firefox.
2922        //newBody = newBody.replace("<body","<span");
2923        //newBody = newBody.replace("<BODY","<span");
2924        //while ( ( /<span[^>]*><span[^>]*>/ig ).test( newBody ) )
2925        //      newBody = newBody.replace( /(<span[^>]*>)<span[^>]*>/ig, '$1' );
2926
2927        var _body = document.createElement( 'div' );
2928        _body.id = 'body_' + ID;
2929        _body.innerHTML = newBody;
2930        //_body.style.fontSize = '16px';
2931
2932        var _elements = _body.getElementsByTagName( '*' );
2933        for( var i = 0; i < _elements.length; i++ )
2934                if ( _elements[ i ].attributes && _elements[ i ].attributes.getNamedItem( 'id' ) )
2935                        _elements[ i ].attributes.removeNamedItem( 'id' );     
2936       
2937        div.appendChild( _body );
2938       
2939         //window.setTimeout(function() { $("#div_message_scroll_"+ID).focus() },250);
2940
2941        function mailto( link )
2942        {
2943                var mail = link.href.substr( 7 );
2944                link.onclick = function( )
2945                {
2946                        new_message_to( mail );
2947                        return false;
2948                };
2949        }
2950        var links = div.getElementsByTagName( 'a' );
2951        for ( var i = 0; i < links.length; i++ ){
2952                try{
2953                        if ( links.item( i ).href.indexOf( 'mailto:' ) === 0 ){
2954                                mailto( links.item( i ) );
2955                        }
2956                        else{
2957                                var anchor_pattern = "http://"+location.host+location.pathname+"#";
2958
2959                                if ( ( links.item( i ).href.indexOf( 'javascript:' ) !== 0 ) &&
2960                                        (links.item( i ).href.indexOf(anchor_pattern) !== 0) ) //se não for âncora
2961                                                links.item( i ).setAttribute( 'target', '_blank' );
2962                        }
2963                }catch(e){
2964                }
2965        }
2966        //////////////////////////////////////////////////////////////////////////////////////////////////////
2967        //Make the thumbs of the message.
2968        //////////////////////////////////////////////////////////////////////////////////////////////////////
2969        //k
2970       
2971        if ((info_msg.thumbs)&&(info_msg.thumbs.length > 0)){
2972                var thumbs = jQuery.parseJSON(info_msg.thumbs);
2973                var div_thumbs = document.createElement("div");
2974               
2975                div_thumbs.setAttribute("class", "expressomail-thumbs");
2976                div_thumbs.setAttribute("className", "expressomail-thumbs"); //for IE
2977               
2978                var div_thumbs_lbl = document.createElement("DIV");
2979                div_thumbs_lbl.setAttribute("class", "expressomail-thumbs-label");
2980                div_thumbs_lbl.setAttribute("className", "expressomail-thumbs-label"); //for IE
2981               
2982                var div_thumbs_lbl_sp = document.createElement("SPAN");
2983                div_thumbs_lbl_sp.setAttribute("class", "message_options");
2984                div_thumbs_lbl_sp.setAttribute("className", "message_options"); //for IE
2985                var div_thumbs_lbl_st = document.createElement("STRONG");
2986                div_thumbs_lbl_st.innerHTML = info_msg.attachments.length+" "+get_lang("attachment")+(info_msg.attachments.length > 1 ? "s" : "")+" "+get_lang("in this message");
2987                var div_thumbs_lbl_a  = document.createElement("A");
2988
2989                if(info_msg.thumbs.length > 1){
2990                         if(proxy_mensagens.is_local_folder(current_folder))
2991                                div_thumbs_lbl_a.setAttribute("href", "javascript:expresso_local_messages.download_all_local_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
2992                        else
2993                                div_thumbs_lbl_a.setAttribute("href", "javascript:download_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
2994                        div_thumbs_lbl_a.innerHTML = get_lang('Download all atachments');
2995                } else {
2996                        div_thumbs_lbl_a.setAttribute("style", "display:none; visibility:hidden;");
2997                }
2998
2999                div_thumbs_lbl_sp.appendChild(div_thumbs_lbl_st);
3000                div_thumbs_lbl_sp.appendChild(document.createTextNode(' :: '));
3001                div_thumbs_lbl_sp.appendChild(div_thumbs_lbl_a);
3002                div_thumbs_lbl.appendChild(div_thumbs_lbl_sp);
3003
3004                var div_thumbs_lbl_sp2   = document.createElement("SPAN");
3005                div_thumbs_lbl_sp2.setAttribute("class", "message_tips");
3006                div_thumbs_lbl_sp2.setAttribute("className", "message_tips"); //for IE
3007                div_thumbs_lbl_sp2.innerHTML = get_lang("<strong>Tip:</strong> <span>For faster save, click over the image with <em>right button</em>.</span>");
3008
3009                var ul_thumbs_list = document.createElement("UL");
3010                ul_thumbs_list.setAttribute("class", "expressomail-thumbs-list");
3011                ul_thumbs_list.setAttribute("className", "expressomail-thumbs-list"); //for IE
3012
3013                        var msg = info_msg.msg_number;
3014                        var fdr = info_msg.msg_folder;
3015                                        var i = 0;
3016                                //verifica se está no novo padrão de montagem das mensagens ou no antigo, necessário
3017                                //para exibir as imagens no arquivamento local arquivamento local.
3018                                if(thumbs){
3019                        jQuery.each(thumbs, function(i, thumb) {
3020                                                        if(fdr.indexOf("local_") >= 0){
3021                                                                var href = info_msg.array_attach[i].url + '&image=true';
3022                                                                var src  = info_msg.array_attach[i].url+ '&image=thumbnail';
3023                                                                i++;
3024                                                        }else{
3025                                                                var href = './inc/get_archive.php?msgFolder=' + fdr + '&msgNumber=' + msg + '&indexPart=' + thumb.pid + '&image=true';
3026                                                                //var href = thumb.url;
3027                                                                var src  = 'inc/get_archive.php?msgFolder=' + fdr + '&msgNumber=' + msg + '&indexPart=' + thumb.pid + '&image=thumbnail';
3028                                }
3029                                var msgid= fdr+";;"+msg+";;"+i+";;"+thumb.pid+";;"+thumb.encoding;
3030                                var image_info = '{"folder":"'+fdr+'","message":"'+msg+'","thumbIndex":"'+i+'","pid":"'+thumb.pid+'","encoding":"'+thumb.encoding+'","type":"'+thumb.type+'"}';
3031                                 
3032                                var image= '<img id="' + msgid + '" title="' + 
3033                                                                get_lang('Click here do view (+)') + '" src="' + src + '" style="width:auto;height:100%;" />';
3034                                                         
3035                                var content = '<a title="'+thumb.name+ '" rel="thumbs'+ID+'" class="expressomail-thumbs-link" onMouseDown="save_image(event,this,\'' +thumb.type+'\')" href="'+href+'" onclick="window.open(\''+href+'\',\'mywindow\',\'width=700,height=600,scrollbars=yes\');return false;">'+image+'</a>';
3036                                content += '<input id="thumb_'+ID+'_'+i+'" type="hidden" value="' +escape(image_info) +'" />';
3037                                jQuery(ul_thumbs_list).append('<li>'+content+'</li>');
3038                                 
3039                        });   
3040               
3041                div_thumbs.appendChild(div_thumbs_lbl);
3042                div_thumbs.appendChild(div_thumbs_lbl_sp2);
3043                div_thumbs.appendChild(ul_thumbs_list);
3044               
3045                                }else{
3046                                        div_thumbs.appendChild(div_thumbs_lbl);
3047                                        div_thumbs.appendChild(div_thumbs_lbl_sp2);
3048                                        div_thumbs.innerHTML = div_thumbs.innerHTML + info_msg.thumbs;
3049                                       
3050                                       
3051                                }
3052               
3053                div.appendChild(div_thumbs);
3054        }
3055        //k!!
3056        //////////////////////////////////////////////////////////////////////////////////////////////////////
3057        table_message.appendChild(tbody_message);
3058        content.appendChild(table_message);
3059        resizeWindow();
3060        var msg_number = document.createElement('INPUT');
3061        msg_number.id = "msg_number_" + ID;
3062        msg_number.type = "hidden";
3063        msg_number.value = info_msg.msg_number;
3064        content.appendChild(msg_number);
3065        //////////////////////////////////////////////////////////////////////////////////////////////////////
3066
3067        //Exibe o cabecalho da mensagem totalmente aberto caso esteja setado nas preferencias do usuario
3068        if (preferences.show_head_msg_full == 1)
3069        {
3070                option_hide_more.onclick();
3071                if (Element('div_toaddress_'+ID) != null)
3072                        show_div_address_full(ID,'to');
3073                if (Element('div_ccaddress_'+ID) != null)
3074                        show_div_address_full(ID,'cc');
3075        }
3076
3077        /*
3078         * TODO: implementar o controle como preferência do usuário
3079         *
3080         */
3081        var jcarousel = false;
3082        if (jcarousel) {
3083                //carousel
3084                jQuery(document).ready(function() {
3085                        jQuery('.expressomail-thumbs-list').attr('id', 'expressomail-thumbs-list'+ID)
3086                    .addClass('jcarousel-skin-default').jcarousel();
3087
3088                        jQuery('.expressomail-thumbs-link img').attr('style', '');
3089               
3090                //fancybox
3091                        jQuery(".expressomail-thumbs-list li a").attr('onclick', 'return true;');
3092                        jQuery(".expressomail-thumbs-list li a").fancybox({
3093                                'hideOnContentClick': true,
3094                                        'type': 'image',
3095                                        'titlePosition': 'over',                                         
3096                                        'titleFormat' : function(name, currentArray, currentIndex, currentOpts) {                       
3097                                                        var image_info = $('#thumb_'+ID+'_'+currentIndex).val();
3098
3099                                                        return '<div id="fancybox-title" class="fancybox-title-over" style="width: 100%; display: block;">' +
3100                                                                                '<div id="fancybox-title-over">' +
3101                                                                                        '<a title="Anterior" onclick="javascript:$.fancybox.prev();" style="float:left;">' +
3102                                                                                                        '<img src="./templates/'+template+'/images/left_arrow_white.png" width="30" height="30" />' +
3103                                                                                        '</a>'+
3104                                                                                        '<a title="Baixar imagem" onclick="javascript:save_image2(\''+image_info+'\');" style="padding:0 5px;">' +
3105                                                                                                        '<img src="./templates/'+template+'/images/image_down.png" width="22" height="22" />' +
3106                                                                                        '</a>'+
3107                                                                                        '<a title="Baixar todas de uma vez" onclick="javascript:download_all_attachments(\''+info_msg.msg_folder+"','"+info_msg.msg_number+'\')" style="padding:0 5px;">'+
3108                                                                                                        '<img src="./templates/'+template+'/images/package_down.png" width="26" height="26" />' +
3109                                                                                        '</a>'+
3110                                                                                        '<span style="margin-left:5px; margin-top:7px; position:absolute;">'+name+'</span>'+
3111                                                                                        '<a title="Próxima" onclick="javascript:$.fancybox.next();" style="float:right;">' +
3112                                                                                                '<img src="./templates/'+template+'/images/right_arrow_white.png" width="30" height="30" />' +
3113                                                                                        '</a>' +
3114                                                                                '</div>' +
3115                                                                        '</div>';
3116                                        }
3117                        });
3118                });
3119        }
3120       
3121    resizeWindow();
3122        if ( is_webkit){ //Corrige o bug de foco no Chrome
3123               var ev = document.createEvent('MouseEvents');
3124           ev.initEvent(
3125                                'click'   
3126                                ,false
3127                                ,true
3128                        );
3129               var divScroll = Element('div_message_scroll_'+ID);
3130                        if (divScroll) {
3131                                divScroll.setAttribute('tabindex','-1');
3132                                divScroll.onclick = function() {setTimeout(function(){$("#div_message_scroll_"+ID).focus();},0);};
3133                                divScroll.dispatchEvent(ev);
3134                        }
3135                }
3136                else  $("#div_message_scroll_"+ID).focus();
3137}
3138 
3139function changeLinkState(el,state){
3140        el.innerHTML = get_lang(state);
3141        switch (state){
3142                case 'important':
3143                        {
3144                                el.onclick = function(){changeLinkState(el,'normal');proxy_mensagens.proxy_set_message_flag(currentTab.substr(0,currentTab.indexOf("_r")),'flagged');write_msg(get_lang('Message marked as ')+get_lang("Important"))}
3145                                break;
3146                        }
3147                case 'normal':
3148                        {
3149                                el.onclick = function(){
3150                                        var _this = this;
3151                                        proxy_mensagens.proxy_set_message_flag(currentTab.substr(0,currentTab.indexOf("_r")),'unflagged', function(success){
3152                                                if (success) {
3153                                                        changeLinkState(_this, 'important');
3154                                                        write_msg(get_lang('Message marked as ') + get_lang("Normal"));
3155                                                }
3156                                        } );
3157                                }
3158                                break;
3159                        }
3160                case 'unseen':
3161                        {
3162                                el.onclick = function(){changeLinkState(el,'seen');proxy_mensagens.proxy_set_message_flag(currentTab.substr(0,currentTab.indexOf("_r")),'unseen');write_msg(get_lang('Message marked as ')+get_lang("unseen"))}
3163                                break;
3164
3165                        }
3166                case 'seen':
3167                        {
3168                                el.onclick = function(){changeLinkState(el,'unseen');proxy_mensagens.proxy_set_message_flag(currentTab.substr(0,currentTab.indexOf("_r")),'seen');write_msg(get_lang('Message marked as ')+get_lang("seen"))}
3169                                break;
3170
3171                        }
3172                default:
3173                        {
3174                                break;
3175                        }
3176        }
3177}
3178
3179function draw_new_message(border_ID){
3180        connector.loadScript("color_palette");
3181        connector.loadScript('wfolders');
3182        if(typeof(RichTextEditor) == 'undefined' || typeof(ColorPalette) == 'undefined' || typeof(wfolders) == 'undefined')
3183                return false;
3184
3185        var ID = create_border("",border_ID);
3186        if (ID == 0)
3187                return 0;
3188        else if(ID == 'maximo')
3189                return 'maximo';
3190        hold_session = true;
3191
3192        var footer_menu = Element("footer_menu");
3193        if (footer_menu) {
3194                footer_menu.style.display = 'none';
3195        }
3196/////////////////////////////////////////////////////////////////////////////////////////////////////////
3197        var form = document.createElement("FORM");
3198        form.name = "form_message_"+ID;
3199        form.method = "POST";
3200        form.onsubmit = function(){return false;}
3201        if(!is_ie)
3202                form.enctype="multipart/form-data";
3203        else
3204                form.encoding="multipart/form-data";
3205/////////////////////////////////////////////////////////////////////////////////////////////////////////
3206        //ConstructMenuNewMessage(ID);
3207////////////////////////////////////////////////////////////////////////////////////////////////////////
3208        var content = Element('content_id_' + ID);
3209        var table_message = document.createElement("TABLE");
3210        table_message.width = "100%";
3211        var tbody_message = document.createElement("TBODY");
3212        var tr0 = document.createElement("TR");
3213        tr0.className = "tr_message_header";
3214        var td0 = document.createElement("TD");
3215        td0.colSpan = '2';
3216
3217        var table_menu_new_message = document.createElement("TABLE");
3218        table_menu_new_message.width = "100%";
3219        table_menu_new_message.border = '0';
3220        table_menu_new_message.className = 'table_message';
3221        var tbody_menu_new_message = document.createElement("TBODY");
3222        var tr_menu_new_message = document.createElement("TR");
3223        tr_menu_new_message.width = "100%";
3224        var td_menu_new_message = document.createElement("TD");
3225        //td_menu_new_message.setAttribute("noWrap","true");
3226        td_menu_new_message.className = "new-message-menu";
3227        td_menu_new_message.width = "100%";
3228        if ((preferences.save_in_folder == '-1') || (preferences.save_in_folder == '')){
3229                var option_send = '<button title="Enviar Email" id="send_button_'+ID+'" class="header-button button small" onclick=send_message("'+ID+'","null","null");>'+get_lang("Send")+'</button>';
3230                //var option_send   = '<input type="button" id="send_button_'+ID+'" class="em_button_like_span" tabindex="1" value="'+get_lang("Send and not file")+'" onclick=send_message("'+ID+'","null","null");>' + ' | ';
3231                if(!expresso_offline)
3232                        var option_send_and_file= '<button id="send_and_custom_save_'+ID+'" class="header-button button small" onclick=wfolders.makeWindow("'+ID+'","send_and_file");>'+get_lang("Send and file")+'</button>';
3233                else
3234                        var option_send_and_file='';
3235        }
3236        else{
3237                var option_send = '<button title="'+get_lang("Send Mail")+'" id="send_button_'+ID+'" class="header-button button small" onclick="send_message(\''+ID+'\',\''+preferences.save_in_folder+'\',\'null\');">'+get_lang("Send")+'</button>';
3238                //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\');">' + ' | ';
3239                var option_send_and_file='';
3240                wfolders.alert = true;
3241        }
3242//      var option_save_as              = '<span class="message_options" onclick=wfolders.makeWindow("'+ID+'","save");>'+get_lang("Save as")+'</span> | ';
3243       
3244        if (!expresso_offline) {
3245                var option_save = '<button title="'+get_lang("Save Mail")+'" id="save_message_options_'+ID+'" class="header-button button small" onclick="save_msg('+ID+');">'+get_lang("Save")+'</button>';
3246                //var option_search = '<button class="header-button" onclick=openListUsers("'+ID+'");>'+get_lang("Search")+'</button>';
3247        }
3248        else {
3249                var option_save = '<input type="hidden" id="save_message_options_'+ID+'">';
3250                //var option_search = '';
3251        }
3252        if (parseInt(preferences.use_important_flag))
3253                var option_important = '<button title="'+get_lang("Important message")+'" name="important_message_'+ID+'" id="important_message_options_'+ID+'" class="send_option header-button button small">&nbsp;</button>';
3254               
3255        var option_confLeitura = '<button title="'+get_lang("Return receipt")+'" name="return_receipt_'+ID+'" id="conf_leitura_message_options_'+ID+'" class="send_option header-button button small">&nbsp;</button>';
3256       
3257        td_menu_new_message.innerHTML = option_send +  option_save + option_send_and_file + (option_important ? option_important: "") +option_confLeitura; //+ option_search;
3258       
3259        td_menu_another_adress = document.createElement("TD");
3260        td_menu_another_adress.id = "another_adress_"+ID;
3261        //td_menu_another_adress.style.position = "absolute";
3262        td_menu_another_adress.style.width = "1%";
3263        td_menu_another_adress.setAttribute("noWrap","true");
3264        $(td_menu_another_adress).css("text-align","right");
3265        //td_menu_new_message.setAttribute("noWrap","true");
3266       
3267        tr_menu_new_message.appendChild(td_menu_new_message);
3268        tr_menu_new_message.appendChild(td_menu_another_adress);
3269       
3270       
3271        tbody_menu_new_message.appendChild(tr_menu_new_message);
3272        table_menu_new_message.appendChild(tbody_menu_new_message);
3273
3274        content.appendChild(table_menu_new_message);
3275        tr0.appendChild(td0);
3276        tbody_message.appendChild(tr0);
3277////////////////////////////////////////////////////////////////////////////////////////////////////////
3278        var tr1_1 = document.createElement("TR");
3279        tr1_1.style.display = 'none';
3280        var td1_1 = document.createElement("TD");
3281        td1_1.innerHTML = get_lang("From")+":";
3282        //td1_1.setAttribute("noWrap","noWrap");
3283        //td1_1.style.width = "1%";
3284       
3285        var td_from = document.createElement("TD");
3286        //td_from.setAttribute("noWrap","noWrap");
3287        td_from.style.width = "100%";
3288        //td_from.colSpan = "2";
3289        var sel_from = document.createElement('SELECT');
3290        sel_from.id = "from_"+ID;
3291        sel_from.name = "input_from";
3292        sel_from.style.width = "100%";
3293        //sel_from.setAttribute("wrap","soft");
3294        td_from.appendChild(sel_from);
3295        tr1_1.appendChild(td1_1);
3296        tr1_1.appendChild(td_from);
3297        tbody_message.appendChild(tr1_1);
3298///////////////////////////////////////////////////////////////////////
3299        var tr1_2 = document.createElement("TR");
3300        tr1_2.id = "tr_replyto_"+ID;
3301        var td1_2 = document.createElement("TD");
3302        tr1_2.style.display = 'none';
3303    td1_2.innerHTML = get_lang("Reply to")+":";
3304        //td1_2.setAttribute("noWrap","true");
3305        //td1_2.style.width = "1%";
3306
3307        var td_replyto = document.createElement("TD");
3308    //td_replyto.setAttribute("noWrap","true");
3309        td_replyto.style.width = "100%";
3310        //td_replyto.colSpan = "2";
3311        var input_replyto = document.createElement('INPUT');
3312        input_replyto.id = "replyto_"+ID;
3313        input_replyto.name = "input_replyto";
3314        input_replyto.setAttribute("tabIndex","1");
3315    input_replyto.style.width = "100%";
3316        //input_replyto.setAttribute("wrap","soft");
3317    input_replyto.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer));search_contacts('onfocus', this.id);};
3318        input_replyto.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
3319
3320        if (!is_ie)
3321        {
3322        input_replyto.rows = 2;
3323            input_replyto.onkeydown = function (e)
3324                {
3325            if ((e.keyCode) == 120) //F9
3326                        {
3327                emQuickSearch(input_replyto.value, 'replyto', ID);
3328                        }
3329                        else
3330                        {
3331                                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
3332                                {
3333                                        e.preventDefault();
3334                    search_contacts(e.keyCode,this.id);
3335                }
3336                        }
3337        }
3338        input_replyto.onkeyup = function (e)
3339        {
3340                        if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
3341                        {
3342                                search_contacts(e.keyCode,this.id);
3343            }
3344        }
3345        }
3346        else
3347    {
3348                input_replyto.rows = 3;
3349        input_replyto.onkeyup = function (e)
3350                {
3351                        if ((window.event.keyCode) == 120) //F9
3352                        {
3353                                        emQuickSearch(input_replyto.value, 'replyto', ID);
3354                        }
3355                        else
3356                        {
3357                search_contacts(window.event.keyCode,this.id);
3358            }
3359                }
3360        }
3361        td_replyto.appendChild(input_replyto);
3362        tr1_2.appendChild(td1_2);
3363        tr1_2.appendChild(td_replyto);
3364        tbody_message.appendChild(tr1_2);
3365////////////////////////////////////////////////////////////////////////////////////////////////////////
3366        var tr1 = document.createElement("TR");
3367        var td1 = document.createElement("TD");
3368        td1.innerHTML = '<button title="'+get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.')+'" id="to_button_'+ID+'" name="to" class="button small adress_button">'+get_lang("To")+':</button>';
3369        //td1.setAttribute("noWrap","true");
3370        td1.style.width = "70px";
3371
3372        var td_to = document.createElement("TD");
3373        //td_to.setAttribute("noWrap","true");
3374        td_to.style.width = "100%";
3375
3376        var input_to = document.createElement('TEXTAREA');
3377        input_to.id = "to_"+ID;
3378        input_to.name = "input_to";
3379        input_to.setAttribute("tabIndex","1");
3380        input_to.style.width = "100%";
3381        input_to.style.padding = "1px";
3382        input_to.className = "mail_fields";
3383        //input_to.style.wrap="off";
3384        //input_to.setAttribute("wrap","off");
3385        input_to.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer));search_contacts('onfocus', this.id);};
3386        input_to.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
3387        if (!is_ie)
3388        {
3389                input_to.rows = 1;
3390                input_to.onkeydown = function (e)
3391                {
3392                        if ((e.keyCode) == 120) //F9
3393                        {
3394                                emQuickSearch(input_to.value, 'to', ID);
3395                        }
3396                        else
3397                        {
3398                                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
3399                                {
3400                                        e.preventDefault();
3401                                        search_contacts(e.keyCode,this.id);
3402                                }
3403                        }
3404                }
3405                input_to.onkeyup = function (e)
3406                {
3407                        if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
3408                        {
3409                                search_contacts(e.keyCode,this.id);
3410                        }
3411                }
3412        }
3413        else
3414        {
3415                input_to.rows = 1;
3416                input_to.onkeyup = function (e)
3417                {
3418                        if ((window.event.keyCode) == 120) //F9
3419                        {
3420                                emQuickSearch(input_to.value, 'to', ID);
3421                        }
3422                        else
3423                        {
3424                                search_contacts(window.event.keyCode,this.id);
3425                        }
3426                }
3427        }
3428        td_to.appendChild(input_to);
3429
3430        var forwarded_local_message = document.createElement("INPUT"); //Hidden para indicar se é um forward de uma mensagem local
3431        forwarded_local_message.id = "is_local_forward"+ID;
3432        forwarded_local_message.name = "is_local_forward";
3433        forwarded_local_message.type = "HIDDEN";
3434        forwarded_local_message.value = "0";
3435        td_to.appendChild(forwarded_local_message);
3436       
3437        //var td_to2 = document.createElement("TD");
3438        //td_to2.id = "another_adress_"+ID;
3439        //td_to2.style.width = "200px";
3440        //td_to2.setAttribute("noWrap","true");
3441       
3442        tr1.appendChild(td1);
3443        tr1.appendChild(td_to);
3444        //tr1.appendChild(td_to2);
3445        tbody_message.appendChild(tr1);
3446//////////////////////////////////////////////////////////////////////////////////////////////////////
3447        var tr2 = document.createElement("TR");
3448        tr2.id = "tr_cc_"+ID;
3449        tr2.style.display = 'none';
3450        var td2 = document.createElement("TD");
3451        td2.innerHTML = '<button title="'+get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.')+'" id="cc_button_'+ID+'" name="cc" class="button small adress_button">Cc:</button>';
3452        //td2.setAttribute("noWrap","true");
3453        //td2.style.width = "1%";
3454
3455        var td_cc = document.createElement("TD");
3456        //td_cc.setAttribute("noWrap","true");
3457        td_cc.style.width = "100%";
3458        //td_cc.colSpan = "2";
3459       
3460        var input_cc = document.createElement('TEXTAREA');
3461        input_cc.id = "cc_"+ID;
3462        input_cc.name = "input_cc";
3463        input_cc.setAttribute("tabIndex","1");
3464        input_cc.style.width = "100%";
3465        input_cc.className = "mail_fields";
3466        input_cc.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer));search_contacts('onfocus',this.id);};
3467        input_cc.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
3468        input_cc.rows = 1;
3469        //td_cc.setAttribute("noWrap","true");
3470        if (!is_ie)
3471        {
3472                //input_cc.rows = 1;
3473                input_cc.onkeydown = function (e)
3474                {
3475                        if ((e.keyCode) == 120) //F9
3476                        {
3477                                emQuickSearch(input_cc.value, 'cc', ID);
3478                        }
3479                        else
3480                        {
3481                                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
3482                                {
3483                                        e.preventDefault();
3484                                        search_contacts(e.keyCode,this.id);
3485                                }
3486                        }
3487                }
3488                input_cc.onkeyup = function (e)
3489                {
3490                        if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
3491                        {
3492                                search_contacts(e.keyCode,this.id);
3493                        }
3494                }
3495        }
3496        else if (is_ie)
3497        {
3498                //input_cc.rows = 1;
3499                input_cc.onkeyup = function (e)
3500                {
3501                        if ((window.event.keyCode) == 120) //F9
3502                        {
3503                                emQuickSearch(input_cc.value, 'cc', ID);
3504                        }
3505                        else
3506                        {
3507                                search_contacts(window.event.keyCode,this.id);
3508                        }
3509                }
3510        }
3511        td_cc.appendChild(input_cc);
3512        tr2.appendChild(td2);
3513        tr2.appendChild(td_cc);
3514        tbody_message.appendChild(tr2);
3515//////////////////////////////////////////////////////////////////////////////////////////////////////
3516       
3517        if( allow_hidden_copy )
3518        {
3519                 
3520                var tr3 = document.createElement("TR");
3521                tr3.id = "tr_cco_"+ID;
3522                tr3.style.display = 'none';
3523                var td3 = document.createElement("TD");
3524                //td3.setAttribute("noWrap","true");
3525                td3.innerHTML = '<button title="'+get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.')+'" id="cc_button_'+ID+'" name="cco" class="button small adress_button">'+get_lang("CCo")+':</button>';
3526                //td3.style.width = "1%";
3527
3528                var td_cco = document.createElement("TD");
3529                //td_cco.colSpan = "2";
3530                //td_cco.setAttribute("noWrap","true");
3531                td_cco.style.width = "100%";
3532
3533                var input_cco = document.createElement('TEXTAREA');
3534                input_cco.id = "cco_"+ID;
3535                input_cco.name = "input_cco";
3536                input_cco.setAttribute("tabIndex","1");
3537                input_cco.style.width = "100%";
3538                input_cco.className = "mail_fields";
3539                input_cco.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer));search_contacts('onfocus',this.id);};
3540                input_cco.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
3541                input_cco.rows = 1;
3542                if (!is_ie)
3543                {
3544                       
3545                        input_cco.onkeydown  = function (e)
3546                        {
3547                                if ((e.keyCode) == 120) //F9
3548                                {
3549                                        emQuickSearch(input_cco.value, 'cco', ID);
3550                                }
3551                                else
3552                                {
3553                                        if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
3554                                        {
3555                                                e.preventDefault();
3556                                                search_contacts(e.keyCode,this.id);
3557                                        }
3558                                }
3559                        }
3560                        input_cco.onkeyup = function (e)
3561                        {
3562                                if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
3563                                {
3564                                        search_contacts(e.keyCode,this.id);
3565                                }
3566                        }
3567                }
3568                else if (is_ie)
3569                {
3570                        input_cco.onkeyup = function (e)
3571                        {
3572                                if ((window.event.keyCode) == 120) //F9
3573                                {
3574                                        emQuickSearch(input_cco.value, 'cco', ID);
3575                                }
3576                                else
3577                                {
3578                                        search_contacts(window.event.keyCode,this.id);
3579                                }
3580                        }
3581                }
3582
3583                td_cco.appendChild(input_cco);
3584
3585                tr3.appendChild(td3);
3586                tr3.appendChild(td_cco);
3587                tbody_message.appendChild(tr3);
3588        }
3589//////////////////////////////////////////////////////////////////////////////////////////////////////
3590        var a_cc_link = document.createElement('button');
3591        a_cc_link.innerHTML = get_lang('Add CC');
3592        a_cc_link.id = "a_cc_link_"+ID;
3593        a_cc_link.className = "button small another_adress";
3594        a_cc_link.setAttribute("tabIndex","-1");
3595        var cc_load = "";
3596        a_cc_link.onclick = function () {
3597                var remove = function(){
3598                        document.getElementById('tr_cc_'+ID).style.display = 'none';
3599                        $("#cc_"+ID).parent().find("div").remove();
3600                        $("#cc_"+ID).val("");
3601                        $("#a_cc_link_"+ID).toggleClass("expressomail-button-icon-ative");
3602                }
3603                if(!($("#cc_"+ID).parent().find("div")[0])){
3604                        document.getElementById('tr_cc_'+ID).style.display = '';
3605                        document.getElementById('cc_'+ID).style.width = "100%";
3606                        $(this).find("span").html(get_lang('Remove CC'));
3607                        $("#cc_"+ID).elastic().unbind('blur');
3608                        $(this).toggleClass("expressomail-button-icon-ative");
3609                }
3610                else{
3611                        if($("#cc_"+ID).val() != ""){
3612                                if(confirm("Tem certeza que deseja remover o campo CC")){
3613                                        remove();
3614                                        $(this).find("span").html(get_lang('Add CC'));
3615                                }
3616                        }else{
3617                                remove();
3618                                $(this).find("span").html(get_lang('Add CC'));
3619                        }
3620                }
3621                input_cc.focus();
3622               
3623                return false;
3624        };
3625       
3626        if( allow_hidden_copy )
3627        {
3628                var a_cco_link = document.createElement('button');
3629                a_cco_link.innerHTML = get_lang('Add BCC');
3630                a_cco_link.id = "a_cco_link_"+ID;
3631                a_cco_link.className = "button small another_adress";
3632                a_cco_link.setAttribute("tabIndex","-1");
3633                var cco_load = "";
3634                a_cco_link.onclick = function () {
3635                        var remove = function(){
3636                                document.getElementById('tr_cco_'+ID).style.display = 'none';
3637                                $("#cco_"+ID).parent().find("div").remove();
3638                                $("#cco_"+ID).val("");
3639                                $("#a_cco_link_"+ID).toggleClass("expressomail-button-icon-ative");
3640                        }
3641                        if(!($("#cco_"+ID).parent().find("div")[0])){
3642                                document.getElementById('tr_cco_'+ID).style.display='';
3643                                document.getElementById('cco_'+ID).style.width = "100%";
3644                                $(this).find("span").html(get_lang('Remove CCo'));
3645                                $("#cco_"+ID).elastic().unbind('blur');
3646                                $(this).toggleClass("expressomail-button-icon-ative");
3647                        }
3648                        else{
3649                        if($("#cco_"+ID).val() != ""){
3650                                if(confirm("Tem certeza que deseja remover o campo CCO")){
3651                                        remove();
3652                                        $(this).find("span").html(get_lang('Add BCC'));
3653                                }
3654                        }else{
3655                                remove();
3656                                $(this).find("span").html(get_lang('Add BCC'));
3657                        }
3658                }
3659                        input_cco.focus();
3660                };
3661                //td2_link.appendChild(a_cco_link);
3662        }
3663       
3664//////////////////////////////////////////////////////////////////////////////////////////////////////
3665        var tr4 = document.createElement("TR");
3666        var td4 = document.createElement("TD");
3667        td4.innerHTML = get_lang("Subject")+":";
3668        //td4.style.width = "1%";
3669        var td_subject = document.createElement("TD");
3670        var input_subject = document.createElement('input');
3671        input_subject.id = "subject_"+ID;
3672        input_subject.name = "input_subject";
3673        input_subject.setAttribute("tabIndex","1");
3674        input_subject.style.width = "100%";
3675        input_subject.setAttribute("autocomplete","off");
3676        input_subject.onkeydown = function(event){ 
3677                var k; 
3678                if(window.event){
3679                        k = window.event.keyCode; 
3680                }else{
3681                        k = event.keyCode; 
3682                }
3683               
3684                if (k == 9){         
3685                        RichTextEditor.focus(ID); 
3686                        return false; 
3687                }   
3688        }
3689        //td_subject.colSpan = "2";
3690        td_subject.appendChild(input_subject);
3691        tr4.appendChild(td4);
3692        tr4.appendChild(td_subject);
3693        tbody_message.appendChild(tr4);
3694//////////////////////////////////////////////////////////////////////////////////////////////////////
3695        var tr5 = document.createElement("TR");
3696        var td_content = '';
3697
3698        if((preferences.use_assinar_criptografar != '0')) {
3699                if(parseInt(preferences.use_signature_digital_cripto)==1) {
3700                        var input_return_digital_chk = (parseInt(preferences.use_signature_digital)==1) ? 'checked="checked"' : '';
3701                        var input_return_digital = '<input type="checkbox" class="checkbox" name="input_return_digital" id="return_digital_'+ID+'" tabIndex="-1" '+input_return_digital_chk+' />';
3702                        var label_return_digital = '<label for="return_digital_'+ID+'">'+get_lang("Digitally sign message?")+'</label>';
3703                        var button_return_digital = '<button title="'+get_lang("Include digital signature")+'" class="send_option header-button button small '+(input_return_digital_chk != "" ? "expressomail-button-icon-ative" : "")+'" name="return_digital_'+ID+'" id="return_digital_options_'+ID+'">&nbsp;</button>';
3704                        td_content += input_return_digital + label_return_digital;
3705                        $("#content_id_"+ID).find(".new-message-menu").append(button_return_digital);
3706                       
3707                        var input_return_cripto_chk = (parseInt(preferences.use_signature_cripto)==1) ? 'checked="checked"' : '';
3708                        var input_return_cripto = '<input type="checkbox" class="checkbox" name="input_return_cripto" id="return_cripto_'+ID+'" tabIndex="-1" '+input_return_cripto_chk+' />';
3709                        var label_return_cripto = '<label for="return_cripto_'+ID+'">'+get_lang("Digitally crypt message?")+'</label>';
3710                        var button_return_cripto = '<button title="'+get_lang("Encrypted email")+'" class="send_option header-button button small '+(input_return_cripto_chk != "" ? "expressomail-button-icon-ative" : "")+'" name="return_cripto_'+ID+'" id="return_cripto_options_'+ID+'">&nbsp;</button>';
3711                        $("#content_id_"+ID).find(".new-message-menu").append(button_return_cripto);
3712                        td_content += input_return_cripto + label_return_cripto;
3713                }
3714        }
3715
3716        var input_return_receipt_chk = (preferences.return_recipient_deafault != '0') ? 'checked="checked"' : '';
3717        var input_return_receipt = '<input type="checkbox" class="checkbox" name="input_return_receipt" id="return_receipt_'+ID+'" tabIndex="-1" '+input_return_receipt_chk+' />';
3718        var label_return_receipt = '<label for="return_receipt_'+ID+'">'+get_lang("Return receipt")+'</label>';
3719        if(input_return_receipt_chk != ''){
3720                $("#conf_leitura_message_options_"+ID).toggleClass("expressomail-button-icon-ative");
3721        }
3722        td_content += input_return_receipt + label_return_receipt;
3723
3724        if (parseInt(preferences.use_important_flag))
3725                            {
3726                var input_important = '<input type="checkbox" class="checkbox" id="important_message_'+ID+'" name="input_important_message" tabIndex="-1"/>';
3727                var label_important = '<label for="important_message_'+ID+'">'+get_lang("Important message")+'</label>';
3728                //jQuery(tbody_message).append('<tr><td> </td><td>'+input_important+label_important+'</td</tr>');
3729
3730                td_content += input_important + label_important;
3731        }
3732
3733        if (!expresso_offline) {
3734                var onclk_text_plain = 'javascript:RichTextEditor.setPlain(this.checked, '+ID+');';
3735                var input_text_plain = '<input type="checkbox" class="checkbox" name="textplain_rt_checkbox" id="textplain_rt_checkbox_'+ID+'" tabIndex="-1" onclick="'+onclk_text_plain+'"/>';
3736                var label_text_plain = '<label for="textplain_rt_checkbox_'+ID+'">'+get_lang('Simple text mode')+'</label>';
3737                       
3738                td_content += input_text_plain + label_text_plain;
3739        }
3740
3741        jQuery(tr5).append('<td>&nbsp;</td><td class="message-general-options" colspan="2">'+td_content+'</td>');
3742        tr5.style.display = "none"
3743        tbody_message.appendChild(tr5);
3744
3745        /**
3746        * event to enable autosave_draft on file attachment
3747        */
3748        function save_onchange_attachment_handler () {
3749                away = false;
3750                var save_link = Element("save_message_options_"+ID);
3751                save_link.onclick = function onclick(event) {
3752                        openTab.toPreserve[ID] = true;
3753                        save_msg(ID);
3754                };
3755                $("#save_message_options_"+ID).button({ disabled: false });
3756        };
3757
3758        var add_files = document.createElement("A");
3759        add_files.setAttribute("href", "javascript:void(0)");
3760        add_files.onclick = function () {
3761                var obj = addFile(ID);
3762                if (preferences.auto_save_draft == 1 && obj) {
3763                        if ( obj.addEventListener ){
3764                                obj.addEventListener('click', save_onchange_attachment_handler, false);
3765                        }
3766                }
3767                return false;
3768        };
3769       
3770        add_files.innerHTML =  get_lang("Attachments: add+");
3771        add_files.setAttribute("tabIndex","-1");
3772       
3773        var add_msgs = document.createElement("A");
3774        add_msgs.setAttribute("href", "javascript:void(0)");
3775        is_ie ? add_msgs.setAttribute("className", 'message-attach-link') : add_msgs.setAttribute("class", 'message-attach-link');
3776        add_msgs.innerHTML =  get_lang("Messages: add+");
3777        var divfiles = document.createElement("DIV");
3778        divfiles.id = "divFiles_"+ID;
3779
3780        jQuery(add_msgs).click(function(event){
3781                jQuery('#message-attach-dialog').html(DataLayer.render("../prototype/modules/attach_message/attach_message.ejs", {}));
3782                jQuery('#message-attach-dialog').dialog({
3783                        width:920,
3784                        height:550,
3785                        resizable:false,
3786                        modal: true,
3787                        closeOnEscape:true,
3788                        close:function(event, ui) {event.stopPropagation();},
3789                        autoOpen:false
3790                });
3791                jQuery.getScript("../prototype/modules/attach_message/attach_message.js", function(){
3792                        jQuery('#message-attach-dialog').dialog('open');
3793                       
3794                        jQuery('#message-attach-attach-btn').click(function(event){
3795                                //alert(dump(selectedMessages));../
3796                                jQuery.each(selectedMessages, function(folder_name, messages) {
3797                                 
3798                                        var isOffline = /^local_messages/.test(folder_name);
3799
3800                                        jQuery.each(selectedMessages[folder_name], function(message_number, message) {
3801                                                if (message) {
3802                                                        var subject = onceOpenedMessages[folder_name][message_number].subject;
3803                                                        var text_input  = '<input type="text" name="message_attachments['+folder_name+']['+message_number+']" value="'+subject+'"/>';
3804                                                        text_input += '<a href="javascript:void(0)" onclick="javascript:this.parentNode.parentNode.removeChild(this.parentNode);">' + get_lang("Remove")+'</a>';
3805                                                        if( isOffline )
3806                                                                text_input += '<input type="hidden" name="message_attachments_content['+folder_name+']['+message_number+']" value="'+Base64.encode( onceOpenedMessages[folder_name][message_number].eml )+'"/>';
3807                                                        jQuery(divfiles).append('<div>'+text_input+'</div>');
3808                                                }
3809
3810                                        });
3811                                });
3812                               
3813                                jQuery('#message-attach-dialog').dialog('close');
3814                        });
3815                        jQuery('#message-attach-cancel-btn').click(function(event){
3816                                jQuery('#message-attach-dialog').dialog('close');
3817                        });
3818                });
3819        });
3820        var tr5 = document.createElement("TR");
3821        var td5_link = document.createElement("TD");
3822        var td5_input = document.createElement("TD");
3823        td5_input.innerHTML = "&nbsp;"
3824        //td5_input.style.width = "1%";
3825        td5_link.setAttribute("valign","top");
3826        //td5_link.setAttribute("colSpan","2");
3827        td5_link.appendChild(add_files);
3828        td5_link.appendChild(add_msgs);
3829        $(td5_link).append('<div id="message-attach-dialog" title="'+get_lang('Select messages to attach...')+'"> </div>');
3830        tr5.appendChild(td5_input);
3831        tr5.appendChild(td5_link);
3832        tbody_message.appendChild(tr5);
3833        var tr6 = document.createElement("TR");
3834        var td6_link  = document.createElement("TD");
3835        var td6_input = document.createElement("TD");
3836        //td6_link.style.width = "1%";
3837        tr6.appendChild(td6_link);
3838        td6_input.appendChild(divfiles);
3839        tr6.appendChild(td6_input);
3840        tbody_message.appendChild(tr6);
3841//////////////////////////////////////////////////////////////////////////////////////////////////////
3842        var tr5 = document.createElement("TR");
3843        //var td5 = document.createElement("TD");
3844        //td5.innerHTML = "&nbsp;";
3845        var td_body = document.createElement("TD");
3846        td_body.setAttribute("colSpan","2");
3847        var div_body_position = document.createElement("DIV");
3848        div_body_position.id = "body_position_" + ID;
3849        td_body.appendChild(div_body_position);
3850        //tr5.appendChild(td5);
3851        tr5.appendChild(td_body);
3852        tbody_message.appendChild(tr5);
3853        var _div = document.createElement("DIV");
3854        _div.id = "div_message_scroll_"+ID;
3855        _div.style.overflow = "auto";
3856        _div.style.width = "100%";
3857
3858        // Hide the contac tips and re-position the pallete color.
3859        _div.onscroll = function() {
3860                var intElemScrollTop = Element("div_message_scroll_"+ID).scrollTop;
3861                if (!is_ie)
3862                        ColorPalette.repos(intElemScrollTop);
3863                Tooltip.scrollChanged();
3864        };
3865//////////////////////////////////////////////////////////////////////////////////////////////////////
3866        _div.appendChild(form);
3867        content.appendChild(_div);
3868        table_message.appendChild(tbody_message);
3869        form.appendChild(table_message);
3870        RichTextEditor.loadEditor(ID);
3871       
3872        var rich_button = document.createElement("button");
3873       
3874        if(preferences.plain_text_editor == 1){
3875                var texto = get_lang("Rich Text");
3876        }else{
3877                var texto = get_lang("Simple Text");
3878        }
3879               
3880        rich_button.innerHTML = texto;
3881        rich_button.className = "button small rich-button";
3882        rich_button.name = "textplain_rt_checkbox_"+ID;
3883       
3884//////////////////////////////////////////////////////////////////////////////////////////////////////
3885        if(!expresso_offline)
3886                draw_from_field(sel_from,tr1_1);
3887               
3888        resizeWindow();
3889
3890        if ( ! expresso_offline )
3891        {
3892                        if ( mobile_device )
3893                        {
3894                                        text_plain.click( );
3895                                        text_plain.parentNode.style.display = 'none';
3896                        }
3897        }
3898        //var a_cc_link2 = document.createElement("button");
3899       
3900        $("#another_adress_"+ID).append(a_cc_link);
3901       
3902        if(a_cco_link != undefined)
3903                $("#another_adress_"+ID).append(a_cco_link);
3904               
3905        $("#another_adress_"+ID).append(rich_button);
3906       
3907        $("#to_"+ID).elastic().unbind('blur');
3908        //$(".mail_fields");
3909        //$(".mail_fields").css("width","100%");
3910       
3911        $(".another_adress").button();
3912        $(".rich-button").button();
3913        $(".rich-button").click(function(){
3914                //TO-DO : Se o usuário clicar varias vezes no botão, a função de iniciar o ckeditor se perde e morre.
3915                $(this).button({ disabled: true });
3916                if($(this).find("span:first-child").html() == get_lang("Rich text")){
3917                        $(this).find("span:first-child").html(get_lang("Simple Text"));
3918                }else{
3919                        $(this).find("span:first-child").html(get_lang("Rich Text"));
3920                }
3921               
3922                var check = $("#"+$(this).attr("name")).attr("checked");
3923                $("#"+$(this).attr("name")).attr("checked", (!check ? true : false));
3924                $("#"+$(this).attr("name")).trigger('click');
3925                $("#"+$(this).attr("name")).attr("checked", (!check ? true : false));
3926                //$(this).button({ disabled: false });
3927        });
3928       
3929        if($("#send_and_custom_save_"+ID)[0])
3930                $("#send_and_custom_save_"+ID).button({
3931                        icons : {
3932                                primary :"expressomail-icon-save_and_send"
3933                        }
3934                })
3935        $("#content_id_"+ID).find(".adress_button").button().click(function(){
3936                emQuickSearch($("#"+($(this).attr("name"))+"_"+ID).val(), $(this).attr("name"), ID, undefined, true);
3937        });
3938       
3939        $("#send_button_"+ID).button({
3940                icons : {
3941                        primary : "expressomail-icon-send"
3942                }
3943        }).next().button({
3944                icons : {
3945                        primary : "expressomail-icon-save"
3946                }
3947        });
3948        $("#content_id_"+ID).find("[name=return_receipt_"+ID+"]").button({
3949                icons : {
3950                        primary : "expressomail-icon-read-confirmation"
3951                }
3952        });
3953        $("#important_message_options_"+ID).button({
3954                icons : {
3955                        primary : "expressomail-icon-important"
3956                }
3957        });
3958        $("#return_digital_options_"+ID).button({
3959                icons : {
3960                        primary : "expressomail-icon-signature"
3961                }
3962        });
3963        $("#return_cripto_options_"+ID).button({
3964                icons : {
3965                        primary : "expressomail-icon-encryption"
3966                }
3967        });
3968
3969        $("#content_id_"+ID).find(".send_option").click(function(){
3970                var check = $("#"+$(this).attr("name")).attr("checked");
3971                $("#"+$(this).attr("name")).attr("checked", (!check ? true : false));
3972                $(this).toggleClass("expressomail-button-icon-ative");
3973        });
3974       
3975        return ID;
3976}
3977
3978//      Verify if any user is sharing his name/email address
3979//      for use in the new messages's "From " field.
3980function draw_from_field(sel_from,tr1_1){
3981
3982        var el_shared_users = Element("el_shared_users");
3983        // The element was loaded and populated...so return.
3984        if(el_shared_users){
3985                // Nothing to work...so return.
3986                if(el_shared_users.options.length == 0)
3987                        return;
3988                tr1_1.style.display = '';
3989                for (var x = 0; x < el_shared_users.options.length; x++) {
3990                        var _option = document.createElement("OPTION");
3991                        _option.text = el_shared_users.options[x].text;
3992                        _option.value = el_shared_users.options[x].value;
3993                        sel_from.options[sel_from.options.length] = _option     ;
3994                }
3995                return;
3996        }
3997        // Get the shared folders.....
3998        var sharedFolders = new Array();
3999        for(var i = 0; i < folders.length; i++) {
4000                var x = folders[i].folder_id;
4001                if (folders[i].folder_parent == 'user'){
4002                        sharedFolders[sharedFolders.length] = x;
4003                }
4004        }
4005
4006        var matchUser = '#';
4007        var sharedUsers = new Array();
4008        // Filter the shared folders (only root folders) .....
4009        for(var i = 0; i < sharedFolders.length; i++) {
4010                matchUser = sharedFolders[i];
4011                sharedUsers[sharedUsers.length] = matchUser.substring(("user"+cyrus_delimiter).length,matchUser.length);
4012        }
4013
4014        // Handler function for cExecute
4015        var h_user = function(data) {
4016                if(data.length > 0) {
4017                        tr1_1.style.display = '';
4018                        var mycn = typeof(data.myname != 'undefined') ? data.myname : '';
4019                        var _option = document.createElement("OPTION");
4020                        _option.text =  '"'+mycn+'" <'+Element("user_email").value+'>';
4021                        _option.value  = mycn+";"+Element("user_email").value;
4022                        sel_from.options[sel_from.options.length] = _option;
4023
4024                        var options = '';
4025                        var cn = '';
4026                        for (var x = 0; x < data.length; x++)   {
4027                                cn = typeof(data[x].cn[0] != 'undefined') ? data[x].cn[0] : '';
4028                                var _option = document.createElement("OPTION");
4029                                _option.text = '"'+cn+'" <'+data[x].mail[0]+'>';
4030                                _option.value = cn+';'+data[x].mail[0]+';'+data[x].save_shared[0]+';'+data[x].uid[0];
4031                                sel_from.options[sel_from.options.length] = _option     ;
4032                        }
4033                }
4034                var shared_users_from = Element("el_shared_users");
4035                if(!shared_users_from) {
4036                        shared_users_from = sel_from.cloneNode(true);
4037                        shared_users_from.id = "el_shared_users";
4038                        shared_users_from.style.display = 'none';
4039                        document.body.appendChild(shared_users_from);
4040                }
4041        }
4042        // First time, so execute.....
4043        cExecute ("$this.ldap_functions.getSharedUsersFrom&uids="+sharedUsers.join(';'), h_user);
4044}
4045
4046function changeBgColorToON(all_messages, begin, end){
4047        var _tab_prefix = getTabPrefix();
4048        var _msg_id;
4049        for (begin; begin<=end; begin++)
4050        {
4051                _msg_id = getMessageIdFromRowId(all_messages[begin].id);
4052                add_className(all_messages[begin], 'selected_msg');
4053                Element(_tab_prefix + "check_box_message_" + _msg_id).checked = true;
4054        }
4055}
4056
4057function updateBoxBgColor(box){
4058        // Set first TR Class
4059        var _className = 'tr_msg_read2';
4060        for(var i = 0; i < box.length;i++){
4061                if(exist_className(box[i],_className))
4062                        remove_className(box[i], _className);
4063                _className = (_className == 'tr_msg_read2' ? 'tr_msg_read' : 'tr_msg_read2');
4064                if(!exist_className(box[i],_className))
4065                        add_className( box[i], _className);
4066        }
4067}
4068function changeBgColor(event, msg_number) {
4069        var _element_id = msg_number.toString();
4070        var first_order, last_order;
4071
4072        if (typeof(currentTab)!='number') {
4073                _element_id = _element_id+'_s'+numBox;
4074        }
4075        actual_tr = Element(_element_id);
4076
4077        if (event.shiftKey)
4078        {
4079                var last_tr = Element(last_message_selected);
4080                if(!last_tr)
4081                        last_tr = actual_tr;
4082
4083                var all_messages = actual_tr.parentNode.childNodes;
4084
4085                for (var i=0; i < all_messages.length; i++)
4086                {
4087                        if (actual_tr.id == all_messages[i].id)
4088                                first_order = i;
4089                        if (last_tr.id == all_messages[i].id)
4090                                last_order = i;
4091                }
4092
4093                if (parseInt(first_order) > parseInt(last_order))
4094                        changeBgColorToON(all_messages, last_order, first_order);
4095                else
4096                        changeBgColorToON(all_messages, first_order, last_order);
4097        }
4098        else{
4099                //if ( exist_className(actual_tr, 'selected_msg') )
4100                if ( document.getElementById(getTabPrefix()+'check_box_message_' + msg_number).checked ){
4101                        if( document.getElementById("chk_box_select_all_messages").checked) {
4102                                add_className(actual_tr, 'selected_msg selected_shortcut_msg');
4103                        }else
4104                        add_className(actual_tr, 'selected_msg');
4105                }else{
4106                        if( document.getElementById("chk_box_select_all_messages").checked){
4107                                remove_className(actual_tr, 'selected_msg selected_shortcut_msg');
4108                                remove_className(actual_tr, 'selected_msg');
4109                                remove_chk_box_select_all_messages();
4110                                if(actual_tr.className == 'selected_msg')
4111                        remove_className(actual_tr, 'selected_msg');
4112                        }else
4113                                remove_className(actual_tr, 'selected_msg');
4114                }
4115        }
4116        last_message_selected = _element_id;
4117}
4118
4119function build_quota(data){
4120        id = "content_quota";
4121        q_limit = data['quota_limit'];
4122        var div = document.getElementById(id);
4123        if(!q_limit){
4124                div.innerHTML = '<span><font size="2" style="color:red"><strong>'+get_lang("Without Quota")+'</strong></font></span>';
4125        }
4126        else{
4127        if(div)
4128                div.innerHTML = '';
4129        value = data['quota_percent'];
4130        q_used = data['quota_used'];
4131        table = document.getElementById("table_quota");
4132        if(table)
4133                table.parentNode.removeChild(table);
4134        table = document.createElement("TABLE");
4135        tbody = document.createElement("TBODY");
4136        table.appendChild(tbody);
4137        table.id = "table_quota";
4138        table.width="102";
4139        table.border="0";
4140        table.cellSpacing = 0;
4141        table.cellPadding = 0;
4142
4143        //tr1 = document.createElement("TR");
4144        td11 = document.createElement("TD");
4145        td11.align="center";
4146        td11.setAttribute("noWrap","true");
4147        td11.innerHTML += '&nbsp;<span class="boxHeaderText">' + value+"% ("+borkb(q_used*1024)+"/"+borkb(q_limit*1024)+")</span>";
4148        //tr1.appendChild(td11);
4149
4150        tr2 = document.createElement("TR");
4151        td21 = document.createElement("TD");
4152        td21.setAttribute("noWrap","true");
4153        td21.height="15";
4154        td22 = document.createElement("TD");
4155        td21.setAttribute("background","../phpgwapi/templates/"+template+"/images/dsunused.gif");
4156        table221 = document.createElement("TABLE");
4157        tbody221 = document.createElement("TBODY");
4158        table221.appendChild(tbody221);
4159        table221.style.width=value+"%";
4160        td21.width="102";
4161        table221.border="0";
4162        table221.cellSpacing = 0;
4163        table221.cellPadding = 0;
4164        tr221 = document.createElement("TR");
4165        td221 = document.createElement("TD");
4166        td221.height="15";
4167        if(value > 90) {
4168                if(value >= 100)
4169                        write_msg(get_lang("Your Mailbox is 100% full! You must free more space or will not receive messages."));
4170                else
4171                        write_msg(get_lang("Warning: Your Mailbox is almost full!"));
4172                td221.setAttribute("background","templates/"+template+"/images/dsalert.gif");
4173        }
4174        else if(value > 80)
4175                td221.setAttribute("background","templates/"+template+"/images/dswarn.gif");
4176        else
4177                td221.className = 'dsused';
4178
4179        td221.setAttribute("style","width: 100%");
4180
4181        tr221.appendChild(td221);
4182        tbody221.appendChild(tr221);
4183        td21.appendChild(table221);
4184        tr2.appendChild(td21);
4185        tr2.appendChild(td11);
4186
4187        //tr2.appendChild(td1);
4188
4189        tbody.appendChild(tr2); //Desenho
4190        //tbody.appendChild(tr1); //Letras
4191        div.appendChild(table);
4192        }
4193}
4194
4195function draw_quota(data){
4196        build_quota(data);
4197}
4198
4199function update_quota(folder_id){
4200        cExecute ("$this.imap_functions.get_quota&folder_id="+folder_id,build_quota);
4201}
4202
4203function draw_search(headers_msgs){
4204        Element("border_id_0").innerHTML = "&nbsp;&nbsp;" + get_lang('Search Result') + "&nbsp;&nbsp;";
4205
4206        var tbody = Element('tbody_box');
4207        for (var i=0; i<(headers_msgs.length); i++){
4208            // passa parâmetro offset
4209                var tr = this.make_tr_message(headers_msgs[i], headers_msgs[i].msg_folder);
4210                if (tr)
4211                        tbody.appendChild(tr);
4212        }
4213}
4214
4215function draw_search_header_box(){
4216        var table_message_header_box = Element("table_message_header_box");
4217        table_message_header_box.parentNode.removeChild(table_message_header_box);
4218
4219        var content_id_0 = Element("content_id_0");
4220        var table_element = document.createElement("TABLE");
4221        var tbody_element = document.createElement("TBODY");
4222        table_element.setAttribute("id", "table_message_header_box");
4223        table_element.className = "table_message_header_box";
4224        tr_element = document.createElement("TR");
4225        tr_element.className = "message_header";
4226        td_element1 = document.createElement("TD");
4227        td_element1.setAttribute("width", "1%");
4228        chk_box_element = document.createElement("INPUT");
4229        chk_box_element.id  = "chk_box_select_all_messages";
4230        chk_box_element.setAttribute("type", "checkbox");
4231        chk_box_element.className = "checkbox";
4232        chk_box_element.onclick = function(){select_all_messages(this.checked);};
4233        chk_box_element.onmouseover = function () {this.title=get_lang('Select all messages.')};
4234        chk_box_element.onkeydown = function (e){
4235                if (is_ie)
4236                {
4237                        if ((window.event.keyCode) == 46)
4238                        {
4239                                //delete_all_selected_msgs_imap();
4240                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
4241                        }
4242                }
4243                else
4244                {
4245                        if ((e.keyCode) == 46)
4246                        {
4247                                //delete_all_selected_msgs_imap();
4248                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
4249                        }
4250                }
4251        };
4252
4253        td_element1.appendChild(chk_box_element);
4254        td_element2 = document.createElement("TD");
4255        td_element2.setAttribute("width", "3%");
4256        td_element3 = document.createElement("TD");
4257        td_element3.setAttribute("width", "30%");
4258        td_element3.id = "message_header_SORTFROM";
4259        td_element3.align = "left";
4260        td_element3.innerHTML = get_lang("From");
4261        td_element4 = document.createElement("TD");
4262        td_element4.setAttribute("width", "49%");
4263        td_element4.id = "message_header_SORTSUBJECT";
4264        td_element4.align = "left";
4265        td_element4.innerHTML = get_lang("Subject");
4266        td_element5 = document.createElement("TD");
4267        td_element5.setAttribute("width", "10%");
4268        td_element5.id = "message_header_SORTARRIVAL";
4269        td_element5.align = "center";
4270        td_element5.innerHTML = "<B>"+get_lang("Date")+"</B>";
4271        td_element5.innerHTML += "<img src ='templates/"+template+"/images/arrow_descendant.gif'>";
4272        td_element6 = document.createElement("TD");
4273        td_element6.setAttribute("width", "10%");
4274        td_element6.id = "message_header_SORTSIZE";
4275        td_element6.align = "right";
4276        td_element6.innerHTML = get_lang("Size");
4277        tr_element.appendChild(td_element1);
4278        tr_element.appendChild(td_element2);
4279        tr_element.appendChild(td_element3);
4280        tr_element.appendChild(td_element4);
4281        tr_element.appendChild(td_element5);
4282        tr_element.appendChild(td_element6);
4283
4284        tbody_element.appendChild(tr_element);
4285        table_element.appendChild(tbody_element);
4286        content_id_0.appendChild(table_element);
4287}
4288
4289function draw_search_division(msg){
4290        var tbody = Element('tbody_box');
4291        var tr = document.createElement("TR");
4292        var td = document.createElement("TD");
4293        td.colSpan = '7';
4294        td.width = '100%';
4295
4296        var action_info_table = document.createElement("TABLE");
4297        var action_info_tbody = document.createElement("TBODY");
4298
4299        action_info_table.className = "action_info_table";
4300        action_info_table.width = "100%";
4301
4302        var action_info_tr = document.createElement("TR");
4303
4304        var action_info_th1 = document.createElement("TH");
4305        action_info_th1.width = "40%";
4306        action_info_th1.innerHTML = "&nbsp;";
4307
4308        var action_info_th2 = document.createElement("TH");
4309
4310        action_info_th2.innerHTML = msg;
4311        action_info_th2.className = "action_info_th";
4312        action_info_th2.setAttribute("noWrap", "true");
4313
4314        var action_info_th3 = document.createElement("TH");
4315        action_info_th3.width = "40%";
4316        action_info_th3.innerHTML = "&nbsp;";
4317
4318        action_info_tr.appendChild(action_info_th1);
4319        action_info_tr.appendChild(action_info_th2);
4320        action_info_tr.appendChild(action_info_th3);
4321        action_info_tbody.appendChild(action_info_tr);
4322        action_info_table.appendChild(action_info_tbody);
4323
4324        td.appendChild(action_info_table);
4325        tr.appendChild(td);
4326        tbody.appendChild(tr);
4327}
4328
4329function draw_search_box(){
4330        var content_id_0 = Element("content_id_0");
4331        var table = document.createElement("TABLE");
4332        table.id = "table_box";
4333        table.width = 'auto';
4334        var tbody = document.createElement("TBODY");
4335        tbody.id = "tbody_box";
4336
4337        table.className = "table_box";
4338        table.setAttribute("frame", "below");
4339        table.setAttribute("rules", "none");
4340        table.setAttribute("cellpadding", "0");
4341        table.onkeydown = function (e){
4342                if (is_ie)
4343                {
4344                        if ((window.event.keyCode) == 46)
4345                        {
4346                                //delete_all_selected_msgs_imap();
4347                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
4348                        }
4349                }
4350                else
4351                {
4352                        if ((e.keyCode) == 46)
4353                        {
4354                                //delete_all_selected_msgs_imap();
4355                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
4356                        }
4357                }
4358        };
4359        if (is_ie)
4360                table.style.cursor = "hand";
4361
4362        table.appendChild(tbody);
4363        content_id_0.appendChild(table);
4364}
4365        var idx_cc = 0;
4366
4367function draw_plugin_cc(ID, addrs){
4368        connector.loadScript("ccQuickAdd");
4369
4370        var array_addrs = '';
4371        var array_name  = '';
4372        var cc_data = new Array();
4373        if(typeof(addrs.name) != 'undefined') {
4374                array_name      = LTrim(addrs.name).split(" ");
4375                array_addrs = new Array(addrs.email);
4376        }
4377        else {
4378                array_addrs = (typeof addrs == 'object' ? addrs.toString().split("\" ") : addrs.split("\" "));
4379                array_name      = LTrim(array_addrs[0]).replace('"','').split(" ");
4380        }
4381
4382        var _split = array_name[0].split('@');
4383        cc_data[0] = _split[0];
4384        cc_data[1] = _split[0];
4385        cc_data[2] = '';
4386
4387        for (i=1; i < array_name.length; i++)
4388                cc_data[2] += array_name[i] + " ";
4389
4390
4391        if(array_addrs.length > 1)
4392                cc_data[3] = array_addrs[1] ? array_addrs[1].replace("&lt;",'').replace("&gt;",'') : '';
4393        else
4394                cc_data[3] = array_addrs[0];
4395
4396        var sm_envelope_img1 = '<img style="cursor:'+ (is_ie ? 'hand' : 'pointer') +'" title="' + get_lang("Add Contact") +
4397        '" onclick="ccQuickAddOne.showList(\''+cc_data+'\')" src="./templates/'+template+'/images/user_card.png">';
4398        var to_addybook_add = "<SPAN id='insert_plugin_"+idx_cc+"_"+ID+"'>";
4399        to_addybook_add += addrs;
4400        to_addybook_add +=  sm_envelope_img1;
4401        idx_cc++;
4402        to_addybook_add += "</SPAN>";
4403        return to_addybook_add;
4404}
4405
4406function deny_email(email){
4407        connector.loadScript("filter");
4408        connector.loadScript("filters");
4409        var dn_em       = document.createElement("SPAN");
4410                dn_em.id = "tt_d";
4411                dn_em.onclick = function(){filter.new_rule(email);};
4412                dn_em.setAttribute("title",get_lang("Block Sender"));
4413                dn_em.style.cursor = "pointer";
4414                dn_em.innerHTML = "<img align='top' src='./templates/"+template+"/images/deny.gif'>";
4415        return dn_em;
4416
4417}
4418
4419function show_div_address_full(id, type) {
4420        var div_address_full = Element("div_"+type+"address_full_"+id);
4421        if(!div_address_full) {
4422                div_address_full = document.createElement("SPAN");
4423                div_address_full.id = "div_"+type+"address_full_"+id;
4424                div_address_full.style.display="none";
4425                var _address = eval(type+"address_array['"+id+"']");
4426                var isOverLimit = (_address.length > 100);
4427
4428                if(isOverLimit) {
4429                        alert("Esse campo possui muitos endereços ("+_address.length+" destinatários).\r\n"+
4430                        "Para evitar o travamento do navegador, o botão 'Adicionar Contato' foi desabilitado!");
4431                }
4432
4433                for(var idx = 1 ; idx  < _address.length;idx++) {
4434                        div_address_full.innerHTML += isOverLimit ?  '<br>'+_address[idx] : ','+draw_plugin_cc(id,_address[idx]);
4435                }
4436                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>)";
4437                Element(type+"_"+id).appendChild(div_address_full);
4438        }
4439        Element('div_'+type+'address_'+id).style.display='none';
4440        div_address_full.style.display='';
4441}
4442
4443function draw_footer_box(num_msgs){
4444        folder = get_current_folder();
4445        connector.loadScript('wfolders');
4446        var span_R = Element("table_message");
4447        var span_options = Element("span_options");
4448        if(!span_options) {
4449                span_options = document.createElement("TD");
4450                span_options.style.fontSize = "12";
4451                span_options.id = "span_options";
4452                span_R.appendChild(span_options);
4453        }
4454
4455        var change_font_color = 'onmouseover="var last_class = this.className;'+
4456                                'if (this.className != \'message_options_over\')'+
4457                                'this.className=\'message_options_active\'; '+
4458                                'this.onmouseout=function(){this.className=last_class;}"';
4459
4460        span_options.innerHTML =
4461                '<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>'+
4462                '<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>'+
4463                ((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>')+
4464//              '<span class="message_options_print"><span ' + change_font_color + ' title="'+get_lang("Print")+'" class="message_options" onclick=print_all()>'+get_lang("Print")+'</span></span>'+
4465                ((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>') +
4466                ((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>');
4467        if(preferences.use_local_messages==1 && !expresso_offline)
4468                if(proxy_mensagens.is_local_folder(current_folder))
4469                        span_options.innerHTML += '&nbsp; <span id="localOption" ' + change_font_color + ' title="'+get_lang("Unarchive")+'" class="message_options" onclick="expresso_local_messages.unarchive_msgs(\''+folder+'\',null)">'+get_lang("Unarchive")+'</span>';
4470                else
4471                        span_options.innerHTML += '&nbsp; <span id="localOption" ' + change_font_color + ' title="'+get_lang("Archive")+'" class="message_options" onclick="archive_msgs(\''+folder+'\',null)">'+get_lang("Archive")+'</span>';
4472        if (use_spam_filter) {
4473                if ( current_folder == 'INBOX'+cyrus_delimiter+'Spam' ) {
4474                        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>';
4475                }
4476                else {
4477                        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>';
4478                }
4479        }
4480        var span_D = Element("span_D");
4481        if(!span_D){
4482                span_D = document.createElement("TD");
4483                span_D.align = "right";
4484                span_D.style.fontSize = "12";
4485                span_D.id = "span_D";
4486                span_R.appendChild(span_D);
4487        }
4488        span_D.innerHTML =
4489                 get_lang("List")+': '+
4490        '<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>, '+
4491        '<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>, '+
4492        '<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>, '+
4493        '<span ' + change_font_color + ' id="span_flag_ANSWERED" class="'+(search_box_type == 'ANSWERED' ? 'message_options_over' : 'message_options')+'" title="'+get_lang("title_answered")+'" onclick="if(\'ANSWERED\' == \''+search_box_type+'\') return false;sort_box(\'ANSWERED\',\''+sort_box_type+'\')">'+get_lang("l_answered")+'</span>, '+
4494        '<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;';
4495        draw_paging(num_msgs);
4496        Element("tot_m").innerHTML = num_msgs;
4497}
Note: See TracBrowser for help on using the repository browser.