source: trunk/expressoMail1_2/js/jscode/draw_api_folders.js @ 2904

Revision 2904, 45.6 KB checked in by rodsouza, 14 years ago (diff)

Ticket #1059 - Exibindo layout do ExpressoMail? independente do carregamento dos e-mails

Line 
1
2
3var lastPage = 1;
4var numPages = 5;
5var last_folder = 'INBOX';
6
7function draw_quota(data){
8        build_quota(data);
9}
10
11function update_quota(folder_id){
12        cExecute ("expressoMail1_2.imap_functions.get_quota&folder_id="+folder_id,build_quota);
13}
14
15function draw_search(headers_msgs){
16        Element("border_id_0").innerHTML = "  " + get_lang('Search Result') + "  ";
17
18        var tbody = Element('tbody_box');
19        for (var i=0; i<(headers_msgs.length); i++){
20                var tr = this.make_tr_message(headers_msgs[i], headers_msgs[i].msg_folder);
21                if (tr)
22                        tbody.appendChild(tr);
23        }
24}
25
26function draw_header_box(){
27        switch(sort_box_type){
28                case 'SORTFROM':
29                        type_name = get_lang("Who");
30                        break;
31                case 'SORTSUBJECT':
32                        type_name = get_lang("Subject");
33                        break;
34                case 'SORTARRIVAL':
35                        type_name = get_lang("Date");
36                        break;
37                case 'SORTSIZE':
38                        type_name = get_lang("Size");
39                        break;
40                default:
41                        type_name = get_lang("Date");
42                        break;
43        }
44        document.getElementById("message_header_SORTFROM_"+numBox).innerHTML    = get_lang("Who");
45        document.getElementById("message_header_SORTSUBJECT_"+numBox).innerHTML = get_lang("Subject");
46        document.getElementById("message_header_SORTARRIVAL_"+numBox).innerHTML = get_lang("Date");
47        document.getElementById("message_header_SORTSIZE_"+numBox).innerHTML    = get_lang("Size");     
48        document.getElementById("message_header_"+(sort_box_type.lastIndexOf("SORT") != "-1" ? sort_box_type : "SORTARRIVAL")+"_"+numBox ).innerHTML = "<B>"+type_name+'</B><img src ="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/arrow_'+(sort_box_reverse == 1 ? 'desc' : 'asc')+'endant.gif">';
49}
50
51function draw_search_header_box(){
52        var table_message_header_box = Element("table_message_header_box");
53        table_message_header_box.parentNode.removeChild(table_message_header_box);
54
55        var content_id_0 = Element("content_id_0");
56        var table_element = document.createElement("TABLE");
57        var tbody_element = document.createElement("TBODY");
58        table_element.setAttribute("id", "table_message_header_box");
59        table_element.className = "table_message_header_box";
60        tr_element = document.createElement("TR");
61        tr_element.className = "message_header";
62        td_element1 = document.createElement("TD");
63        td_element1.setAttribute("width", "1%");
64        chk_box_element = document.createElement("INPUT");
65        chk_box_element.id  = "chk_box_select_all_messages";
66        chk_box_element.setAttribute("type", "checkbox");
67        chk_box_element.className = "checkbox";
68        chk_box_element.onclick = function(){
69                select_all_messages(this.checked);
70        };
71        chk_box_element.onmouseover = function () {
72                this.title=get_lang('Select all messages.')
73        };
74        chk_box_element.onkeydown = function (e){
75                if (is_ie)
76                {
77                        if ((window.event.keyCode) == 46)
78                        {
79                                //delete_all_selected_msgs_imap();
80                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
81                        }
82                }
83                else
84                {
85                        if ((e.keyCode) == 46)
86                        {
87                                //delete_all_selected_msgs_imap();
88                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
89                        }
90                }
91        };
92
93        td_element1.appendChild(chk_box_element);
94        td_element2 = document.createElement("TD");
95        td_element2.setAttribute("width", "3%");
96        td_element3 = document.createElement("TD");
97        td_element3.setAttribute("width", "30%");
98        td_element3.id = "message_header_SORTFROM";
99        td_element3.align = "left";
100        td_element3.innerHTML = get_lang("From");
101        td_element4 = document.createElement("TD");
102        td_element4.setAttribute("width", "49%");
103        td_element4.id = "message_header_SORTSUBJECT";
104        td_element4.align = "left";
105        td_element4.innerHTML = get_lang("Subject");
106        td_element5 = document.createElement("TD");
107        td_element5.setAttribute("width", "10%");
108        td_element5.id = "message_header_SORTARRIVAL";
109        td_element5.align = "center";
110        td_element5.innerHTML = "<B>"+get_lang("Date")+"</B>";
111        td_element5.innerHTML += '<img src ="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/arrow_descendant.gif">';
112        td_element6 = document.createElement("TD");
113        td_element6.setAttribute("width", "10%");
114        td_element6.id = "message_header_SORTSIZE";
115        td_element6.align = "right";
116        td_element6.innerHTML = get_lang("Size");
117        tr_element.appendChild(td_element1);
118        tr_element.appendChild(td_element2);
119        tr_element.appendChild(td_element3);
120        tr_element.appendChild(td_element4);
121        tr_element.appendChild(td_element5);
122        tr_element.appendChild(td_element6);
123
124        tbody_element.appendChild(tr_element);
125        table_element.appendChild(tbody_element);
126        content_id_0.appendChild(table_element);
127}
128
129function draw_search_division(msg){
130        var tbody = Element('tbody_box');
131        var tr = document.createElement("TR");
132        var td = document.createElement("TD");
133        td.colSpan = '7';
134        td.width = '100%';
135
136        var action_info_table = document.createElement("TABLE");
137        var action_info_tbody = document.createElement("TBODY");
138
139        action_info_table.className = "action_info_table";
140        action_info_table.width = "100%";
141
142        var action_info_tr = document.createElement("TR");
143
144        var action_info_th1 = document.createElement("TH");
145        action_info_th1.width = "40%";
146        action_info_th1.innerHTML = "&nbsp;";
147
148        var action_info_th2 = document.createElement("TH");
149
150        action_info_th2.innerHTML = msg;
151        action_info_th2.className = "action_info_th";
152        action_info_th2.setAttribute("noWrap", "true");
153
154        var action_info_th3 = document.createElement("TH");
155        action_info_th3.width = "40%";
156        action_info_th3.innerHTML = "&nbsp;";
157
158        action_info_tr.appendChild(action_info_th1);
159        action_info_tr.appendChild(action_info_th2);
160        action_info_tr.appendChild(action_info_th3);
161        action_info_tbody.appendChild(action_info_tr);
162        action_info_table.appendChild(action_info_tbody);
163
164        td.appendChild(action_info_table);
165        tr.appendChild(td);
166        tbody.appendChild(tr);
167}
168
169function draw_search_box(){
170        var content_id_0 = Element("content_id_0");
171        var table = document.createElement("TABLE");
172        table.id = "table_box";
173        table.width = 'auto';
174        var tbody = document.createElement("TBODY");
175        tbody.id = "tbody_box";
176
177        table.className = "table_box";
178        table.setAttribute("frame", "below");
179        table.setAttribute("rules", "none");
180        table.setAttribute("cellpadding", "0");
181        table.onkeydown = function (e){
182                if (is_ie)
183                {
184                        if ((window.event.keyCode) == 46)
185                        {
186                                //delete_all_selected_msgs_imap();
187                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
188                        }
189                }
190                else
191                {
192                        if ((e.keyCode) == 46)
193                        {
194                                //delete_all_selected_msgs_imap();
195                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
196                        }
197                }
198        };
199        if (is_ie)
200                table.style.cursor = "hand";
201
202        table.appendChild(tbody);
203        content_id_0.appendChild(table);
204}
205
206function build_quota(data){
207        id = "content_quota";
208        q_limit = data['quota_limit'];
209        var div = document.getElementById(id);
210        if(!q_limit){
211                div.innerHTML = '<span><font size="2" style="color:red"><strong>'+get_lang("Without Quota")+'</strong></font></span>';
212        }
213        else{
214                if(div)
215                {
216                        div.innerHTML = '';
217                        value = data['quota_percent'];
218                        q_used = data['quota_used'];
219                        table = document.getElementById("table_quota");
220                        if(table)
221                                table.parentNode.removeChild(table);
222                        table = document.createElement("TABLE");
223                        tbody = document.createElement("TBODY");
224                        table.appendChild(tbody);
225                        table.id = "table_quota";
226                        table.width="102";
227                        table.border="0";
228                        table.cellSpacing = 0;
229                        table.cellPadding = 0;
230
231                        //tr1 = document.createElement("TR");
232                        td11 = document.createElement("TD");
233                        td11.align="center";
234                        td11.setAttribute("noWrap","true");
235                        td11.innerHTML += '&nbsp;<span class="boxHeaderText">' + value+"% ("+q_used+"M/"+q_limit+"M)</span>";
236                        //tr1.appendChild(td11);
237
238                        tr2 = document.createElement("TR");
239                        td21 = document.createElement("TD");
240                        td21.setAttribute("noWrap","true");
241                        td21.height="15";
242                        td22 = document.createElement("TD");
243                        td21.setAttribute("background", URL_SERVER + 'phpgwapi/templates/' + template + '/images/dsunused.gif');
244                        table221 = document.createElement("TABLE");
245                        tbody221 = document.createElement("TBODY");
246                        table221.appendChild(tbody221);
247                        table221.style.width=value+"%";
248                        td21.width="102";
249                        table221.border="0";
250                        table221.cellSpacing = 0;
251                        table221.cellPadding = 0;
252                        tr221 = document.createElement("TR");
253                        td221 = document.createElement("TD");
254                        td221.height="15";
255                        if(value > 90) {
256                                if(value >= 100)
257                                        write_msg(get_lang("Your Mailbox is 100% full! You must free more space or will not receive messages."));
258                                else
259                                        write_msg(get_lang("Warning: Your Mailbox is almost full!"));
260                                td221.setAttribute("background","templates/"+template+"/images/dsalert.gif");
261                        }
262                        else if(value > 80)
263                                td221.setAttribute("background", URL_SERVER + 'expressoMail1_2/templates/' + template + '/images/dswarn.gif');
264                        else
265                                td221.className = 'dsused';
266
267                        tr221.appendChild(td221);
268                        tbody221.appendChild(tr221);
269                        td21.appendChild(table221);
270                        tr2.appendChild(td21);
271                        tr2.appendChild(td11);
272
273                        //tr2.appendChild(td1);
274
275                        tbody.appendChild(tr2); //Desenho
276                        //tbody.appendChild(tr1); //Letras
277                        div.appendChild(table);
278                }
279        }
280}
281
282function draw_paging(num_msgs){
283        num_msgs = parseInt(num_msgs);
284        total_pages = 1;
285
286        if(last_folder != current_folder){
287                lastPage = 1;
288                current_page = 1;
289                last_folder = current_folder;
290        }
291
292        if(num_msgs > parseInt(preferences.max_email_per_page)) {
293                total_pages = parseInt(num_msgs/preferences.max_email_per_page);
294                if((num_msgs/preferences.max_email_per_page) > total_pages)
295                        total_pages++;
296        }
297
298        if(total_pages == 1) {
299                if(span_paging = document.getElementById("span_paging")) {
300                        span_paging.parentNode.removeChild(span_paging);
301                }
302                return;
303        }
304
305        span_paging = document.getElementById("span_paging");
306        if(!span_paging){
307                span_paging = document.createElement("DIV");
308                span_paging.id = "span_paging";
309                span_paging.className = "boxHeaderText";
310                span_paging.align="right";
311                var div_menu_c3 = document.getElementById("div_menu_c3");
312                if ( div_menu_c3 )
313                        div_menu_c3.appendChild(span_paging);
314        }
315        span_paging.style.width="100%";
316        span_paging.innerHTML="";
317        msg_range_begin = 1;
318        msg_range_end = preferences.max_email_per_page;
319        if(current_page != 1) {
320                lnk_page = document.createElement("A");
321                lnk_page.setAttribute("href", "javascript:current_page=1;kill_current_box(); draw_paging("+num_msgs+"); proxy_mensagens.messages_list(get_current_folder(),"+msg_range_begin+","+msg_range_end+",'"+sort_box_type+"','"+search_box_type+"',"+sort_box_reverse+","+preferences.preview_msg_subject+","+preferences.preview_msg_tip+",function handler(data){draw_box.draw_newBox(data, get_current_folder());});");
322        }
323        else {
324                lnk_page = document.createElement("SPAN");
325        }
326        span_paging.appendChild(lnk_page);
327
328        lnk_page.innerHTML = "&lt;&lt;";
329        lnk_page.title = get_lang("First");
330        span_paging.innerHTML += "&nbsp;";
331
332        if(current_page == lastPage + numPages)
333                lastPage = current_page - 1;
334        else if((lastPage != 1 && lastPage == current_page) || current_page == total_pages)
335                lastPage = current_page - (numPages - 1);
336        else if(current_page == 1)
337                lastPage = 1;
338
339        if(lastPage < 1)
340                lastPage = 1;
341        else if(lastPage > 1 && (lastPage > (total_pages -(numPages - 1))))
342                lastPage = total_pages -(numPages - 1);
343
344        var     hasMarked = false;
345
346        for(i = lastPage; i <= total_pages; i++) {
347
348                if(current_page == i || (i == total_pages && !hasMarked)) {
349                        lnk_page = document.createElement("SPAN");
350                        span_paging.appendChild(lnk_page);
351                        lnk_page.innerHTML = "&nbsp;<b>"+i+"</b>&nbsp;";
352                        hasMarked = true;
353                        continue;
354                }
355                else{
356                        lnk_page = document.createElement("A");
357                        span_paging.appendChild(lnk_page);
358                        msg_range_begin = ((i*preferences.max_email_per_page)-(preferences.max_email_per_page-1));
359                        msg_range_end = (i*preferences.max_email_per_page);
360                        lnk_page.setAttribute("href", "javascript:current_page="+i+";kill_current_box(); draw_paging("+num_msgs+"); proxy_mensagens.messages_list(get_current_folder(),"+msg_range_begin+","+msg_range_end+",'"+sort_box_type+"','"+search_box_type+"',"+sort_box_reverse+","+preferences.preview_msg_subject+","+preferences.preview_msg_tip+",function handler(data){draw_box.draw_newBox(data, get_current_folder());});");
361                }
362
363                lnk_page.innerHTML = "&nbsp;...&nbsp;";
364
365                if(i == (lastPage + numPages))
366                        break;
367                else if(lastPage == 1 || i != lastPage)
368                        lnk_page.innerHTML = "&nbsp;"+i+"&nbsp;";
369
370                span_paging.innerHTML += "&nbsp;";
371        }
372
373        if(current_page != total_pages) {
374                lnk_page = document.createElement("A");
375                msg_range_begin = ((total_pages*preferences.max_email_per_page)-(preferences.max_email_per_page-1));
376                msg_range_end = (total_pages*preferences.max_email_per_page);
377                lnk_page.setAttribute("href", "javascript:current_page="+total_pages+";kill_current_box(); draw_paging("+num_msgs+"); proxy_mensagens.messages_list(get_current_folder(),"+msg_range_begin+","+msg_range_end+",'"+sort_box_type+"','"+search_box_type+"',"+sort_box_reverse+","+preferences.preview_msg_subject+","+preferences.preview_msg_tip+",function handler(data){draw_box.draw_newBox(data, get_current_folder());});");
378        }
379        else {
380                lnk_page = document.createElement("SPAN");
381        }
382        span_paging.innerHTML += "&nbsp;";
383        span_paging.appendChild(lnk_page);
384
385        lnk_page.title = get_lang("Last");
386        lnk_page.innerHTML = "&gt;&gt;";
387}
388
389
390function draw_tree_local_folders() {
391        /**
392         * Pastas locais
393         */
394        if(preferences.use_local_messages==1 || expresso_offline) {
395                var local_folders = expresso_local_messages.list_local_folders();
396                var has_changes = false;
397                for (var i in local_folders) { //Coloca as pastas locais.
398                        if(!isNaN(i)){
399                                var new_caption = local_folders[i][0];
400                                if(local_folders[i][0].indexOf("/")!="-1") {
401                                        final_pos = local_folders[i][0].lastIndexOf("/");
402                                        new_caption = local_folders[i][0].substr(final_pos+1);
403                                }
404
405                                var folder_unseen = Element('dftree_local_'+local_folders[i][0]+'_unseen');
406
407                                if ((folder_unseen) && (local_folders[i][1] > 0))
408                                {
409                                        folder_unseen.innerHTML = local_folders[i][1];
410                                        has_changes = true;
411                                }
412                                else if (local_folders[i][1] > 0)
413                                {
414                                        tree_folders.getNodeById("local_"+local_folders[i][0]).alter({
415caption: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>'
416});
417tree_folders.getNodeById("local_"+local_folders[i][0])._refresh();
418has_changes = true;
419}
420else if (local_folders[i][1] <= 0)
421{
422        tree_folders.getNodeById("local_"+local_folders[i][0]).alter({
423caption:lang_folder(new_caption)
424});
425tree_folders.getNodeById("local_"+local_folders[i][0])._refresh();
426has_changes = true;
427}
428
429        if("local_"+local_folders[i][0] == get_current_folder()){
430                var old_new_m = isNaN(parseInt(Element('new_m').innerHTML)) ? parseInt(Element('new_m').firstChild.innerHTML) : parseInt(Element('new_m').innerHTML);
431                if(!isNaN(old_new_m) && old_new_m < local_folders[i][1]){
432                        Element('tot_m').innerHTML = parseInt(Element('tot_m').innerHTML) + (parseInt(local_folders[i][1])-old_new_m);
433                }
434                Element('new_m').innerHTML = local_folders[i][1] ? '<font color="RED">'+local_folders[i][1]+'</font>' : 0;
435                draw_paging(Element('tot_m').innerHTML);
436                has_changes = true;
437                }
438        }
439}
440if(has_changes)
441        tree_folders.getNodeById("local_root").open();
442
443        }
444}
445
446function draw_tree_folders( folders )
447{
448        // Check if the tree folders alredy exist.
449        if ( ! Element( 'dftree_tree_folders' ) )
450        {
451                translatedFolders = new Map( );
452                if ( ! expresso_offline )
453                {
454                        tree_folders = new dFTree( {
455                                "name" : 'tree_folders'
456                        } );
457
458                        var n_root = new dNode( {
459                                "id" : 'root',
460                                "caption" : get_lang( "My Folders" )
461                        } );
462
463                        tree_folders.add( n_root, 'anything' ); //Places the root; second argument can be anything.
464
465                        var unseen_in_mailbox = 0;
466                        var unseen_in_shared_folders = 0;
467
468                        for ( var i = 0; i < folders.length; i++ )
469                        {
470                                if ( folders[ i ].folder_unseen > 0 )
471                                {
472                                        unseen_in_mailbox = parseInt( unseen_in_mailbox + folders[ i ].folder_unseen );
473                                        if ( folders[i].folder_id.indexOf( 'INBOX' ) !== 0 )
474                                                unseen_in_shared_folders = parseInt( unseen_in_shared_folders + folders[ i ].folder_unseen );
475
476                                        var nn = new dNode( {
477                                                "id" : folders[i].folder_id,
478                                                "caption" : lang_folder( folders[ i ].folder_name )
479                                                                        + '<font style=color:red>&nbsp(</font><span id="dftree_'
480                                                                        + folders[ i ].folder_id
481                                                                        + '_unseen" style=color:red>'
482                                                                        + folders[ i ].folder_unseen
483                                                                        + '</span><font style=color:red>)</font>',
484                                                "onClick" : "change_folder('" + folders[ i ].folder_id+"','" + folders[ i ].folder_name + "')",
485                                                "plusSign" : folders[ i ].folder_hasChildren
486                                        } );
487
488                                        if ( folders[ i ].folder_name.toLowerCase( ) == 'inbox' )
489                                                Element( 'new_m' ).innerHTML = '<font style="color:red">' + folders[ i ].folder_unseen + '</font>';
490                                }
491                                else
492                                        var nn = new dNode( {
493                                                "id" : folders[ i ].folder_id,
494                                                "caption" : lang_folder( folders[ i ].folder_name ),
495                                                "onClick" : "change_folder('" + folders[ i ].folder_id + "','" + folders[ i ].folder_name + "')",
496                                                "plusSign" : folders[ i ].folder_hasChildren
497                                        });
498
499                                if ( folders[ i ].folder_parent == '' )
500                                        folders[ i ].folder_parent = 'root';
501                                else
502                                {
503                                        if ( folders[ i ].folder_parent == 'user' && ( ! tree_folders.getNodeById( 'user' ) ) )
504                                        {
505                                                tmpFolderId = folders[ i ].folder_id.split( cyrus_delimiter ).pop( );
506                                                if ( tmpFolderId != folders[ i ].folder_name )
507                                                        translatedFolders.add( tmpFolderId, folders[ i ].folder_name );
508
509                                                var n_root_shared_folders = new dNode( {
510                                                        "id" : 'user',
511                                                        "caption" : get_lang( "Shared folders" ),
512                                                        "plusSign" : true
513                                                } );
514                                                tree_folders.add( n_root_shared_folders, 'root' );
515                                        }
516                                }
517                                tree_folders.add( nn, folders[ i ].folder_parent );
518                        }
519                }
520
521                /**
522                 * Pastas locais
523                 */
524                if (preferences.use_local_messages==1 || expresso_offline)
525                {
526                        if (!window.google || !google.gears) {
527                                if (!expresso_local_messages.installGears())
528                                        preferences.use_local_messages=0;
529                        }
530                        else{
531                                if (!window.google || !google.gears) {
532                                        temp = confirm(get_lang("To use local messages you have to install google gears. Would you like to be redirected to gears installation page?"));
533                                        if (temp) {
534                                                location.href = "http://gears.google.com/?action=install&message="+
535                                                        "Para utilizar o recurso de mensagens locais, instale o google gears&return=" +
536                                                        document.location.href;
537                                        }
538                                        else {
539                                                preferences.use_local_messages=0;
540                                        }
541                                }
542                                else{
543                                        if (expresso_offline)
544                                                tree_folders = new dFTree({
545                                                                "name" : 'tree_folders'
546                                                                });
547                                        var root_local = new dNode({
548                                                        "id" : "local_root",
549                                                        "caption" : get_lang('local folders')
550                                                        });
551                                        tree_folders.add(root_local, "root"); //coloca root local
552                                        var local_folders = expresso_local_messages.list_local_folders();
553                                        for (var i in local_folders) { //Coloca as pastas locais.
554                                                if(!isNaN(i)){
555                                                        var node_root = "local_root";
556                                                        var new_caption = local_folders[i][0];
557                                                        if (local_folders[i][0].indexOf("/") != "-1") {
558                                                                final_pos = local_folders[i][0].lastIndexOf("/");
559                                                                node_root = "local_" + local_folders[i][0].substr(0, final_pos);
560                                                                new_caption = local_folders[i][0].substr(final_pos + 1);
561                                                        }
562                                                        if (local_folders[i][1] > 0)
563                                                                var nodeLocal = new dNode({
564                                                                                "id": "local_" + local_folders[i][0],
565                                                                                "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>',
566                                                                                "onClick": "change_folder('local_" + local_folders[i][0] + "','" + new_caption + "')",
567                                                                                "plusSign": local_folders[i][2]
568                                                                                });
569                                                        else
570                                                                var nodeLocal = new dNode({
571                                                                                "id": "local_" + local_folders[i][0],
572                                                                                "caption": lang_folder(new_caption),
573                                                                                "onClick": "change_folder('local_" + local_folders[i][0] + "','" + new_caption + "')",
574                                                                                "plusSign": local_folders[i][2]
575                                                                                });
576                                                        tree_folders.add(nodeLocal, node_root);
577                                                }
578                                        }
579                                }
580                        }
581                }
582
583                tree_folders.draw( Element( 'content_folders' ) );
584                if ( ! expresso_offline )
585                {
586                        n_root.changeState( );
587                        folder_select = ( current_folder ? current_folder : "INBOX" );
588
589                        if ( typeof( tree_folders.getNodeById( folder_select ) ) == 'undefined' )
590                                return false;
591
592                        tree_folders.getNodeById( folder_select )._select( );
593                }
594                else
595                {
596                        root_local.changeState( );
597                        tree_folders.getNodeById( 'local_Inbox' )._select( );
598                }
599
600                var trash_span = document.getElementById( 'lINBOX/' + trashfolder + 'tree_folders' );
601                var draft_span = document.getElementById( 'lINBOX/' + draftsfolder + 'tree_folders' );
602                var sent_span = document.getElementById( 'lINBOX/' + sentfolder + 'tree_folders' );
603                var spam_span = document.getElementById( 'lINBOX/' + spamfolder + 'tree_folders' );
604
605                var folder_img = URL_SERVER + "phpgwapi/templates/" +template + "/images/foldertree_"
606
607                if ( trash_span )
608                        trash_span.style.backgroundImage = "url(" + folder_img + "trash.png)";
609
610                if ( draft_span )
611                        draft_span.style.backgroundImage = "url(" + folder_img + "draft.png)";
612
613                if ( sent_span )
614                        sent_span.style.backgroundImage = "url(" + folder_img + "sent.png)";
615
616                if ( spam_span )
617                        spam_span.style.backgroundImage = "url(" + folder_img + "spam.png)";
618
619
620                draw_paging( Element( 'tot_m' ).innerHTML );
621
622                if ( document.getElementById( "nINBOX/" + trashfolder + "tree_folders" ) )
623                {
624                        var trash = document.createElement( "SPAN" );
625                        trash.id = 'empty_trash';
626                        trash.className = 'clean_folder';
627                        trash.style.cursor = 'pointer';
628                        trash.onclick = function( )
629                        {
630                                empty_trash_imap( );
631                        };
632                        trash.innerHTML = "[" + get_lang( "Clean" ) + "]";
633                        trash.title = get_lang( "Empty trash" );
634                        trash.onmouseover = function( )
635                        {
636                                trash.style.color = "red";
637                        };
638                        trash.onmouseout= function( )
639                        {
640                                trash.style.color="#666666";
641                        };
642                        document.getElementById( "nINBOX/" + trashfolder + "tree_folders" ).appendChild( trash );
643                }
644                if ( document.getElementById( "nINBOX/" + spamfolder + "tree_folders" ) )
645                {
646                        var spam = document.createElement( "SPAN" );
647                        spam.id = 'empty_spam';
648                        spam.className = 'clean_folder';
649                        spam.style.cursor = 'pointer';
650                        spam.style.padding = '0 0 0 6px';
651                        spam.onclick = function( )
652                        {
653                                empty_spam_imap( );
654                        };
655                        spam.innerHTML = "[" + get_lang( "Clean" ) + "]";
656                        spam.title = get_lang( "Empty Spam Folder" );
657                        spam.onmouseover = function( )
658                        {
659                                spam.style.color = "red";
660                        };
661                        spam.onmouseout = function( )
662                        {
663                                spam.style.color = "#666666";
664                        };
665                        document.getElementById( "nINBOX/" + spamfolder + "tree_folders" ).appendChild( spam );
666                }
667
668                if ( ! expresso_offline )
669                        var display_unseen_in_mailbox = tree_folders.getNodeById( 'root' );
670                else
671                        var display_unseen_in_mailbox = tree_folders.getNodeById( 'local_root' );
672
673                display_unseen_in_mailbox.alter( {
674                        "caption" : get_lang( "My Folders" )
675                } );
676
677                display_unseen_in_mailbox._refresh( );
678
679                var display_unseen_in_shared_folders = tree_folders.getNodeById( 'user' );
680
681                if ( display_unseen_in_shared_folders )
682                {
683                        if ( unseen_in_shared_folders )
684                                display_unseen_in_shared_folders.alter( {
685                                        "caption" : '<font style=color:red>[</font><span id="dftree_user_unseen" style="color:red">'
686                                                                + unseen_in_shared_folders
687                                                                + '</span><font style=color:red>]</font> '
688                                                                + get_lang( "Shared folders" )
689                                } );
690                        else
691                                display_unseen_in_shared_folders.alter( {
692                                        "caption" : get_lang( "Shared folders" )
693                                } );
694
695                        display_unseen_in_shared_folders._refresh( );
696                }
697        }
698
699        if ( ! expresso_offline )
700        {
701                var folder_create = "";
702                var nm1 = "";
703                if ( tree_folders._folderPr.length > 0 )
704                {
705                        var nm_folder = "";
706                        for ( var i = 0; i < tree_folders._folderPr.length; i++ )
707                        {
708                                nm_folder = tree_folders._folderPr[ i ].split( cyrus_delimiter );
709                                if( nm_folder[ 0 ] == "INBOX" )
710                                {
711                                        if ( nm1 == "" )
712                                        {
713                                                nm1 = nm_folder[ 1 ];
714                                                folder_create = "INBOX" + cyrus_delimiter + nm_folder[ 1 ] + ";";
715                                        }
716                                        else
717                                        {
718                                                if ( nm1 != nm_folder[ 1 ] )
719                                                {
720                                                        folder_create += "INBOX" + cyrus_delimiter + nm_folder[ 1 ] + ";";
721                                                        nm1 = nm_folder[ 1 ];
722                                                }
723                                        }
724                                }
725                        }
726                }
727
728                if ( folder_create != "" )
729                {
730                        if ( confirm( get_lang( "There are folders with invalid format. Do you want to fix them?" ) ) )
731                        {
732                                var handler_correct_folders = function( data )
733                                {
734                                        //Timeout to release HTTPRequest , loadScript and update tree folders.
735                                        if ( data )
736                                                setTimeout( "expresso.connector.loadScript('jscode/TreeShow');ttreeBox.update_folder();", 500 );
737                                };
738                                cExecute( "expressoMail1_2.imap_functions.create_extra_mailbox", handler_correct_folders, "nw_folders=" + folder_create );
739                        }
740                }
741        }
742
743        Element( 'main_table' ).style.display = '';
744        draw_box.prepare_box( false );
745        resizeWindow( );
746}
747
748
749function update_menu(data){
750    /*
751         * @AUTHOR Rodrigo Souza dos Santos
752         * @DATE 2008/09/15
753         * @BRIEF When occurs a error in imap server show the message that is in file "error.html".
754         */
755    if ( data && data.imap_error )
756    {
757        if(preferences.use_local_messages==1 && expresso_local_messages.is_offline_installed){
758            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?"));
759            if(conf) {
760                window.onresize = function() {
761                    var target = document.getElementById('divAppbox');
762                    target.style.height= document.body.clientHeight - 83;
763                };
764                var target = document.getElementById('divAppbox');
765                document.getElementById("divAppboxHeader").innerHTML="";
766                target.style.height= document.body.clientHeight - 83;
767                expresso_local_messages.set_as_logged(account_id,0,true);
768                target.innerHTML = "<iframe src='offline.php?inside=1' width='100%' height='100%' frameBorder='0'></iframe>";
769                return false;
770            }
771        }
772        expresso.connector.newRequest('error.html', URL_SERVER + 'expressoMail1_2/templates/'+template+'/error.html', 'GET',
773            function(data)
774            {
775                var target = document.getElementById('divAppbox');
776                if ( target )
777                    target.innerHTML = data;
778            }
779            );
780        return false;
781    }
782
783    draw_tree_folders(data);
784    if(data) {
785        build_quota(data);
786        var f_unseen = Element('dftree_'+current_folder+'_unseen');
787        if(f_unseen && f_unseen.innerHTML)
788            Element('new_m').innerHTML = '<font face="Verdana" size="1" color="RED">'+f_unseen.innerHTML+'</font>';
789        else
790        {
791            if( parseInt(Element('new_m').innerHTML) == 0 )
792                Element('new_m').innerHTML = 0;
793        }
794        folders = data;
795    }
796}
797
798var handler_draw_box = function(data){
799    draw_box.draw_newBox( expresso.connector.unserialize( data ), 'INBOX', true);
800//alternate_border(0);
801};
802
803// Action on change folders.
804function change_folder(folder, folder_name){
805    alternate_border(numBox);
806    if (openTab.imapBox[numBox] != folder)
807    {
808        current_folder = folder;
809        draw_box.prepare_box(true);
810        Element("border_id_0").innerHTML = "&nbsp;" + lang_folder(folder_name) + '&nbsp;<font face="Verdana" size="1" color="#505050">[<span id="new_m">0</span> / <span id="tot_m">0</span>]</font>';
811        var handler_draw_box = function(data)
812        {
813                draw_box.headers_msgs = data;
814                draw_box.draw_box_messages(data, folder, true);
815                draw_paging(data.num_msgs);
816                Element("tot_m").innerHTML = data.num_msgs;
817                Element("new_m").innerHTML = '<font style="color:'+(data.num_unseen > 0 ? 'red': '')+'">' + data.num_unseen + '</font>';
818                folder_unseen = Element('dftree_'+current_folder+'_unseen');
819                var num_unseen = data.num_unseen;
820                if (folder_unseen)
821                        num_unseen -= folder_unseen.innerHTML;
822                increment_folder_unseen(num_unseen);
823                update_menu();
824                return true;
825        };
826        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);
827    }
828}
829
830function open_folder(folder, folder_name){
831    if (current_folder!= folder) {
832        current_folder = folder;
833        var handler_draw_box = function(data){
834            numBox++;
835            create_border(folder_name,numBox.toString());
836            draw_box.draw_newBox(data, current_folder);
837            alternate_border(numBox);
838            return true;
839        };
840        cExecute ("expressoMail1_2.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);
841    }
842    else
843        alternate_border(numBox);
844    return true;
845}
846
847function sort_box(search, sort){
848    var message_header = Element("message_header_"+search);
849    var handler_draw_box = function(data){
850        draw_box.headers_msgs = data;
851        draw_box.draw_box_messages(current_folder);
852
853        draw_paging(Element('tot_m').innerHTML);
854        //Mostrar as msgs nao lidas de acordo com o filtro de relevancia
855        var msgs_unseen = 0;
856        for(i in data){
857            if(data[i].Unseen == 'U')
858                msgs_unseen++;
859        }
860        Element("new_m").innerHTML = '<font style="color:'+(msgs_unseen == 0 ? '': 'red')+'">' + msgs_unseen + '</font>';
861    };
862
863    if(sort_box_type == sort && search_box_type == search){
864        sort_box_reverse = sort_box_reverse ? 0 : 1;
865    }
866    else if(sort_box_type != sort){
867        if ( (sort == 'SORTFROM') || (sort == 'SORTSUBJECT') )
868            sort_box_reverse = 0;
869        else
870            sort_box_reverse = 1;
871    }
872
873    // Global variable.
874    sort_box_type = sort;
875    search_box_type = search;
876
877    draw_box.prepare_box(true);
878    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);
879    current_page = 1;
880//Comentado para nao sobrepor o numero de msgs nao lidas ao utilizar os filtros
881//update_menu();
882}
883
884function make_tr_message(headers_msgs, msg_folder)
885{
886        if ( InfoContact == null )
887                InfoContact = new emInfoContact();
888
889        var tr_element = document.createElement('tr');
890        tr_element.style.height = preferences.line_height;
891        tr_element.id = headers_msgs.msg_number;
892
893        tr_element.msg_sample = "";
894        //if(headers_msgs.msg_sample && headers_msgs.msg_sample.preview_msg_subject != "")
895        if(headers_msgs.msg_sample && preferences.preview_msg_subject == "1")
896        {
897                tr_element.msg_sample = headers_msgs.msg_sample.body.substr(0,120) + "..."; //trecho do body que sera exibido com o assunto;
898        }
899        tr_element.tip = "";
900        if(headers_msgs.msg_sample && preferences.preview_msg_tip == "1")
901        {
902                tr_element.tip = headers_msgs.msg_sample.body.substr(3,300) + "..."; //trecho do body que sera exibido no tool-tip;
903        }
904
905        if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N')){
906                if ((headers_msgs.Flagged == 'F') || (headers_msgs.Importance.toLowerCase().indexOf("high")!=-1 && parseInt(preferences.use_important_flag)))
907                        add_className(tr_element, 'flagged_msg');
908                add_className(tr_element, 'tr_msg_unread');
909        }
910        else{
911                if ((headers_msgs.Flagged == 'F') || (headers_msgs.Importance.toLowerCase().indexOf("high")!=-1 && parseInt(preferences.use_important_flag)))
912                        add_className(tr_element,'flagged_msg');
913        }
914
915        if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N'))
916                add_className(tr_element, 'tr_msg_unread');
917
918        if (headers_msgs.Flagged == 'F')
919                add_className(tr_element,'flagged_msg');
920
921        td_element1 = createAndSet("TD",['class','width'],['td_msg','1%']);
922        _chkbox = createAndSet("INPUT", ['type','class','id'], ['checkbox','checkbox',"check_box_message_"+headers_msgs.msg_number]);
923        _chkbox.onclick = function(e){
924                if (is_ie)
925                        changeBgColor(window.event,headers_msgs.msg_number);
926                else
927                        changeBgColor(e,headers_msgs.msg_number);
928        };
929        td_element1.appendChild(_chkbox);
930
931        td_element2 = document.createElement("TD");
932        td_element2.className = "td_msg";
933        td_element2.setAttribute("width", "2%");
934        if (headers_msgs.attachment && headers_msgs.attachment.number_attachments > 0)
935                td_element2.innerHTML = '<img src ="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/clip.gif" title="' + url_decode(headers_msgs.attachment.names) + '">';
936
937        td_element21 = document.createElement("TD");
938        td_element21.className = "td_msg";
939        td_element21.setAttribute("width", "1%");
940        td_element21.id = "td_message_answered_"+headers_msgs.msg_number;
941
942        if (headers_msgs.attachment && headers_msgs.attachment.number_attachments > 0) {
943                attach_name = headers_msgs.attachment.names.split(", ");
944                for(var item=0; item < attach_name.length; item++)
945                {
946                        if (url_decode(attach_name[item]) != 'smime.p7s' && url_decode(attach_name[item]) != 'smime.p7m'){
947                                td_element21.innerHTML = '<img src ="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/clip.gif" title="' + url_decode(attach_name[item]) + '">';
948                                break;
949                        }
950                }
951        }
952
953        if ((headers_msgs.Forwarded == 'F')  || (headers_msgs.Draft == 'X' && headers_msgs.Answered == 'A')){
954                td_element21.innerHTML = '<img src ="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/forwarded.gif" title="'+get_lang('Forwarded')+'">';
955                headers_msgs.Draft = '';
956                headers_msgs.Answered = '';
957        }
958        else if (headers_msgs.Draft == 'X')
959                td_element21.innerHTML = '<img src ="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/draft.gif" title="'+get_lang('Draft')+'">';
960        else if (headers_msgs.Answered == 'A')
961                td_element21.innerHTML = '<img src ="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/answered.gif" title="'+get_lang('Answered')+'">';
962        else
963                td_element21.innerHTML = "&nbsp;&nbsp;&nbsp;";
964
965        td_element22 = document.createElement("TD");
966        td_element22.className = "td_msg";
967        td_element22.setAttribute("width", "1%");
968        td_element22.id = "td_message_signed_"+headers_msgs.msg_number;
969
970        switch(headers_msgs.ContentType)
971        {
972                case "signature":
973                {
974                        td_element22.innerHTML = '<img src ="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/signed_msg.gif" title="' + get_lang('Signed message') + '">';
975                        break;
976                }
977                case "cipher":
978                {
979                        td_element22.innerHTML = '<img src ="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/lock.gif" title="' + get_lang('Crypted message') + '">';
980                        break;
981                }
982                default:
983                {
984                        break;
985                }
986        };
987
988        td_element23 = document.createElement("TD");
989        td_element23.className = "td_msg";
990        td_element23.setAttribute("width", "1%");
991        td_element23.id = "td_message_important_"+headers_msgs.msg_number;
992
993        if (headers_msgs.Flagged == 'F' || (parseInt(preferences.use_important_flag) && headers_msgs.Importance.toLowerCase().indexOf("high") != -1))
994        {
995                td_element23.innerHTML = '<img src ="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/important.gif" title="'+get_lang('Important')+'">';
996        }
997        else
998                td_element23.innerHTML = "&nbsp;&nbsp;&nbsp;";
999
1000        td_element24 = document.createElement("TD");
1001        td_element24.className = "td_msg";
1002        td_element24.setAttribute("width", "1%");
1003        td_element24.id = "td_message_sent_"+headers_msgs.msg_number;
1004        td_element24.innerHTML = "&nbsp;&nbsp;&nbsp;";
1005        // preload images
1006        var _img_sent = new Image();
1007        _img_sent.src   = URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/sent.gif';
1008        var _img_unseen = new Image();
1009        _img_unseen.src = URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/unseen.gif';
1010
1011        var td_element25 = document.createElement("TD");
1012        td_element25.className = "td_msg";
1013        td_element25.setAttribute("width", "1%");
1014        td_element25.id = "td_message_unseen_"+headers_msgs.msg_number;
1015        if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N'))
1016                td_element25.innerHTML = "<img src ='"+_img_unseen.src+"' title='"+get_lang('Unseen')+"'>";
1017        else
1018                td_element25.innerHTML = "<img src ='"+URL_SERVER +"expressoMail1_2/templates/"+template+"/images/seen.gif' title='"+get_lang('Seen')+"'>";
1019
1020        td_element3 = document.createElement("TD");
1021        td_element3.className = "td_msg";
1022        td_element3.id = "td_who_"+ headers_msgs.msg_number;
1023        td_element3.setAttribute("width", "20%");
1024        var _onclick = function(){
1025                InfoContact.hide();proxy_mensagens.get_msg(headers_msgs, msg_folder,true, show_msg);
1026        };
1027        td_element3.onclick = _onclick;
1028        td_element3.innerHTML = '&nbsp;';
1029
1030        if (typeof(headers_msgs.from) == 'undefined')
1031                return false;
1032        if(headers_msgs.from.email.toLowerCase() == Element("user_email").value)
1033        {
1034                td_element3.onmouseover = function () {
1035                        this.title=headers_msgs.to.email;
1036                };
1037                if (headers_msgs.Draft == 'X')
1038                        td_element3.innerHTML += "<span style=\"color:red\">("+get_lang("Draft")+") </span>";
1039                else{
1040                        if(headers_msgs.to.email != null && headers_msgs.to.email.toLowerCase() != Element("user_email").value)
1041                                td_element24.innerHTML = '<img valign="center" src ="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/sent.gif" title="'+get_lang('Sent')+'">';
1042
1043                        if ((headers_msgs.to)&&(headers_msgs.to.name != null))
1044                                td_element3.innerHTML += headers_msgs.to.name;
1045                        else if (headers_msgs.to){
1046                                td_element3.innerHTML += headers_msgs.to.email;
1047                        }
1048                }
1049        }
1050        else{
1051                if (headers_msgs.Draft == 'X'){
1052                        td_element3.innerHTML = "<span style=\"color:red\">("+get_lang("Draft")+") </span>";
1053                }
1054                else{
1055                        var spanSender = document.createElement("SPAN");
1056                        spanSender.onmouseover = function (event) {
1057                                this.style.textDecoration = "underline";try {
1058                                        InfoContact.begin(this,headers_msgs.from.email)
1059                                } catch(e){};
1060                        };
1061                        spanSender.onmouseout = function (){
1062                                try {
1063                                        this.style.textDecoration = "none"; clearTimeout(InfoContact.timeout);
1064                                } catch(e){}
1065                        };
1066                        spanSender.innerHTML =  headers_msgs.from.name != null ? headers_msgs.from.name : headers_msgs.from.email;
1067                        if (spanSender.innerHTML.indexOf(" ") == '-1' && spanSender.innerHTML.length > 25){
1068                                spanSender.innerHTML = spanSender.innerHTML.substring(0,25) + "...";
1069                        }
1070                        else if (spanSender.innerHTML.length > 40 ){
1071                                spanSender.innerHTML = spanSender.innerHTML.substring(0,40) + "...";
1072                        }
1073                        td_element3.appendChild(spanSender);
1074                }
1075        }
1076        td_element4 = document.createElement("TD");
1077        td_element4.className = "td_msg";
1078        td_element4.setAttribute("width", "50%");
1079        td_element4.onclick = _onclick;
1080        //              td_element4.setAttribute("style","white-space:nowrap;");
1081        td_element4.innerHTML = !is_ie ? "<a nowrap id='a_message_"+tr_element.id+"'>&nbsp;" : "&nbsp;";
1082
1083        if ((headers_msgs.subject)&&(headers_msgs.subject.length > 50))
1084        {
1085                //                      if( (headers_msgs.subject.length+tr_element.msg_sample.length)>
1086                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;
1087        }
1088        else
1089        {
1090                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;
1091        }
1092
1093        td_element4.title=tr_element.tip;
1094        if(!is_ie){
1095                td_element4.innerHTML += "</a>";
1096        }
1097
1098
1099        td_element5 = document.createElement("TD");
1100        td_element5.className = "td_msg";
1101        td_element5.setAttribute("width", "14%");
1102        td_element5.onclick = _onclick;
1103        td_element5.setAttribute("align", "center");
1104        td_element5.innerHTML = headers_msgs.udate;
1105
1106        td_element6 = document.createElement("TD");
1107        td_element6.className = "td_msg";
1108        td_element6.setAttribute("width", "14%");
1109        td_element6.setAttribute("noWrap","true");
1110        td_element6.setAttribute("align", "center");
1111        td_element6.onclick = _onclick;
1112
1113        td_element6.innerHTML = borkb(headers_msgs.Size);
1114
1115        return appendChilds(tr_element,td_element1,td_element2,td_element21,td_element22,td_element23,td_element24,td_element25,td_element3,td_element4,td_element5,td_element6);
1116}
1117function draw_folder(){
1118}
1119
1120draw_folder.prototype.draw_newBox = function(headers_msgs,msg_folder,alternate){
1121        this.headers_msgs = headers_msgs;
1122        this.prepare_box( alternate );
1123        this.draw_box_messages(headers_msgs,msg_folder);
1124}
1125
1126draw_folder.prototype.prepare_box = function(alternate){
1127        if (alternate)
1128                kill_current_box();
1129
1130        if(is_ie)
1131                document.getElementById("border_table").width = "99.5%";
1132
1133        openTab.content_id[numBox] = document.getElementById("content_id_"+numBox);
1134        openTab.type[numBox] = 0;
1135        table_message_header_box = Element("table_message_header_box_"+numBox);
1136        if (table_message_header_box == null){
1137                var table_element = document.createElement("TABLE");
1138                table_element.setAttribute("id", "table_message_header_box_"+numBox);
1139                table_element.setAttribute('class',  "table_message_header_box");
1140
1141                var tbody_element = document.createElement("TBODY");
1142
1143                tr_element = createAndSet("TR",['class'],['message_header']);
1144                td_element1 = createAndSet("TD",['width'],['1%']);
1145                _chkbox_element = createAndSet("INPUT",['id','type','class'],["chk_box_select_all_messages","checkbox","checkbox"]);
1146                _chkbox_element.onclick = function(){
1147                        select_all_messages(this.checked);
1148                };
1149                _chkbox_element.onmouseover = function () {
1150                        this.title=get_lang('Select all messages.');
1151                };
1152                _chkbox_element.onkeydown = function (e){
1153                        if (is_ie)
1154                        {
1155                                if ((window.event.keyCode) == 46)
1156                                        proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
1157                        }
1158                        else
1159                        {
1160                                if ((e.keyCode) == 46)
1161                                        proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
1162                        }
1163                };
1164
1165                td_element1.appendChild(_chkbox_element);
1166
1167                td_element2 = document.createElement("TD");
1168                td_element2.setAttribute("width", "7%");
1169                td_element3 = createAndSet("TD",['width','id','align'],['29%',"message_header_SORTFROM_"+numBox,'left'],get_lang("Who"));
1170                td_element3.onclick = function () {
1171                        sort_box(search_box_type,'SORTFROM');
1172                };
1173                td_element4 = createAndSet("TD",['width','id','align'],['38%',"message_header_SORTSUBJECT_"+numBox,"left"],get_lang("Subject"));
1174                td_element4.onclick = function () {
1175                        sort_box(search_box_type,'SORTSUBJECT');
1176                };
1177                td_element5 = createAndSet("TD",['width','id','align'],["14%","message_header_SORTARRIVAL_"+numBox,"center"],get_lang("Date"));
1178                td_element5.onclick = function () {
1179                        sort_box(search_box_type,'SORTARRIVAL');
1180                };
1181                td_element6 = createAndSet("TD",['width','id','align'],["14%","message_header_SORTSIZE_"+numBox,"left"],get_lang("Size"));
1182                td_element6.onclick = function () {
1183                        sort_box(search_box_type,'SORTSIZE');
1184                };
1185                appendChilds(tr_element,td_element1,td_element2);
1186                var td_element21 = document.createElement("TD");
1187                td_element21.innerHTML = "&nbsp;&nbsp;&nbsp;";
1188                var td_element22 = document.createElement("TD");
1189                td_element22.innerHTML = "&nbsp;&nbsp;&nbsp;";
1190                var td_element23 = document.createElement("TD");
1191                td_element23.innerHTML = "&nbsp;&nbsp;";
1192
1193                tbody_element.appendChild(appendChilds(tr_element,td_element21,td_element22,td_element23,td_element3,td_element4,td_element5,td_element6));
1194                table_element.appendChild(tbody_element);
1195                openTab.content_id[numBox].appendChild(table_element);
1196        }
1197        draw_header_box();
1198        var _divScroll = document.getElementById("divScrollMain_"+numBox);
1199        if(!_divScroll){
1200                _divScroll = document.createElement("DIV");
1201                _divScroll.id = "divScrollMain_"+numBox;
1202        }
1203
1204        _divScroll.style.overflowY = "auto";
1205        _divScroll.style.overflowX = "hidden";
1206        _divScroll.style.width  ="100%";
1207
1208        var _t_element = createAndSet("TABLE",['id','class','borderColorDark','frame','rules','cellPadding','cellSpacing'],["table_box","table_box","#bbbbbb","void","rows","0","0"]);
1209        _t_element.onkeydown = function (e){
1210                if (is_ie)
1211                {
1212                        if ((window.event.keyCode) == 46)
1213                        {
1214                                //delete_all_selected_msgs_imap();
1215                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
1216                        }
1217                }
1218                else
1219                {
1220                        if ((e.keyCode) == 46)
1221                        {
1222                                //delete_all_selected_msgs_imap();
1223                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
1224                        }
1225                }
1226        };
1227        if (is_ie)
1228                _t_element.style.cursor = "hand";
1229
1230        var _tbody_element = document.createElement("TBODY");
1231        _tbody_element.setAttribute("id", "tbody_box");
1232        _t_element.appendChild(_tbody_element);
1233
1234        _divScroll.appendChild(_t_element);
1235
1236        openTab.content_id[numBox].appendChild(_divScroll);
1237        _divScroll.appendChild(loading_img);
1238};
1239
1240draw_folder.prototype.draw_box_messages = function(msg_folder){
1241        openTab.content_id[numBox] = document.getElementById("content_id_"+numBox);
1242        var _divScroll = document.getElementById("divScrollMain_"+numBox);
1243        _divScroll.removeChild(_divScroll.lastChild);
1244        var tbody_element = _divScroll.firstChild.firstChild;
1245
1246        var f_unseen = 0;
1247        openTab.imapBox[numBox] = msg_folder;
1248        if (this.headers_msgs.num_msgs == 0){
1249                var tr_info = document.createElement("TR");
1250                var td_info = createAndSet("TD",['colspan','background','align','style'],
1251                                ['10','#FFF','center','padding-top: 25px;font-weight:bold;font-size:11pt;'],get_lang("This mail box is empty"));
1252                tr_info.setAttribute("id", "msg_info");
1253                tr_info.appendChild(td_info);
1254                tbody_element.appendChild(tr_info);
1255        }
1256
1257
1258        for (var i=0; i < this.headers_msgs.length; i++){
1259                if ((this.headers_msgs[i].Unseen == 'U') || (this.headers_msgs[i].Recent == 'N'))
1260                        f_unseen++;
1261                tr_element = make_tr_message(this.headers_msgs[i], msg_folder);
1262                if (tr_element){
1263                        tbody_element.appendChild(tr_element);
1264                        add_className(tr_element, i%2 != 0 ? 'tr_msg_read2' : 'tr_msg_read');
1265                }
1266                if ( _dragArea == null )
1267                        _dragArea = new DragArea( );
1268                _dragArea.makeDragged(tr_element, this.headers_msgs[i].msg_number, this.headers_msgs[i].subject, true);
1269        }
1270
1271        if ((preferences.use_shortcuts == '1') && (this.headers_msgs[0]))
1272                select_msg(this.headers_msgs[0].msg_number, 'null', true);
1273
1274        var tdFolders  =  Element("folderscol");
1275        tdFolders.style.display = preferences.hide_folders == '1'  ? "none" : "";
1276        draw_footer_box(this.headers_msgs.num_msgs);
1277        Element('main_table').style.display = '';
1278        if(is_ie6)      // Stupid Fixing on IE6.
1279                setTimeout("resizeWindow()",1);
1280        else
1281                resizeWindow();
1282        if(debug) {
1283                var _eTime = new Date();
1284                _eTime = _eTime.getTime();
1285                alert("Carregou em "+(_eTime - _bTime)+" ms");
1286        }
1287        var msg_folder = Element('msg_folder').value;
1288        var msg_number = Element('msg_number').value;
1289        if(!msg_folder && msg_number) {
1290                new_message('new','null');
1291        }
1292        else if(msg_folder && msg_number){
1293                proxy_mensagens.get_msg(this.headers_msgs, url_encode(msg_folder),true, show_msg);
1294                Element('msg_folder').value = '';
1295                Element('msg_number').value = '';
1296        }
1297
1298        if(!is_ie) {
1299                var scripts = new Array("jscode/ccQuickAdd",
1300                                "jscode/color_palette",
1301                                "jscode/filter",
1302                                "jscode/filters",
1303                                "jscode/html2xhtml",
1304                                "jscode/preferences",
1305                                "jscode/QuickCatalogSearch",
1306                                "jscode/QuickSearchUser",
1307                                "jscode/rich_text_editor",
1308                                "jscode/sharemailbox",
1309                                "jscode/search",
1310                                "jscode/TreeS",
1311                                "jscode/TreeShow");
1312
1313                expresso.connector.loadAllScripts(scripts);
1314        }
1315        // Loading Quota View Folder Component (if exists...)
1316        if(Element("table_quota"))
1317                expresso.connector.loadScript("jscode/InfoQuota");
1318        alternate_border(numBox);
1319};
1320
1321draw_box = new draw_folder();
Note: See TracBrowser for help on using the repository browser.