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

Revision 569, 90.8 KB checked in by niltonneto, 15 years ago (diff)

Resolve #379

  • Property svn:eol-style set to native
  • Property svn:executable set to *
Line 
1var openBox = {
2        'content_id' : [],
3        'tab_folder' : []
4 };
5var numBox = 0; // Open Mailboxes at context
6
7function draw_tree_folders(folders){
8        // Check if the tree folders alredy exist.
9
10        if (Element('dftree_tree_folders')){
11                var update_tree_folders = function(data){
12                        build_quota(data);
13                        for (var i=0; i<data.length; i++){
14                                var folder_unseen = Element('dftree_'+data[i].folder_id+'_unseen');
15                               
16                                if ((folder_unseen) && (data[i].folder_unseen > 0))
17                                {
18                                        folder_unseen.innerHTML = data[i].folder_unseen;
19                                }
20                                else if (data[i].folder_unseen > 0)
21                                {
22                                        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>'});
23                                        tree_folders.getNodeById(data[i].folder_id)._refresh();
24                                }
25                                else if (data[i].folder_unseen <= 0)
26                                {
27                                        tree_folders.getNodeById(data[i].folder_id).alter({caption:lang_folder(data[i].folder_name)});
28                                        tree_folders.getNodeById(data[i].folder_id)._refresh();
29                                }
30
31                                if(data[i].folder_id == get_current_folder()){                                 
32                                        var old_new_m = isNaN(parseInt(Element('new_m').innerHTML)) ? parseInt(Element('new_m').firstChild.innerHTML) : parseInt(Element('new_m').innerHTML);
33//                                      if(!isNaN(old_new_m) && old_new_m < data[i].folder_unseen){
34//                                              Element('tot_m').innerHTML = parseInt(Element('tot_m').innerHTML) + (parseInt(data[i].folder_unseen)-old_new_m);
35//                                      }
36                                        Element('new_m').innerHTML = data[i].folder_unseen ? '<font color="RED">'+data[i].folder_unseen+'</font>' : 0;
37                                        draw_paging(Element('tot_m').innerHTML);
38                                }
39                        }
40                }
41                cExecute ("$this.imap_functions.get_folders_list", update_tree_folders);
42                return;
43        }
44        else{
45                tree_folders = new dFTree({name: 'tree_folders'});
46
47                var n_root = new dNode({id:'root', caption: get_lang("My Folders")});
48                tree_folders.add(n_root,'anything'); //Places the root; second argument can be anything.
49       
50                for (var i=0; i<folders.length; i++){
51                        if (folders[i].folder_unseen > 0)
52                        {
53                                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});
54                               
55                                if( folders[i].folder_name.toLowerCase() == 'inbox' )
56                                        Element('new_m').innerHTML = '<font style="color:red">' + folders[i].folder_unseen + '</font>';
57                        }
58                        else
59                                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});
60                       
61                        if (folders[i].folder_parent == '')
62                                folders[i].folder_parent = 'root';
63                        else if (folders[i].folder_parent == 'user'){
64                                if (!tree_folders.getNodeById('user')){
65                                        var n_root_shared_folders = new dNode({id:'user', caption:get_lang("Shared folders"), plusSign:true});
66                                        tree_folders.add(n_root_shared_folders,'root');
67                                }
68                        }
69                        tree_folders.add(nn,folders[i].folder_parent);
70                }
71                tree_folders.draw(Element('content_folders'));
72                n_root.changeState();
73                tree_folders.getNodeById('INBOX')._select();           
74                draw_paging(Element('tot_m').innerHTML);
75                // Draw right menu folders.
76                /*
77                var treeroot = document.getElementById('chroottree_folders');
78                for (var linkBox = treeroot.firstChild; linkBox != null; linkBox = linkBox.nextSibling)
79                        _dragArea.makeMenuBox(linkBox);
80                */
81        }
82       
83        var folder_create = "";
84        var nm1 = "";
85        if(tree_folders._folderPr.length > 0){
86                var nm_folder = "";
87                for(var i=0; i < tree_folders._folderPr.length; i++){
88                        nm_folder = tree_folders._folderPr[i].split(cyrus_delimiter);
89                        if(nm_folder[0] == "INBOX"){
90                                if(nm1 == ""){
91                                        nm1 = nm_folder[1];
92                                        folder_create = "INBOX" + cyrus_delimiter + nm_folder[1] + ";";
93                                }else{
94                                        if( nm1 != nm_folder[1]){
95                                                folder_create += "INBOX" + cyrus_delimiter + nm_folder[1] + ";";
96                                                nm1 = nm_folder[1];
97                                        }
98                                }
99                        }
100                }
101        }
102        if(folder_create != ""){
103                if(confirm(get_lang("There are folders with invalid format. Do you want to fix them?"))){
104                        var handler_correct_folders = function(data){
105                                //Timeout to release HTTPRequest , loadScript and update tree folders.
106                                if(data)
107                                        setTimeout("connector.loadScript('TreeShow');ttreeBox.update_folder();",500);
108                        }
109                        cExecute("$this.imap_functions.create_extra_mailbox",handler_correct_folders,"nw_folders="+folder_create);
110                }
111        }
112}
113
114function update_menu(data){
115                /*
116                 * @AUTHOR Rodrigo Souza dos Santos
117                 * @DATE 2008/09/15
118                 * @BRIEF When occurs a error in imap server show the message that is in file "error.html".
119                 */
120                if ( data && data.imap_error )
121                {
122                        connector.newRequest('error.html', 'templates/default/error.html', 'GET',
123                                function(data)
124                                {
125                                        var target = document.getElementById('divAppbox');
126                                        if ( target )
127                                                target.innerHTML = data;
128                                }
129                        );
130                        return false;
131                }
132
133                draw_tree_folders(data);
134                if(data) {
135                        build_quota(data);                     
136                        var f_unseen = Element('dftree_'+get_current_folder()+'_unseen');
137                        if(f_unseen && f_unseen.innerHTML)
138                                Element('new_m').innerHTML = '<font face="Verdana" size="1" color="RED">'+f_unseen.innerHTML+'</font>';
139                        else
140                        {
141                                if( parseInt(Element('new_m').innerHTML) == 0 )
142                                        Element('new_m').innerHTML = 0;                 
143                        }
144                        folders = data;
145                        cExecute ("$this.imap_functions.get_range_msgs2&folder=INBOX&msg_range_begin=1&msg_range_end="+preferences.max_email_per_page+"&sort_box_type=SORTARRIVAL&sort_box_reverse=1", handler_draw_box);
146                }
147}
148
149var handler_draw_box = function(data){
150        draw_box(data, 'INBOX', true);
151        //alternate_border(0);
152}
153
154// Action on change folders.
155function change_folder(folder, folder_name){
156        if (openBox.tab_folder[0] != folder)
157        {
158                current_folder = folder;
159                var handler_draw_box = function(data)
160                {
161                        if(!verify_session(data))
162                                return;
163                        alternate_border(0);
164                        Element("border_id_0").innerHTML = "&nbsp;" + lang_folder(folder_name) + '&nbsp;<font face="Verdana" size="1" color="#505050">[<span id="new_m">&nbsp;</span> / <span id="tot_m"></span>]</font>';
165                        draw_box(data, folder, true);
166                        draw_paging(data.num_msgs);
167                        Element("tot_m").innerHTML = data.num_msgs;
168                        update_menu();
169                        return true;
170                }
171                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);
172        } else
173                alternate_border(0);
174}
175
176function open_folder(folder, folder_name){
177        if (get_current_folder()!= folder) {
178                current_folder = folder;
179                var handler_draw_box = function(data){
180                        if(!verify_session(data))
181                                return false;
182                        numBox++;
183                        create_border(folder_name,numBox.toString());
184                        draw_box(data, current_folder, false);
185                        alternate_border(numBox);
186                        return true;
187                }
188                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);
189        }
190        else
191                alternate_border(numBox);
192        return true;
193}
194
195var lastPage = 1;
196var numPages = 5;
197var last_folder = 'INBOX';
198function draw_paging(num_msgs){
199        num_msgs = parseInt(num_msgs);
200        total_pages = 1;
201
202        if(last_folder != get_current_folder()){
203                lastPage = 1;
204                current_page = 1;
205                last_folder = get_current_folder();
206        }
207
208        if(num_msgs > parseInt(preferences.max_email_per_page)) {       
209                total_pages = parseInt(num_msgs/preferences.max_email_per_page);
210                if((num_msgs/preferences.max_email_per_page) > total_pages)
211                        total_pages++;                 
212        }
213
214        if(total_pages == 1) {
215                if(span_paging = document.getElementById("span_paging")) {
216                        span_paging.parentNode.removeChild(span_paging);
217                }
218                return;
219        }
220       
221        span_paging = document.getElementById("span_paging");
222        if(!span_paging){
223                span_paging = document.createElement("DIV");
224                span_paging.id = "span_paging";
225                span_paging.align="right";
226                document.getElementById("div_menu_c3").appendChild(span_paging);       
227        }
228        span_paging.style.width="100%";                                 
229        span_paging.innerHTML="";
230        msg_range_begin = 1;
231        msg_range_end = preferences.max_email_per_page;
232        if(current_page != 1) {
233                lnk_page = document.createElement("A");
234                lnk_page.setAttribute("href", "javascript:current_page=1;kill_current_box(); draw_paging("+num_msgs+"); cExecute ('$this.imap_functions.get_range_msgs2&folder='+get_current_folder()+'&msg_range_begin="+msg_range_begin+"&msg_range_end="+msg_range_end+"&sort_box_type="+sort_box_type+ "&search_box_type="+ search_box_type +"&sort_box_reverse="+sort_box_reverse+"', function handler(data){draw_box(data, get_current_folder());})");
235        }
236        else {
237                lnk_page = document.createElement("SPAN");
238        }
239        span_paging.appendChild(lnk_page);
240
241        lnk_page.innerHTML = "&lt;&lt;";
242        lnk_page.title = get_lang("First");
243        span_paging.innerHTML += "&nbsp;";
244               
245        if(current_page == lastPage + numPages)
246                lastPage = current_page - 1;           
247        else if((lastPage != 1 && lastPage == current_page) || current_page == total_pages)             
248                lastPage = current_page - (numPages - 1);
249        else if(current_page == 1)
250                lastPage = 1;
251
252        if(lastPage < 1)
253                lastPage = 1;
254        else if(lastPage > 1 && (lastPage > (total_pages -(numPages - 1))))
255                lastPage = total_pages -(numPages - 1);
256
257        var     hasMarked = false;
258
259        for(i = lastPage; i <= total_pages; i++) {
260                       
261                if(current_page == i || (i == total_pages && !hasMarked)) {                     
262                        lnk_page = document.createElement("SPAN");
263                        span_paging.appendChild(lnk_page);
264                        lnk_page.innerHTML = "&nbsp;<b>"+i+"</b>&nbsp;";
265                        hasMarked = true;
266                        continue;
267                }
268                else{                   
269                        lnk_page = document.createElement("A");
270                        span_paging.appendChild(lnk_page);
271                        msg_range_begin = ((i*preferences.max_email_per_page)-(preferences.max_email_per_page-1));
272                        msg_range_end = (i*preferences.max_email_per_page);
273                        lnk_page.setAttribute("href", "javascript:current_page="+i+";kill_current_box(); draw_paging("+num_msgs+"); cExecute ('$this.imap_functions.get_range_msgs2&folder='+get_current_folder()+'&msg_range_begin="+msg_range_begin+"&msg_range_end="+msg_range_end+"&sort_box_type="+sort_box_type+ "&search_box_type="+ search_box_type +"&sort_box_reverse="+sort_box_reverse+"', function handler(data){draw_box(data, get_current_folder());})");
274                }
275               
276                lnk_page.innerHTML = "&nbsp;...&nbsp;";
277               
278                if(i == (lastPage + numPages))
279                                break;                 
280                else if(lastPage == 1 || i != lastPage)                                                 
281                        lnk_page.innerHTML = "&nbsp;"+i+"&nbsp;";
282               
283                span_paging.innerHTML += "&nbsp;";                                                                                                                                                                     
284        }
285       
286        if(current_page != total_pages) {
287                lnk_page = document.createElement("A");
288                msg_range_begin = ((total_pages*preferences.max_email_per_page)-(preferences.max_email_per_page-1));
289                msg_range_end = (total_pages*preferences.max_email_per_page);           
290                lnk_page.setAttribute("href", "javascript:current_page="+total_pages+";kill_current_box(); draw_paging("+num_msgs+"); cExecute ('$this.imap_functions.get_range_msgs2&folder='+get_current_folder()+'&msg_range_begin="+msg_range_begin+"&msg_range_end="+msg_range_end+"&sort_box_type="+sort_box_type+ "&search_box_type="+ search_box_type +"&sort_box_reverse="+sort_box_reverse+"', function handler(data){draw_box(data, get_current_folder());})");
291        }
292        else {
293                lnk_page = document.createElement("SPAN");
294        }
295        span_paging.innerHTML += "&nbsp;";
296        span_paging.appendChild(lnk_page);
297
298        lnk_page.title = get_lang("Last");
299        lnk_page.innerHTML = "&gt;&gt;";
300}
301
302
303// Draw the inbox and another folders
304function draw_box(headers_msgs, msg_folder, alternate){
305        if (alternate)
306                kill_current_box();
307       
308        if(is_ie)
309                document.getElementById("border_table").width = "99.5%";
310
311        openBox.content_id[numBox] = document.getElementById("content_id_"+numBox);     
312        openBox.tab_folder[numBox] = msg_folder;
313       
314        table_message_header_box = document.getElementById("table_message_header_box_"+numBox);
315        if (table_message_header_box == null){
316                var table_element = document.createElement("TABLE");
317                var tbody_element = document.createElement("TBODY");
318                table_element.setAttribute("id", "table_message_header_box_"+numBox);
319                table_element.className = "table_message_header_box";
320               
321                tr_element = document.createElement("TR");
322                tr_element.className = "message_header";
323                td_element1 = document.createElement("TD");
324                td_element1.setAttribute("width", "1%");
325                chk_box_element = document.createElement("INPUT");
326                chk_box_element.id  = "chk_box_select_all_messages";
327                chk_box_element.setAttribute("type", "checkbox");
328                chk_box_element.className = "checkbox";
329                chk_box_element.onclick = function(){select_all_messages(this.checked);};
330                chk_box_element.onmouseover = function () {this.title=get_lang('Select all messages.')};
331                chk_box_element.onkeydown = function (e){
332                        if (is_ie)
333                        {
334                                if ((window.event.keyCode) == 46)
335                                        delete_msgs(get_current_folder(),'selected','null');
336                        }
337                        else
338                        {
339                                if ((e.keyCode) == 46)
340                                        delete_msgs(get_current_folder(),'selected','null');
341                        }
342                };
343               
344                td_element1.appendChild(chk_box_element);
345               
346                td_element2 = document.createElement("TD");
347                td_element2.setAttribute("width", "2%");
348       
349                td_element3 = document.createElement("TD");
350                td_element3.setAttribute("width", "31%");
351                td_element3.onclick = function () {sort_box(search_box_type,'SORTFROM');};
352                td_element3.id = "message_header_SORTFROM_"+numBox;
353                td_element3.align = "left";
354                td_element3.innerHTML = get_lang("Who");
355               
356                td_element4 = document.createElement("TD");
357                td_element4.setAttribute("width", "41%");
358                td_element4.onclick = function () {sort_box(search_box_type,'SORTSUBJECT');};
359                td_element4.id = "message_header_SORTSUBJECT_"+numBox;
360                td_element4.align = "left";
361                td_element4.innerHTML = get_lang("Subject");
362       
363                td_element5 = document.createElement("TD");
364                td_element5.setAttribute("width", "14%");
365                td_element5.onclick = function () {sort_box(search_box_type,'SORTARRIVAL');};
366                td_element5.id = "message_header_SORTARRIVAL_"+numBox;
367                td_element5.align = "center";
368                td_element5.innerHTML = get_lang("Date");
369                td_element6 = document.createElement("TD");
370                td_element6.setAttribute("width", "14%");
371                td_element6.onclick = function () {sort_box(search_box_type,'SORTSIZE');}
372                td_element6.id = "message_header_SORTSIZE_"+numBox;
373                td_element6.align = "left";
374                td_element6.innerHTML = get_lang("Size");
375
376                tr_element.appendChild(td_element1);
377                tr_element.appendChild(td_element2);
378                tr_element.appendChild(td_element3);
379                tr_element.appendChild(td_element4);
380                tr_element.appendChild(td_element5);
381                tr_element.appendChild(td_element6);
382                tbody_element.appendChild(tr_element);
383                table_element.appendChild(tbody_element);
384                openBox.content_id[numBox].appendChild(table_element);
385        }
386        draw_header_box();
387        var table_element = document.createElement("TABLE");
388        var tbody_element = document.createElement("TBODY");
389       
390        table_element.id = "table_box";
391        table_element.className = "table_box";
392        table_element.borderColorDark = "#bbbbbb";
393        table_element.frame = "void";
394        table_element.rules = "rows";
395        table_element.cellPadding = "0";
396        table_element.cellSpacing = "0";
397       
398        table_element.onkeydown = function (e){
399                if (is_ie)
400                {
401                        if ((window.event.keyCode) == 46)
402                        {
403                                //delete_all_selected_msgs_imap();
404                                delete_msgs(get_current_folder(),'selected','null');
405                        }
406                }
407                else
408                {
409                        if ((e.keyCode) == 46)
410                        {
411                                //delete_all_selected_msgs_imap();
412                                delete_msgs(get_current_folder(),'selected','null');
413                        }
414                }
415        };
416        if (is_ie)
417                table_element.style.cursor = "hand";
418       
419        tbody_element.setAttribute("id", "tbody_box");
420        table_element.appendChild(tbody_element);
421
422        var _divScroll = document.getElementById("divScrollMain_"+numBox);
423
424        var bar = document.getElementById("toolbar");
425        var offset = 0;
426
427        if(!_divScroll){               
428                _divScroll = document.createElement("DIV");
429                _divScroll.id = "divScrollMain_"+numBox;
430        }
431       
432        if(is_ie) {
433                _divScroll.style.overflowY = "auto";                                                           
434                _divScroll.style.overflowX = "hidden";
435                _divScroll.style.width  ="100%";
436        }                                                                                                       
437        else{
438                _divScroll.style.overflow = "-moz-scrollbars-vertical";
439                _divScroll.style.width  ="99.3%";
440        }
441        // Inicio: Redimensiona DIV SCROLL
442        var bar = Element("toolbar");
443        var offset = 0;
444        if(bar.style.visibility != 'hidden')
445                offset = (bar.offsetHeight ? bar.offsetHeight :  bar.clientHeight);             
446        var screenHeight = document.body.clientHeight ? document.body.clientHeight : document.body.offsetHeight;
447        var defaultHeight = screenHeight - offset;             
448        _divScroll.style.height         = defaultHeight - 110;
449        Element('content_folders').style.height = defaultHeight - (is_ie ? 165 : 150);
450        // Fim: Redimensiona DIV SCROLL
451        _divScroll.appendChild(table_element);
452        openBox.content_id[numBox].appendChild(_divScroll);
453       
454        var f_unseen = 0;
455
456                if (headers_msgs.num_msgs == 0){
457                        td_info = document.createElement("H3");
458                        td_info.setAttribute("height", "25%");
459                        td_info.setAttribute("background", "#FFF");
460                        td_info.setAttribute("id", "msg_info");
461                        td_info.align = "center";
462                        td_info.innerHTML = get_lang("This mail box is empty");
463                        tbody_element.appendChild(td_info);
464                }
465       
466       
467        for (var i=0; i < headers_msgs.length; i++){
468                        if ((headers_msgs[i].Unseen == 'U') || (headers_msgs[i].Recent == 'N'))
469                                f_unseen++;
470                        tr_element = this.make_tr_message(headers_msgs[i], msg_folder);
471                        tbody_element.appendChild(tr_element);
472                        _dragArea.makeDragged(tr_element, headers_msgs[i].msg_number, headers_msgs[i].subject, true);
473        }
474
475        if ((preferences.use_shortcuts == '1') && (headers_msgs[0]))
476                select_msg(headers_msgs[0].msg_number, 'null', true);
477
478        var tdFolders  =  Element("folderscol");
479        tdFolders.style.display = preferences.hide_folders == '1'  ? "none" : "";
480        alternate_border(numBox);
481        draw_footer_box(headers_msgs.num_msgs);
482        Element('main_table').style.display = '';
483        if(debug) {
484                var _eTime = new Date();
485                _eTime = _eTime.getTime();
486                alert("Carregou em "+(_eTime - _bTime)+" ms");
487        }
488        var msg_folder = Element('msg_folder').value;
489        var msg_number = Element('msg_number').value;   
490        if(!msg_folder && msg_number) {
491                new_message('new','null');
492        }
493        else if(msg_folder && msg_number){
494                cExecute("$this.imap_functions.get_info_msg&msg_number="+ msg_number + "&msg_folder=" + msg_folder, show_msg);
495                Element('msg_folder').value = '';
496                Element('msg_number').value = '';
497        }
498
499        if(!is_ie) {
500                var scripts = new Array("ccQuickAdd",
501                                                        "color_palette",
502                                                        "filter",
503                                                        "filters",
504                                                        "html2xhtml",
505                                                        "preferences",
506                                                        "QuickCatalogSearch",
507                                                        "QuickSearchUser",
508                                                        "rich_text_editor",
509                                                        "sharemailbox",
510                                                        "search",
511                                                        "TreeS",
512                                                        "TreeShow");
513                                                       
514                connector.loadAllScripts(scripts);
515        }
516}
517
518function make_tr_message(headers_msgs, msg_folder){
519                var tr_element = document.createElement('tr');
520                tr_element.style.height = preferences.line_height;
521                var _fontSize = preferences.font_size ? preferences.font_size : "11";
522                tr_element.id = headers_msgs.msg_number;
523
524                if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N'))
525                        add_className(tr_element, 'tr_msg_unread');
526                else
527                        add_className(tr_element, 'tr_msg_read');
528               
529                if (headers_msgs.Flagged == 'F')
530                        add_className(tr_element,'flagged_msg');
531
532                td_element1 = document.createElement("TD");
533                td_element1.setAttribute("width", "1%");
534                chk_box_element = document.createElement("INPUT");
535                chk_box_element.setAttribute("type", "checkbox");
536                chk_box_element.className = "checkbox";
537                chk_box_element.setAttribute("id", "check_box_message_"+headers_msgs.msg_number);
538                chk_box_element.onclick = function(e){
539                        if (is_ie)
540                                changeBgColor(window.event,headers_msgs.msg_number);
541                        else
542                                changeBgColor(e,headers_msgs.msg_number);
543                };
544                td_element1.appendChild(chk_box_element);
545               
546                td_element2 = document.createElement("TD");
547                td_element2.setAttribute("width", "2%");
548                if (headers_msgs.attachment && headers_msgs.attachment.number_attachments > 0)
549                        td_element2.innerHTML = "<img src ='templates/default/images/clip.gif' title='" + url_decode(headers_msgs.attachment.names) + "'>";
550                       
551                td_element21 = document.createElement("TD");
552                td_element21.setAttribute("width", "1%");
553                td_element21.id = "td_message_answered_"+headers_msgs.msg_number;
554
555                if ((headers_msgs.Forwarded == 'F')  || (headers_msgs.Draft == 'X' && headers_msgs.Answered == 'A')){
556                        td_element21.innerHTML += "<img src ='templates/default/images/forwarded.gif' title='"+get_lang('Forwarded')+"'>";
557                        headers_msgs.Draft = ''
558                        headers_msgs.Answered = '';
559                        headers_msgs.Forwarded == 'F';
560                }
561                else if (headers_msgs.Draft == 'X')
562                        td_element2.innerHTML += "<img src ='templates/default/images/draft.gif' title='"+get_lang('Draft')+"'>";
563                else if (headers_msgs.Answered == 'A')
564                        td_element21.innerHTML += "<img src ='templates/default/images/answered.gif' title='"+get_lang('Answered')+"'>";
565
566                td_element22 = document.createElement("TD");
567                td_element22.setAttribute("width", "1%");
568                td_element22.id = "td_message_important_"+headers_msgs.msg_number;
569
570                // preload image
571                var _img_important = new Image();
572                _img_important.src = "templates/default/images/important.gif";
573
574                if (headers_msgs.Flagged == 'F')
575                        td_element22.innerHTML += "<img src ='templates/default/images/important.gif' title='"+get_lang('Important')+"'>";
576                else
577                        td_element22.innerHTML += "&nbsp;&nbsp;&nbsp;";
578                       
579                       
580                td_element23 = document.createElement("TD");
581                td_element23.setAttribute("width", "1%");
582                td_element23.id = "td_message_sent_"+headers_msgs.msg_number;
583                td_element23.innerHTML = "&nbsp;&nbsp;&nbsp;";
584                // preload image
585                var _img_sent = new Image();
586                _img_sent.src    = "templates/default/images/sent.gif";
587
588                td_element3 = document.createElement("TD");
589                td_element3.id = "td_who_"+ headers_msgs.msg_number;
590                td_element3.setAttribute("width", "30%");
591                var _onclick = function(){InfoContact.hide();cExecute("$this.imap_functions.get_info_msg&msg_number="+ headers_msgs.msg_number + "&msg_folder=" + msg_folder, show_msg);};
592                td_element3.onclick = _onclick;
593                td_element3.innerHTML = '&nbsp;';
594               
595                if(headers_msgs.from.email.toLowerCase() == Element("user_email").value)
596                {
597                        td_element3.onmouseover = function () {this.title=headers_msgs.to.email;};
598                        if (headers_msgs.Draft == 'X')
599                                td_element3.innerHTML += "<span style=\"color:red\">("+get_lang("Draft")+") </span>";
600                        else{                           
601                                if(headers_msgs.to.email.toLowerCase() != Element("user_email").value)
602                                        td_element23.innerHTML = "<img valign='center' src ='templates/default/images/sent.gif' title='"+get_lang('Sent')+"'>";
603                       
604                                if ((headers_msgs.to)&&(headers_msgs.to.name != null))
605                                        td_element3.innerHTML += headers_msgs.to.name;
606                                else if (headers_msgs.to){
607                                        td_element3.innerHTML += headers_msgs.to.email;
608                                }
609                        }
610                }
611                else{
612                        td_element3.onmouseover = function (event) {try {InfoContact.begin(this,headers_msgs.from.email)} catch(e){};};
613                        td_element3.onmouseout = function (){ try {clearTimeout(InfoContact.timeout);} catch(e){}};
614                        if (headers_msgs.Draft == 'X'){
615                                td_element3.innerHTML = "<span style=\"color:red\">("+get_lang("Draft")+") </span>";
616                        }
617                        else{
618                                if (headers_msgs.from.name != null)
619                                        td_element3.innerHTML += headers_msgs.from.name;
620                                else
621                                        td_element3.innerHTML += headers_msgs.from.email;
622                        }
623                }       
624                if (td_element3.innerHTML.indexOf(" ") == '-1' && td_element3.innerHTML.length > 25){
625                        td_element3.innerHTML = td_element3.innerHTML.substring(0,25) + "...";
626                }
627                else if (td_element3.innerHTML.length > 40 ){
628                        td_element3.innerHTML = td_element3.innerHTML.substring(0,40) + "...";
629                }
630               
631                td_element4 = document.createElement("TD");
632                td_element4.setAttribute("width", "40%");
633                td_element4.onclick = _onclick;
634                td_element4.innerHTML = !is_ie ? "<a id='a_message_"+tr_element.id+"'>&nbsp;" : "&nbsp;";
635               
636                if ((headers_msgs.subject)&&(headers_msgs.subject.length > 50))
637                        td_element4.innerHTML += headers_msgs.subject.substring(0,50) + "...";
638                else
639                        td_element4.innerHTML += headers_msgs.subject;
640                                       
641                if(!is_ie){
642                        td_element4.innerHTML += "</a>";
643                        tr_element.onmouseover = function(){};
644                }
645               
646
647                td_element5 = document.createElement("TD");
648                td_element5.setAttribute("width", "14%");
649                td_element5.onclick = _onclick;
650                td_element5.setAttribute("align", "center");
651                td_element5.innerHTML = headers_msgs.udate;
652
653                td_element6 = document.createElement("TD");
654                td_element6.setAttribute("width", "14%");
655                td_element6.onclick = _onclick;
656                td_element6.setAttribute("noWrap","true");
657                td_element6.setAttribute("align", "center");
658               
659                td_element3.style.fontSize= _fontSize;
660                td_element4.style.fontSize= _fontSize;
661                td_element5.style.fontSize= _fontSize;
662                td_element6.style.fontSize= _fontSize;
663                msg_size = headers_msgs.Size;
664                if (msg_size < 1048576 && msg_size > 1024)
665                        td_element6.innerHTML = this.round(msg_size / 1024, 0) + ' Kb';
666                else if(msg_size > 1024)
667                        td_element6.innerHTML = this.round(msg_size / (1024*1024), 1) + ' Mb';
668                else
669                        td_element6.innerHTML = "1 Kb";
670
671                tr_element.appendChild(td_element1);
672                tr_element.appendChild(td_element2);
673                tr_element.appendChild(td_element21);
674                tr_element.appendChild(td_element22);
675                tr_element.appendChild(td_element23);
676                tr_element.appendChild(td_element3);
677                tr_element.appendChild(td_element4);
678                tr_element.appendChild(td_element5);
679                tr_element.appendChild(td_element6);
680                return tr_element;
681}
682
683function sort_box(search, sort){
684        var message_header = Element("message_header_"+search);
685        var handler_draw_box = function(data){
686                draw_box(data, get_current_folder(),true);
687                draw_paging(Element('tot_m').innerHTML);
688                //Mostrar as msgs nao lidas de acordo com o filtro de relevancia
689                var msgs_unseen = 0;
690                for(i in data){
691                        if(data[i].Unseen == 'U')
692                                msgs_unseen++;
693        }
694                Element("new_m").innerHTML = '<font style="color:'+(msgs_unseen == 0 ? '': 'red')+'">' + msgs_unseen + '</font>';
695        }
696
697        if(sort_box_type == sort && search_box_type == search){
698                sort_box_reverse = sort_box_reverse ? 0 : 1;
699        }
700        else if(sort_box_type != sort){
701                if ( (sort == 'SORTFROM') || (sort == 'SORTSUBJECT') )
702                        sort_box_reverse = 0;
703                else
704                        sort_box_reverse = 1;
705        }
706               
707        // Global variable.
708        sort_box_type = sort;
709        search_box_type = search;
710
711        cExecute ("$this.imap_functions.get_range_msgs2&folder="+current_folder+"&msg_range_begin=1&msg_range_end="+preferences.max_email_per_page+"&search_box_type="+search+"&sort_box_type="+sort+"&sort_box_reverse="+sort_box_reverse+"", handler_draw_box);
712        current_page = 1;
713        //Comentado para nao sobrepor o numero de msgs nao lidas ao utilizar os filtros
714        //update_menu();
715}
716function draw_header_box(){
717        switch(sort_box_type){
718                case 'SORTFROM':
719                        type_name = get_lang("Who");
720                        break;
721                case 'SORTSUBJECT':
722                        type_name = get_lang("Subject");
723                        break;
724                case 'SORTARRIVAL':
725                        type_name = get_lang("Date");
726                        break;
727                case 'SORTSIZE':
728                        type_name = get_lang("Size");
729                        break;
730                default:
731                        type_name = get_lang("Date");
732                        break;
733        }
734        document.getElementById("message_header_SORTFROM_"+numBox).innerHTML    = get_lang("Who");
735        document.getElementById("message_header_SORTSUBJECT_"+numBox).innerHTML = get_lang("Subject");
736        document.getElementById("message_header_SORTARRIVAL_"+numBox).innerHTML = get_lang("Date");
737        document.getElementById("message_header_SORTSIZE_"+numBox).innerHTML    = get_lang("Size");     
738        document.getElementById("message_header_"+(sort_box_type.lastIndexOf("SORT") != "-1" ? sort_box_type : "SORTARRIVAL")+"_"+numBox ).innerHTML = "<B>"+type_name+"</B><img src ='templates/default/images/arrow_"+(sort_box_reverse == 1 ? 'desc' : 'asc')+"endant.gif'>";
739}
740function draw_message(info_msg, ID){
741        var content = document.getElementById('content_id_' + ID);
742        var defaultWidth = document.body.offsetWidth - 37;
743       
744        var menuHidden = Element("folderscol").style.display == 'none' ? true : false;
745        if(!menuHidden)
746                defaultWidth -= Element("folderscol").offsetWidth;
747         //////////////////////////////////////////////////////////////////////////////////////////////////////
748        //Make the next/previous buttom.
749        //////////////////////////////////////////////////////////////////////////////////////////////////////
750        var next_previous_msg_td = document.createElement("TD");
751        next_previous_msg_td.setAttribute("noWrap","true");
752        next_previous_msg_td.align = "right";
753        next_previous_msg_td.width = "40px";
754        var img_next_msg = document.createElement("IMG");
755        img_next_msg.id = 'msg_opt_next_' + ID;
756        img_next_msg.src = './templates/default/images/down.button.png';
757        img_next_msg.title = get_lang('Next');
758        img_next_msg.style.cursor = 'pointer';
759
760        // Old
761        //img_next_msg.onclick = function () {cExecute ("$this.imap_functions.get_info_next_msg&msg_number="+ info_msg.msg_number + "&msg_folder="+ info_msg.msg_folder + "&sort_box_type="+ sort_box_type +  "&search_box_type="+ search_box_type +"&sort_box_reverse="+ sort_box_reverse +"&reuse_border="+ID, show_msg)};
762        var folder = document.getElementById(ID.substr(0, ID.indexOf('_')));
763        if (!folder)
764                delete_border(ID);
765        if (folder.nextSibling)
766        {
767                var inbox = folder.nextSibling.name;
768                if (inbox)
769                        info_msg.msg_folder = inbox;
770
771                var next_msg = folder.nextSibling.id;
772                img_next_msg.onclick = function()
773                {
774                        cExecute("$this.imap_functions.get_info_msg&msg_number="+next_msg+"&msg_folder=" + info_msg.msg_folder+"&reuse_border="+ID, show_msg);
775                };
776        }
777        else
778                img_next_msg.onclick = function()
779                {
780                        current_page++;
781                        msg_range_end = (current_page*preferences.max_email_per_page);
782                        msg_range_begin = (msg_range_end-(preferences.max_email_per_page)+1);
783                        kill_current_box();
784                        cExecute ('$this.imap_functions.get_range_msgs2&folder='+get_current_folder()+'&msg_range_begin='+msg_range_begin+'&msg_range_end='+msg_range_end+'&sort_box_reverse=1', function handler(data){draw_box(data, get_current_folder());})
785                        delete_border(ID);
786                };
787
788        var img_space = document.createElement("SPAN");
789        img_space.innerHTML = "&nbsp;";
790        var img_previous_msg = document.createElement("IMG");
791        img_previous_msg.id = 'msg_opt_previous_' + ID;
792        img_previous_msg.src = './templates/default/images/up.button.png';
793        img_previous_msg.title = get_lang('Previous');
794        img_previous_msg.style.cursor = 'pointer';
795
796        //Old
797        //img_previous_msg.onclick = function () {cExecute ("$this.imap_functions.get_info_previous_msg&msgs_number="+ info_msg.msg_number + "&folder="+ info_msg.msg_folder + "&sort_box_type="+ sort_box_type+ "&search_box_type="+ search_box_type + "&sort_box_reverse="+ sort_box_reverse +"&reuse_border="+ID, show_msg)}
798        folder = document.getElementById(ID.substr(0, ID.indexOf('_')));
799        if (!folder)
800                delete_border(ID);
801        if (folder.previousSibling)
802        {
803                var inbox = folder.previousSibling.name;
804                if (inbox)
805                        info_msg.msg_folder = inbox;
806
807                var previous_msg = folder.previousSibling.id;
808                img_previous_msg.onclick = function()
809                {
810                        cExecute("$this.imap_functions.get_info_msg&msg_number="+previous_msg+"&msg_folder=" + info_msg.msg_folder+"&reuse_border="+ID, show_msg);                     
811                };
812        }
813        else
814                img_previous_msg.onclick = function()
815                {
816                        delete_border(ID);
817                };
818
819        next_previous_msg_td.appendChild(img_previous_msg);
820        next_previous_msg_td.appendChild(img_space);
821        next_previous_msg_td.appendChild(img_next_msg);
822        //////////////////////////////////////////////////////////////////////////////////////////////////////
823        //Make the header message.
824        //////////////////////////////////////////////////////////////////////////////////////////////////////
825        var table_message = document.createElement("TABLE");
826        var tbody_message = document.createElement("TBODY");
827        table_message.border = "0";
828        table_message.width = defaultWidth ;
829
830        //////////////////////////////////////////////////////////////////////////////////////////////////////
831        //Make the options message.
832        //////////////////////////////////////////////////////////////////////////////////////////////////////
833        var tr0 = document.createElement("TR");
834        tr0.className = "tr_message_header";
835        var td0 = document.createElement("TD");
836        var table_message_options = document.createElement("TABLE");
837        table_message_options.width = "100%";
838        table_message_options.border = '0';
839        table_message_options.className = 'table_message';
840        var tbody_message_options = document.createElement("TBODY");
841        var tr = document.createElement("TR");
842        var td = document.createElement("TD");
843        td.setAttribute("noWrap","true");
844        var _name = '';
845        var _maxChar = menuHidden ? 40 : 15;
846        if (info_msg.from.name)
847                _name = info_msg.from.name.length > _maxChar ? info_msg.from.name.substring(0,_maxChar) + "..." : info_msg.from.name;   
848        else           
849                _name = info_msg.from.email.length > _maxChar ? info_msg.from.email.substring(0,_maxChar) + "..." : info_msg.from.email;
850
851        td.innerHTML = _name.bold() + ', ' + info_msg.smalldate;
852        if (info_msg.attachments.length > 0)
853                td.innerHTML += "&nbsp<img style='cursor:pointer' onclick='javascript:Element(\"option_hide_more_"+ID+"\").onclick()' src ='templates/default/images/clip.gif' title='"+info_msg.attachments.names+"'>";
854       
855        if (typeof(info_msg.signature) == 'string')
856        {       
857                if (info_msg.signature != "void")
858                        td.innerHTML += '&nbsp;<img style="cursor:pointer" onclick="alert(\''+ get_lang("This message is signed, and you can trust.") + info_msg.signature +'\');" src="templates/default/images/signed.gif">';
859                else
860                        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/default/images/invalid.gif'>";
861        }
862       
863        if (info_msg.DispositionNotificationTo)
864        {
865                td.innerHTML += '&nbsp;<img style="cursor:pointer" alt="'+ get_lang('Message with read notification') + '" title="'+ get_lang('Message with read notification') + '" src="templates/default/images/notification.gif">';
866        }
867       
868        // NORMAL MSG
869        if(info_msg.Draft != 'X')
870        {
871        var options = document.createElement("TD");
872        options.width = "100%";
873        options.setAttribute("noWrap","true");
874        var option_hide_more = document.createElement("SPAN");
875        option_hide_more.className = 'message_options';
876        options.align = 'right';
877        option_hide_more.value = 'more_options';
878        option_hide_more.id = 'option_hide_more_'+ID;
879        option_hide_more.onclick = function(){
880                var _height = Element("div_message_scroll_"+ID).style.height;
881                _height = parseInt(_height.replace("px",""));
882                var _offset = 35;
883                if (this.value == 'more_options'){
884                        this.innerHTML = "<b><u>"+get_lang('Options')+"</u></b>";
885                        this.value = 'hide_options';
886                        Element("div_message_scroll_"+ID).style.height = (_height - _offset)+"px";
887                        Element('table_message_others_options_'+ID).style.display = '';
888                        Element('tr_other_options_'+ID).style.display = '';
889                       
890                }
891                else{
892                        this.innerHTML = get_lang('Options');
893                        this.value = 'more_options';
894                        Element("div_message_scroll_"+ID).style.height = (_height + _offset)+"px";
895                        Element('table_message_others_options_'+ID).style.display = 'none';
896                        Element('tr_other_options_'+ID).style.display = 'none';                 
897                }
898        };
899
900        option_hide_more.innerHTML = get_lang('Options');
901        options.appendChild(option_hide_more);
902       
903        var space0 = document.createElement("SPAN");
904        space0.innerHTML = '&nbsp;';
905        var space1 = document.createElement("SPAN");
906        space1.innerHTML = '&nbsp;';
907        var space2 = document.createElement("SPAN");
908        space2.innerHTML = '&nbsp;';
909        var space3 = document.createElement("SPAN");
910        space3.innerHTML = '&nbsp;';
911        var space4 = document.createElement("SPAN");
912        space4.innerHTML = '&nbsp;';
913
914        var option_print = document.createElement("SPAN");
915        option_print.id = 'msg_opt_print_'+ID;
916        option_print.className = 'message_options';
917        option_print.onclick = function(){print_msg(info_msg.msg_folder,info_msg.msg_number,ID);};
918        option_print.innerHTML = get_lang('Print');
919        options.appendChild(space0);
920        options.appendChild(option_print);
921        var option_forward = document.createElement("SPAN");
922        option_forward.id = 'msg_opt_forward_'+ID;
923        option_forward.className = 'message_options';
924        option_forward.onclick = function(){new_message('forward', ID);};
925        option_forward.innerHTML = get_lang('Forward');
926        options.appendChild(space1);
927        options.appendChild(option_forward);
928        var option_reply = document.createElement("SPAN");
929        option_reply.id = 'msg_opt_reply_'+ID;
930        option_reply.className = 'message_options';
931        option_reply.onclick = function(){new_message('reply_with_history', ID);};
932        option_reply.innerHTML = get_lang('Reply');
933        options.appendChild(space2);
934        options.appendChild(option_reply);
935        var option_delete = document.createElement("SPAN");
936        option_delete.id = 'msg_opt_delete_'+ID;
937        option_delete.className = 'message_options';
938        option_delete.onclick = function(){delete_msgs(info_msg.msg_folder, info_msg.msg_number, ID);};
939        option_delete.innerHTML = get_lang('Delete');
940        options.appendChild(space3);
941        options.appendChild(option_delete);
942       
943        tr.appendChild(td);
944        tr.appendChild(options);
945        tr.appendChild(next_previous_msg_td);
946        tbody_message_options.appendChild(tr);
947       
948        ////////// OTHER OPTIONS ////////////////////
949        var tr_other_options = document.createElement("TR");
950        tr_other_options.id = 'tr_other_options_' + ID;
951        tr_other_options.style.display = 'none';
952       
953        var td_other_options = document.createElement("TD");
954        td_other_options.colSpan = '3';
955        //td_other_options.align = 'right';
956        //td_other_options.setAttribute("noWrap","true");
957        var div_other_options = document.createElement("DIV");
958
959        var option_mark_as                                              = '<span>'+get_lang("Mark as")+'</span>: ';
960        var option_mark_as_unseen                               = '<span class="message_options" onclick="set_messages_flag(\'unseen\','+info_msg.msg_number+');write_msg(\''+get_lang('Message marked as ')+get_lang("Unseen")+'.\');">'+get_lang("Unseen")+'</span>, ';
961        var option_mark_as_important                    = '<span class="message_options" onclick="set_messages_flag(\'flagged\','+info_msg.msg_number+');write_msg(\''+get_lang('Message marked as ')+get_lang("Important")+'.\');">'+get_lang("Important")+'</span>, ';
962        var option_mark_as_normal                               = '<span class="message_options" onclick="set_messages_flag(\'unflagged\','+info_msg.msg_number+');write_msg(\''+get_lang('Message marked as ')+get_lang("Normal")+'.\');">'+get_lang("Normal")+'</span> | ';
963       
964        var option_move                                                 = '<span class="message_options" onclick=wfolders.makeWindow("'+ID+'","move_to");>'+get_lang("Move")+'</span> | ';
965        var option_reply_to_all                                 = '<span class="message_options" onclick=new_message("reply_to_all_with_history","'+ID+'");>'+get_lang("Reply to all")+'</span> | ';
966        var option_reply_without_history                = '<span class="message_options" onclick=new_message("reply_without_history","'+ID+'");>'+get_lang("Reply without history")+'</span> | ';
967        var option_reply_to_all_without_history = '<span class="message_options" onclick=new_message("reply_to_all_without_history","'+ID+'");>'+get_lang("Reply to all without history")+'</span> | ';
968        var option_source_msg                                   = '<span class="message_options" onclick=source_msg("'+ID+'","'+url_encode(info_msg.msg_folder)+'");>'+get_lang("Message Font")+'</span>';     
969
970        div_other_options.innerHTML = option_mark_as + option_mark_as_unseen + option_mark_as_important + option_mark_as_normal + option_move + option_reply_to_all + option_reply_without_history + option_reply_to_all_without_history + option_source_msg;
971        if (use_spam_filter) {
972                if(info_msg.msg_folder == 'INBOX'+cyrus_delimiter+'Spam')
973                        div_other_options.innerHTML += ' | <span class="message_options" onclick="nospam('+info_msg.msg_number+',\'null\', \''+info_msg.msg_folder+'\')";>'+get_lang("Not Spam")+'</span>';     
974                else
975                        div_other_options.innerHTML += ' | <span class="message_options" onclick="spam(\''+info_msg.msg_folder+'\', '+info_msg.msg_number+',\'null\')";>'+get_lang("Mark as Spam")+'</span>';   
976        }
977               
978        td_other_options.appendChild(div_other_options);
979        //td_other_options.innerHTML = option_print + option_reply_to_all + option_source_msg;
980       
981        tr_other_options.appendChild(td_other_options);
982        tbody_message_options.appendChild(tr_other_options);
983        ////////// END OTHER OPTIONS ////////////////
984        table_message_options.appendChild(tbody_message_options);
985        td0.appendChild(table_message_options);
986        tr0.appendChild(td0);
987        tbody_message.appendChild(tr0);
988        }
989        // IF DRAFT
990        else
991        {
992                var options = document.createElement("TD");
993                options.width = "1%";
994                options.setAttribute("noWrap","true");
995                var option_edit   = '<span class="message_options" onclick="new_message(\'edit\',\''+ID+'\');">'+get_lang('Edit')+'</span> | ';
996                var option_print = '<span class="message_options" onclick="print_msg(\''+info_msg.msg_folder+'\',\''+info_msg.msg_number+'\',\''+ID+'\');">'+get_lang('Print')+'</span> | ';
997                var option_delete = '<span class="message_options" onclick="delete_msgs(\''+info_msg.msg_folder+'\',\''+info_msg.msg_number+'\',\''+ID+'\');">'+get_lang('Delete')+'</span> | ';               
998                var option_hide_more = document.createElement("SPAN");
999                option_hide_more.className = 'message_options';
1000                options.align = 'right';
1001                option_hide_more.value = 'more_options';
1002                option_hide_more.id = 'option_hide_more_'+ID;
1003                option_hide_more.innerHTML = get_lang('Options');
1004                option_hide_more.onclick = function(){
1005                        var _height = Element("div_message_scroll_"+ID).style.height;
1006                        _height = parseInt(_height.replace("px",""));
1007                        var _offset = 35;
1008                        if (this.value == 'more_options'){
1009                                this.innerHTML = "<b><u>"+get_lang('Options')+"</u></b>";
1010                                this.value = 'hide_options';
1011                                Element("div_message_scroll_"+ID).style.height = (_height - _offset)+"px";
1012                                Element('table_message_others_options_'+ID).style.display = '';
1013                        }
1014                        else{
1015                                this.innerHTML = get_lang('Options');
1016                                this.value = 'more_options';
1017                                Element("div_message_scroll_"+ID).style.height = (_height + _offset)+"px";
1018                                Element('table_message_others_options_'+ID).style.display = 'none';
1019                        }
1020                };
1021                options.innerHTML = option_edit + option_print + option_delete;
1022                options.appendChild(option_hide_more);
1023                tr.appendChild(td);
1024                tr.appendChild(options);
1025                tr.appendChild(next_previous_msg_td);
1026                tbody_message_options.appendChild(tr);
1027                table_message_options.appendChild(tbody_message_options);
1028                td0.appendChild(table_message_options);
1029                tr0.appendChild(td0);
1030                tbody_message.appendChild(tr0);
1031        }
1032        //////////////////////////////////////////////////////////////////////////////////////////////////////
1033        // END options message.
1034        //////////////////////////////////////////////////////////////////////////////////////////////////////
1035
1036        var table_message_others_options = document.createElement("TABLE");
1037        table_message_others_options.id = 'table_message_others_options_' + ID;
1038        table_message_others_options.width =  defaultWidth - 30;
1039        table_message_others_options.style.display = 'none';
1040        table_message_others_options.className = "table_message";
1041        var tbody_message_others_options = document.createElement("TBODY");
1042        var tr1 = document.createElement("TR");
1043        tr1.className = "tr_message_header";
1044        var td1 = document.createElement("TD");
1045        td1.innerHTML = get_lang("From: ");
1046        td1.appendChild(deny_email(info_msg.from.email));
1047        td1.width = "7%";
1048       
1049        if (info_msg.sender){
1050                var tr111 = document.createElement("TR");
1051                tr111.className = "tr_message_header";
1052                var td111 = document.createElement("TD");
1053                td111.innerHTML = get_lang("Sent by")+": ";
1054                td111.appendChild(deny_email(info_msg.sender.email));
1055                td111.setAttribute("noWrap","true");
1056                var sender = document.createElement("TD");
1057                sender.id = "sender_"+ID;
1058                var sender_values = document.createElement("INPUT");
1059                sender_values.id = "sender_values_"+ID;
1060                sender_values.type = "HIDDEN";
1061                sender_values.value = info_msg.sender.full; //Veio do IMAP, sem images nem links.
1062                sender.innerHTML += draw_plugin_cc(ID, info_msg.sender.full);
1063                sender.className = "header_message_field";
1064                tr111.appendChild(td111);
1065                tr111.appendChild(sender);
1066                tr111.appendChild(sender_values);
1067                tbody_message_others_options.appendChild(tr111);
1068        }
1069       
1070       
1071        var from = document.createElement("TD");
1072        from.id = "from_"+ID;
1073        from.innerHTML = info_msg.from.full;
1074        if (info_msg.Draft != "X"){
1075                from.innerHTML += draw_plugin_cc(ID, info_msg.from);
1076                tbody_message_others_options.appendChild(tr1);
1077        }
1078        from.className = "header_message_field";
1079        var from_values = document.createElement("INPUT");
1080        from_values.id = "from_values_"+ID;
1081        from_values.type = "HIDDEN";
1082        from_values.value = info_msg.from.full; //Veio do IMAP, sem images nem links.
1083        tr1.appendChild(td1);
1084        tr1.appendChild(from);
1085        tr1.appendChild(from_values);
1086        if (info_msg.reply_to){
1087                var tr11 = document.createElement("TR");
1088                tr11.className = "tr_message_header";
1089                var td11 = document.createElement("TD");
1090                td11.innerHTML = get_lang("Reply to")+": ";
1091                td11.setAttribute("noWrap","true");
1092                var reply_to = document.createElement("TD");
1093                reply_to.id = "reply_to_"+ID;
1094               
1095                var reply_to_values = document.createElement("INPUT");
1096                reply_to_values.id = "reply_to_values_"+ID;
1097                reply_to_values.type = "HIDDEN";
1098                reply_to_values.value = info_msg.reply_to; //Veio do IMAP, sem images nem links.
1099                reply_to.innerHTML = draw_plugin_cc(ID, info_msg.reply_to);
1100                reply_to.className = "header_message_field";
1101                tr11.appendChild(td11);
1102                tr11.appendChild(reply_to);
1103                tr11.appendChild(reply_to_values);
1104                tbody_message_others_options.appendChild(tr11);
1105        }
1106        //////////////////////////////////////////////////////////////////////////////////////////////////////
1107        var tr2 = document.createElement("TR");
1108        tr2.className = "tr_message_header";
1109        var td2 = document.createElement("TD");
1110        td2.innerHTML = get_lang("To: ");
1111        var to = document.createElement("TD");
1112        to.id = "to_"+ID;
1113
1114        var to_values = document.createElement("INPUT");
1115        to_values.id = "to_values_"+ID;
1116        to_values.type = "HIDDEN";
1117        to_values.value = info_msg.toaddress2; //Veio do IMAP, sem images nem links.   
1118
1119        // Salva a pasta da mensagem
1120        var input_current_folder = document.createElement('input');     
1121        input_current_folder.id = "input_folder_"+ID;
1122        input_current_folder.name = "input_folder";
1123        input_current_folder.type = "hidden";
1124        input_current_folder.value = info_msg.msg_folder;
1125        td2.appendChild(input_current_folder); 
1126        // fim
1127        toaddress_array[ID] = info_msg.toaddress2.split(",");
1128        if (toaddress_array[ID].length > 1){
1129                to.innerHTML += draw_plugin_cc(ID, toaddress_array[ID][0]);
1130                var div_toaddress = document.createElement("SPAN");
1131                div_toaddress.id = "div_toaddress_"+ID;
1132                div_toaddress.style.display="";
1133                div_toaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','to');>"+get_lang('more')+"</a>)";
1134                to.appendChild(div_toaddress);         
1135        }
1136        else {
1137                to.innerHTML += draw_plugin_cc(ID,toaddress_array[ID]);
1138        }
1139        to.className = "header_message_field";
1140        tr2.appendChild(td2);
1141        tr2.appendChild(to);
1142        tr2.appendChild(to_values);
1143        tbody_message_others_options.appendChild(tr2);
1144
1145        if (info_msg.cc){
1146                var tr3 = document.createElement("TR");
1147                tr3.className = "tr_message_header";
1148                var td3 = document.createElement("TD");
1149                td3.innerHTML = "CC: ";
1150                var cc = document.createElement("TD");
1151                cc.id = "cc_"+ID;
1152
1153                var cc_values = document.createElement("INPUT");
1154                cc_values.id = "cc_values_"+ID;
1155                cc_values.type = "HIDDEN";
1156                cc_values.value = info_msg.cc;
1157               
1158                ccaddress_array[ID] = info_msg.cc.split(",");           
1159                if (ccaddress_array[ID].length > 1){
1160                        var div_ccaddress = document.createElement("SPAN");
1161                        div_ccaddress.id = "div_ccaddress_"+ID;
1162                        var div_ccaddress_full = document.createElement("SPAN");
1163                        div_ccaddress_full.id = "div_ccaddress_full_"+ID;               
1164                        div_ccaddress.style.display="";
1165                        cc.innerHTML = draw_plugin_cc(ID, ccaddress_array[ID][0]);
1166                        div_ccaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','cc');>"+get_lang('more')+"</a>)";
1167                        cc.appendChild(div_ccaddress);
1168                }
1169                else{
1170                        cc.innerHTML = draw_plugin_cc(ID, info_msg.cc);
1171                }
1172                cc.className = "header_message_field";
1173                tr3.appendChild(td3);
1174                tr3.appendChild(cc);
1175                tr3.appendChild(cc_values);
1176                tbody_message_others_options.appendChild(tr3);
1177        }
1178
1179        /*
1180         * @AUTHOR Rodrigo Souza dos Santos
1181         * @MODIFY-DATE 2008/09/11
1182         * @BRIEF Adding routine to create bcc field if there is one.
1183         */
1184        if (info_msg.bcc)
1185        {
1186                var tr3 = document.createElement("tr");
1187                tr3.className = "tr_message_header";
1188                var td3 = document.createElement("td");
1189                td3.innerHTML = get_lang("BCC") + " : ";
1190                var cco = document.createElement("td");
1191                cco.id = "cco_"+ID;
1192
1193                var cco_values = document.createElement("input");
1194                cco_values.id = "cco_values_"+ID;
1195                cco_values.type = "hidden";
1196                cco_values.value = info_msg.cco;
1197
1198                ccoaddress_array[ID] = info_msg.bcc.split(",");         
1199                if (ccoaddress_array[ID].length > 1){
1200                        var div_ccoaddress = document.createElement("SPAN");
1201                        div_ccoaddress.id = "div_ccoaddress_"+ID;
1202                        var div_ccoaddress_full = document.createElement("SPAN");
1203                        div_ccoaddress_full.id = "div_ccoaddress_full_"+ID;             
1204                        div_ccoaddress.style.display="";
1205
1206                        /*
1207                         * The function below is ugly, doesn't possible use its.
1208                         * The problem is that the code's function was written
1209                         * on a hardcode concept.
1210                         */
1211                        //cco.innerHTML = draw_plugin_cc(ID, ccoaddress_array[ID][0]);
1212                        cco.innerHTML = ccoaddress_array[ID][0];
1213                        div_ccoaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','cco');>"+get_lang('more')+"</a>)";
1214                        cco.appendChild(div_ccoaddress);
1215                }
1216                else{
1217                        /*
1218                         * The function below is ugly, it is not possible to use them.
1219                         * The problem is that the code's function was written
1220                         * on a hardcode concept.
1221                         */
1222                        //cco.innerHTML = draw_plugin_cc(ID, info_msg.cco);
1223                        cco.innerHTML = info_msg.bcc;
1224                }
1225                cco.className = "header_message_field";
1226                tr3.appendChild(td3);
1227                tr3.appendChild(cco);
1228                tr3.appendChild(cco_values);
1229                tbody_message_others_options.appendChild(tr3);
1230        }
1231
1232        var tr4 = document.createElement("TR");
1233        tr4.className = "tr_message_header";
1234        var td4 = document.createElement("TD");
1235        td4.innerHTML = get_lang("Date: ");
1236        var date = document.createElement("TD");
1237        date.id = "date_"+ID;
1238        date.innerHTML = info_msg.fulldate;
1239        var date_day = document.createElement("INPUT");
1240        date_day.id = "date_day_"+ID;
1241        date_day.type = "HIDDEN";
1242        date_day.value = info_msg.msg_day;
1243        var date_hour = document.createElement("INPUT");
1244        date_hour.id = "date_hour_"+ID;
1245        date_hour.type = "HIDDEN";
1246        date_hour.value = info_msg.msg_hour
1247       
1248        date.className = "header_message_field";
1249        tr4.appendChild(td4);
1250        tr4.appendChild(date);
1251        tr4.appendChild(date_day);
1252        tr4.appendChild(date_hour);
1253        tbody_message_others_options.appendChild(tr4);
1254       
1255        var tr5 = document.createElement("TR");
1256        tr5.className = "tr_message_header";
1257        var td5 = document.createElement("TD");
1258        td5.innerHTML = get_lang("Subject");
1259        var subject = document.createElement("TD");
1260        subject.id = "subject_"+ID;
1261        subject.innerHTML = info_msg.subject;
1262        subject.className = "header_message_field";
1263        tr5.appendChild(td5);
1264        tr5.appendChild(subject);
1265        tbody_message_others_options.appendChild(tr5);
1266
1267        if (info_msg.attachments.length > 0){
1268                var tr6 = document.createElement("TR");
1269                tr6.className = "tr_message_header";
1270                var td6 = document.createElement("TD");
1271                td6.innerHTML = get_lang("Attachments: ");
1272               
1273                var attachments = document.createElement("TD");
1274                td6.vAlign = "top";
1275                attachments.align='left';
1276                var zipped_attachments = '';
1277                if(info_msg.attachments.length > 1){
1278                        var zipped_attachments  = document.createElement("TABLE");
1279                        zipped_attachments.style.marginBottom = "4px";
1280                        zipped_attachments.cellPadding="0";
1281                        zipped_attachments.cellSpacing="0";
1282                        var tr = document.createElement("TR");
1283                        var td = document.createElement("TD");                 
1284                        var link_attachment     = document.createElement("A");
1285                        link_attachment.setAttribute("href", "javascript:download_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
1286                        link_attachment.innerHTML = " "+info_msg.attachments.length+' '+get_lang('files')+' :: '+get_lang('Download all atachments');
1287                        link_attachment.innerHTML += '<BR>';
1288                        td.appendChild(link_attachment);
1289                        tr.appendChild(td);
1290                        zipped_attachments.appendChild(tr);
1291                }
1292                if(zipped_attachments)
1293                        attachments.appendChild(zipped_attachments);
1294                attachments.id = "attachments_" + ID;
1295                for (var i=0; i<info_msg.attachments.length; i++){
1296                        var link_attachment = document.createElement("A");
1297                        link_attachment.setAttribute("href", "javascript:download_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"',"+i+",'"+info_msg.attachments[i].pid+"','"+info_msg.attachments[i].encoding+"')");
1298                        link_attachment.innerHTML = url_decode(info_msg.attachments[i].name);
1299                        msg_size = info_msg.attachments[i].fsize;
1300                        if (msg_size < 1048576 && msg_size > 1024)
1301                                link_attachment.innerHTML += ' (' + this.round(msg_size / 1024, 0) + ' Kb)';
1302                        else if(msg_size > 1024)
1303                                link_attachment.innerHTML += ' (' + this.round(msg_size / (1024*1024), 1) + ' Mb)';
1304                        else
1305                                link_attachment.innerHTML += ' (' + msg_size + ' bytes)';
1306                        link_attachment.innerHTML += '<BR>';
1307                        attachments.appendChild(link_attachment);
1308                }
1309                tr6.appendChild(td6);
1310                tr6.appendChild(attachments);
1311                tbody_message_others_options.appendChild(tr6);
1312        }
1313
1314
1315        // BEGIN MAKE THE SCROLL HEIGHT
1316        var bar = document.getElementById("toolbar");
1317        var offset = 0;
1318        if(bar.style.visibility != 'hidden')
1319                offset = bar.offsetHeight ? bar.offsetHeight :  bar.clientHeight;               
1320        var div = document.createElement("DIV");
1321        div.id = "div_message_scroll_"+ID;
1322        div.style.background = 'WHITE';
1323        div.style.height = document.body.clientHeight - offset - 125;
1324        content.style.height = document.body.clientHeight - offset - 80;
1325        div.style.overflow = "auto";
1326        div.style.width = defaultWidth - (is_ie ? 5 : 0);
1327        // END MAKE THE SCROLL HEIGHT
1328        table_message_others_options.appendChild(tbody_message_others_options);
1329        var tr = document.createElement("TR");
1330        var td = document.createElement("TD");
1331        td.colSpan = '2';
1332        div.appendChild(table_message_others_options);
1333        td.appendChild(div);
1334        tr.appendChild(td)
1335        tbody_message.appendChild(tr);
1336
1337
1338        ////////////////////////////////////////////////////////////////////////////////////////////////////// 
1339        //Make the body message.
1340        //////////////////////////////////////////////////////////////////////////////////////////////////////
1341        var tr = document.createElement("TR");
1342        tr.className = "tr_message_body";
1343        var td = document.createElement("TD");
1344        //td.setAttribute("colSpan","2");
1345        info_msg.body = info_msg.body.replace("<body","<span");
1346        info_msg.body = info_msg.body.replace("<BODY","<span");
1347        div.innerHTML+= "<span id='body_"+ID+"'>"+info_msg.body+"</span><br><br>";
1348        ////////////////////////////////////////////////////////////////////////////////////////////////////// 
1349        //Make the thumbs of the message.
1350        //////////////////////////////////////////////////////////////////////////////////////////////////////
1351        if ((info_msg.thumbs)&&(info_msg.thumbs.length > 0)){
1352                var table_message_thumbs = document.createElement("TABLE");
1353                table_message_thumbs.width = "80%";
1354                table_message_thumbs.style.borderTop = "2px solid rgb(170, 170, 170)";
1355                var tbody_message_thumbs = document.createElement("TBODY");
1356                var tr = document.createElement("TR");
1357                tr.className = "tr_message_body";
1358                var td = document.createElement("TD");
1359                td.setAttribute("colSpan","2");
1360                td.id = "body_thumbs_"+ID;
1361                td.innerHTML += "&nbsp;<font color='DARKBLUE' size='2'><b>"+info_msg.attachments.length+" "+get_lang("attachment")+(info_msg.attachments.length > 1 ? "s" : "")+" "+get_lang("in this message")+"</font></b>";
1362                var _link_attachments = '';
1363                if(info_msg.thumbs.length > 1){
1364                        _link_attachments       = document.createElement("A");
1365                        _link_attachments.className = "message_options";
1366                        _link_attachments.setAttribute("href", "javascript:download_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
1367                        _link_attachments.innerHTML = get_lang('Download all atachments');
1368                }
1369               
1370                if(_link_attachments){
1371                        td.innerHTML += " :: ";
1372                        td.appendChild(_link_attachments);
1373                }
1374               
1375                td.innerHTML += "<BR><img src='templates/default/images/menu/ktip.png'>"+get_lang("<b>Tip:</b> For faster save, click over the image with <u>right button</u>.");
1376                td.innerHTML += "<BR>";
1377
1378                for (var i=0; i<info_msg.thumbs.length; i++){
1379                        if ((i % 4) == 0)
1380                                td.innerHTML += "<BR>";
1381                        td.innerHTML += info_msg.thumbs[i];
1382                        td.innerHTML += "&nbsp;&nbsp;";
1383                }
1384                tr.appendChild(td);
1385                tbody_message_thumbs.appendChild(tr);
1386                table_message_thumbs.appendChild(tbody_message_thumbs);
1387                div.appendChild(table_message_thumbs);
1388        }
1389        //////////////////////////////////////////////////////////////////////////////////////////////////////
1390        table_message.appendChild(tbody_message);
1391        content.appendChild(table_message);
1392        var msg_number = document.createElement('INPUT');
1393        msg_number.id = "msg_number_" + ID;
1394        msg_number.type = "hidden";
1395        msg_number.value = info_msg.msg_number;
1396        content.appendChild(msg_number);
1397        //////////////////////////////////////////////////////////////////////////////////////////////////////
1398}
1399
1400function draw_new_message(border_ID){
1401        var ID = create_border("",border_ID);
1402        if (ID == false)
1403                return false;
1404        hold_session = true;
1405/////////////////////////////////////////////////////////////////////////////////////////////////////////
1406        var form = document.createElement("FORM");
1407        form.name = "form_message_"+ID;
1408        form.method = "POST";
1409        form.onsubmit = function(){return false;}
1410        if(!is_ie)
1411                form.enctype="multipart/form-data";
1412        else
1413                form.encoding="multipart/form-data";
1414/////////////////////////////////////////////////////////////////////////////////////////////////////////
1415        //ConstructMenuNewMessage(ID);
1416////////////////////////////////////////////////////////////////////////////////////////////////////////       
1417        var content = Element('content_id_' + ID);
1418        var table_message = document.createElement("TABLE");
1419        table_message.width = "100%";
1420        var tbody_message = document.createElement("TBODY");
1421        var tr0 = document.createElement("TR");
1422        tr0.className = "tr_message_header";
1423        var td0 = document.createElement("TD");
1424        td0.colSpan = '3';
1425       
1426        var table_menu_new_message = document.createElement("TABLE");
1427        table_menu_new_message.width = "100%";
1428        table_menu_new_message.border = '0';
1429        table_menu_new_message.className = 'table_message';
1430        var tbody_menu_new_message = document.createElement("TBODY");
1431        var tr_menu_new_message = document.createElement("TR");
1432        var td_menu_new_message = document.createElement("TD");
1433        td_menu_new_message.setAttribute("noWrap","true");
1434       
1435        if ((preferences.save_in_folder == '-1') || (preferences.save_in_folder == '')){
1436                //var option_send = '<span class="message_options" onclick=send_message("'+ID+'","null","null");>'+get_lang("Send")+'</span> | ';
1437                var option_send   = '<input type="button" id="send_button_'+ID+'" class="em_button_like_span" tabindex="1" value="'+get_lang("Send")+'" onclick=send_message("'+ID+'","null","null");>' + ' | ';
1438                var option_send_and_file= '<span class="message_options" onclick=wfolders.makeWindow("'+ID+'","send_and_file");>'+get_lang("Send and file")+'</span> | ';
1439        }
1440        else{
1441                //var option_send = '<span class="message_options" onclick="send_message(\''+ID+'\',\''+preferences.save_in_folder+'\',\'null\');">'+get_lang("Send")+'</span> | ';
1442                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\');">' + ' | ';
1443                var option_send_and_file='';
1444                wfolders.alert = true;
1445        }
1446//      var option_save_as              = '<span class="message_options" onclick=wfolders.makeWindow("'+ID+'","save");>'+get_lang("Save as")+'</span> | ';
1447        var option_save                 = '<span id="save_message_options" class="message_options" onclick="newMessageTab.toPreserve['+ID+'] = true; save_msg('+ID+');">'+get_lang("Save")+'</span> | ';
1448        var option_search               = '<span class="message_options" onclick=openListUsers("'+ID+'");>'+get_lang("Search")+'</span>';
1449        td_menu_new_message.innerHTML = option_send + option_send_and_file + option_save + option_search;
1450       
1451        tr_menu_new_message.appendChild(td_menu_new_message);
1452        tbody_menu_new_message.appendChild(tr_menu_new_message);
1453        table_menu_new_message.appendChild(tbody_menu_new_message);
1454       
1455        content.appendChild(table_menu_new_message);
1456        tr0.appendChild(td0);
1457        tbody_message.appendChild(tr0);
1458////////////////////////////////////////////////////////////////////////////////////////////////////////
1459        var tr1_1 = document.createElement("TR");
1460        tr1_1.style.display = 'none';
1461        var td1_1 = document.createElement("TD");
1462        td1_1.innerHTML = get_lang("From")+":";
1463        td1_1.setAttribute("noWrap","true");
1464        td1_1.style.width = "1%";
1465       
1466        var td_from = document.createElement("TD");
1467        td_from.setAttribute("noWrap","true");
1468        td_from.style.width = "100%";
1469                       
1470        var sel_from = document.createElement('SELECT');       
1471        sel_from.id = "from_"+ID;
1472        sel_from.name = "input_from";
1473        sel_from.style.width = "70%";
1474        sel_from.setAttribute("wrap","soft");
1475        td_from.appendChild(sel_from); 
1476        tr1_1.appendChild(td1_1);
1477        tr1_1.appendChild(td_from);
1478        tbody_message.appendChild(tr1_1);       
1479////////////////////////////////////////////////////////////////////////////////////////////////////////
1480        var tr1 = document.createElement("TR");
1481        var td1 = document.createElement("TD");
1482        td1.innerHTML = get_lang("To")+":";
1483        td1.setAttribute("noWrap","true");
1484        td1.style.width = "1%";
1485       
1486        var td_to = document.createElement("TD");
1487        td_to.setAttribute("noWrap","true");
1488        td_to.style.width = "100%";
1489       
1490        var input_to = document.createElement('TEXTAREA');
1491        input_to.id = "to_"+ID;
1492        input_to.name = "input_to";
1493        input_to.setAttribute("tabIndex","1"); 
1494        input_to.style.width = "100%";
1495        input_to.setAttribute("wrap","soft");
1496        input_to.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer)); search_contacts('onfocus', this.id);};
1497        input_to.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
1498        if (!is_ie)
1499        {
1500                input_to.rows = 2;
1501                input_to.onkeypress = function (e)
1502        {
1503            if ((e.keyCode) == 120) //F9
1504            {
1505                emQuickSearch(input_to.value, 'to', ID);
1506            }
1507            else
1508            {
1509                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
1510                {
1511                    e.preventDefault();
1512                    search_contacts(e.keyCode,this.id);
1513                }
1514            }
1515        }
1516        input_to.onkeyup = function (e)
1517        {
1518            if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
1519            {
1520                search_contacts(e.keyCode,this.id);
1521            }
1522        }
1523        }
1524        else
1525        {
1526                input_to.rows = 3;
1527                input_to.onkeyup = function (e)
1528        {
1529            if ((window.event.keyCode) == 120) //F9
1530            {
1531                emQuickSearch(input_to.value, 'to', ID);
1532            }
1533            else
1534            {
1535                search_contacts(window.event.keyCode,this.id);
1536            }   
1537        }
1538        }
1539        td_to.appendChild(input_to);
1540       
1541        var img_search = document.createElement("IMG");
1542        img_search.src = "./templates/default/images/search.gif";
1543        img_search.title = get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.');
1544        img_search.onclick = function () {emQuickSearch(document.getElementById('to_'+ID).value, 'to', ID);};
1545        var span_search = document.createElement("SPAN");
1546        span_search.innerHTML = get_lang('Search');
1547       
1548        var td1_img_search = document.createElement("TD");
1549        td1_img_search.setAttribute("noWrap","true");
1550        var td1_span_search = document.createElement("TD");
1551        td1_span_search.setAttribute("noWrap","true"); 
1552       
1553        td1_img_search.appendChild(img_search);
1554        td1_span_search.appendChild(span_search);
1555       
1556        tr1.appendChild(td1);
1557        tr1.appendChild(td_to);
1558        tr1.appendChild(td1_img_search);
1559
1560        tbody_message.appendChild(tr1);
1561//////////////////////////////////////////////////////////////////////////////////////////////////////
1562        var tr2 = document.createElement("TR");
1563        tr2.id = "tr_cc_"+ID;
1564        tr2.style.display = 'none';
1565        var td2 = document.createElement("TD");
1566        td2.innerHTML = "Cc:";
1567        td2.setAttribute("noWrap","true");     
1568        td2.style.width = "1%";
1569       
1570        var td_cc = document.createElement("TD");
1571        td_cc.setAttribute("noWrap","true");
1572        td_cc.style.width = "100%";
1573       
1574        var input_cc = document.createElement('TEXTAREA');
1575        input_cc.id = "cc_"+ID;
1576        input_cc.name = "input_cc";
1577        input_cc.setAttribute("tabIndex","1");
1578        input_cc.style.width = "100%";
1579        input_cc.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer)); search_contacts('onfocus',this.id);};
1580        input_cc.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
1581    if (!is_ie)
1582    {
1583        input_cc.rows = 2;
1584        input_cc.onkeypress = function (e)
1585        {
1586            if ((e.keyCode) == 120) //F9
1587            {
1588                emQuickSearch(input_cc.value, 'cc', ID);
1589            }
1590            else
1591            {
1592                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
1593                {
1594                    e.preventDefault();
1595                    search_contacts(e.keyCode,this.id);
1596                }
1597            }
1598        }
1599        input_cc.onkeyup = function (e)
1600        {
1601            if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
1602            {
1603                search_contacts(e.keyCode,this.id);
1604            }
1605        }
1606    }
1607    else if (is_ie)
1608    {
1609        input_cc.rows = 3;
1610        input_cc.onkeyup = function (e)
1611        {
1612            if ((window.event.keyCode) == 120) //F9
1613            {
1614                emQuickSearch(input_cc.value, 'cc', ID);
1615            }
1616            else
1617            {
1618                search_contacts(window.event.keyCode,this.id);
1619            }
1620        }
1621    }
1622       
1623        td_cc.appendChild(input_cc);
1624        var img_search = document.createElement("IMG");
1625        img_search.src = "./templates/default/images/search.gif";
1626        img_search.onclick = function () {emQuickSearch(document.getElementById('cc_'+ID).value, 'cc', ID)}
1627        img_search.title = get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.');
1628        var span_search = document.createElement("SPAN");
1629        span_search.innerHTML = get_lang('Search');
1630       
1631        var td2_img_search = document.createElement("TD");
1632        td2_img_search.setAttribute("noWrap","true");
1633        var td2_span_search = document.createElement("TD");
1634        td2_span_search.setAttribute("noWrap","true"); 
1635       
1636        td2_img_search.appendChild(img_search);
1637        td2_span_search.appendChild(span_search);
1638               
1639        tr2.appendChild(td2);
1640        tr2.appendChild(td_cc);
1641        tr2.appendChild(td2_img_search);
1642        tbody_message.appendChild(tr2);
1643//////////////////////////////////////////////////////////////////////////////////////////////////////
1644        var tr3 = document.createElement("TR");
1645        tr3.id = "tr_cco_"+ID;
1646        tr3.style.display = 'none';
1647        var td3 = document.createElement("TD");
1648        td3.setAttribute("noWrap","true");
1649        td3.innerHTML = get_lang("CCo")+":";
1650        td3.style.width = "1%";
1651       
1652        var td_cco = document.createElement("TD");
1653        td_cco.setAttribute("noWrap","true");
1654        td_cco.style.width = "100%";
1655       
1656        var input_cco = document.createElement('TEXTAREA');
1657        input_cco.id = "cco_"+ID;
1658        input_cco.name = "input_cco";
1659        input_cco.setAttribute("tabIndex","1");
1660        input_cco.style.width = "100%";
1661        input_cco.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer)); search_contacts('onfocus',this.id);};
1662        input_cco.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
1663       
1664        if (!is_ie)
1665    {
1666        input_cco.rows = 2;
1667        input_cco.onkeypress = function (e)
1668        {
1669            if ((e.keyCode) == 120) //F9
1670            {
1671                emQuickSearch(input_cco.value, 'cco', ID);
1672            }
1673            else
1674            {
1675                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
1676                {
1677                    e.preventDefault();
1678                    search_contacts(e.keyCode,this.id);
1679                }
1680            }
1681        }
1682        input_cco.onkeyup = function (e)
1683        {
1684            if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
1685            {
1686                search_contacts(e.keyCode,this.id);
1687            }
1688        }
1689    }
1690    else if (is_ie)
1691    {
1692        input_cco.rows = 3;
1693        input_cco.onkeyup = function (e)
1694        {
1695            if ((window.event.keyCode) == 120) //F9
1696            {
1697                emQuickSearch(input_cco.value, 'cco', ID);
1698            }
1699            else
1700            {
1701                search_contacts(window.event.keyCode,this.id);
1702            }   
1703        }
1704    }
1705       
1706        td_cco.appendChild(input_cco);
1707        var img_search = document.createElement("IMG");
1708        img_search.src = "./templates/default/images/search.gif";
1709        img_search.title = get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.');   
1710        img_search.onclick = function () {emQuickSearch(document.getElementById('cco_'+ID).value, 'cco', ID);};
1711        var span_search = document.createElement("SPAN");
1712        span_search.innerHTML = get_lang('Search');
1713
1714        var td3_img_search = document.createElement("TD");
1715        td3_img_search.setAttribute("noWrap","true");
1716        var td3_span_search = document.createElement("TD");
1717        td3_span_search.setAttribute("noWrap","true"); 
1718       
1719        td3_img_search.appendChild(img_search);
1720        td3_span_search.appendChild(span_search);
1721               
1722        tr3.appendChild(td3);
1723        tr3.appendChild(td_cco);
1724        tr3.appendChild(td3_img_search);       
1725        tbody_message.appendChild(tr3);
1726//////////////////////////////////////////////////////////////////////////////////////////////////////
1727        var tr_link = document.createElement("TR");
1728        tr_link.id = "tr_link_"+ID;             
1729        var td1_link = document.createElement("TD");
1730        var td2_link = document.createElement("TD");
1731        td1_link.innerHTML = "&nbsp;";
1732        var a_cc_link = document.createElement('A');
1733        a_cc_link.innerHTML = get_lang('Add CC');
1734        a_cc_link.id = "a_cc_link_"+ID;
1735        a_cc_link.setAttribute("href","javascript:void(0)");
1736        a_cc_link.setAttribute("tabIndex","-1");
1737        a_cc_link.onclick = function () {this.style.display='none';document.getElementById('tr_cc_'+ID).style.display='';document.getElementById('space_link_'+ID).style.display='none';input_cc.focus(); return false;}
1738        td2_link.appendChild(a_cc_link);       
1739        var space = document.createElement("span");
1740        space.id ="space_link_"+ID;
1741        space.innerHTML="&nbsp;|&nbsp;";
1742        td2_link.appendChild(space);
1743        var a_cco_link = document.createElement('A');
1744        a_cco_link.innerHTML = get_lang('Add BCC');
1745        a_cco_link.id = "a_cco_link_"+ID;
1746        a_cco_link.setAttribute("href","javascript:void(0)");
1747        a_cco_link.setAttribute("tabIndex","-1");
1748        a_cco_link.onclick = function () {this.style.display='none';document.getElementById('tr_cco_'+ID).style.display='';document.getElementById('space_link_'+ID).style.display='none';input_cco.focus(); return false;}
1749        td2_link.appendChild(a_cco_link);       
1750        tr_link.appendChild(td1_link);
1751        tr_link.appendChild(td2_link);
1752        tbody_message.appendChild(tr_link);
1753//////////////////////////////////////////////////////////////////////////////////////////////////////
1754        var tr4 = document.createElement("TR");
1755        var td4 = document.createElement("TD");
1756        //td4.setAttribute("noWrap","true");   
1757        td4.innerHTML = get_lang("Subject")+":";
1758        var td_subject = document.createElement("TD");
1759        var input_subject = document.createElement('input');
1760        input_subject.id = "subject_"+ID;
1761        input_subject.name = "input_subject";
1762        input_subject.setAttribute("tabIndex","1");
1763        input_subject.style.width = "90%";
1764        input_subject.setAttribute("autocomplete","off");
1765        td_subject.appendChild(input_subject);
1766        tr4.appendChild(td4);
1767        tr4.appendChild(td_subject);
1768        tbody_message.appendChild(tr4);
1769////////////////////////////////////////////////////////////////////////////////////////////////////// 
1770        var tr5 = document.createElement("TR");
1771        var td5 = document.createElement("TD");
1772        td5.innerHTML = "&nbsp;";
1773        var td_return_receipt = document.createElement("TD");
1774        td_return_receipt.setAttribute("noWrap","true");
1775        td_return_receipt.innerHTML = get_lang("Return receipt")+":";
1776        var input_return_receipt = document.createElement('input');
1777        input_return_receipt.type = "checkbox";
1778        input_return_receipt.className = "checkbox";
1779        input_return_receipt.id = "return_receipt_"+ID;
1780        input_return_receipt.name = "input_return_receipt";
1781        input_return_receipt.setAttribute("tabIndex","-1");
1782        td_return_receipt.appendChild(input_return_receipt);   
1783        tr5.appendChild(td5);
1784        tr5.appendChild(td_return_receipt);
1785        tbody_message.appendChild(tr5);
1786//////////////////////////////////////////////////////////////////////////////////////////////////////
1787        var add_files = document.createElement("A");
1788        add_files.setAttribute("href", "javascript:void(0)");
1789        add_files.onclick = function () { addFile(ID); return false;};
1790        add_files.innerHTML =  get_lang("Attachments: add+");
1791        add_files.setAttribute("tabIndex","-1");
1792        var divfiles = document.createElement("DIV");
1793        divfiles.id = "divFiles_"+ID;
1794        var tr5 = document.createElement("TR");
1795        var td5_link = document.createElement("TD");
1796        var td5_input = document.createElement("TD");   
1797        td5_input.innerHTML = "&nbsp;"
1798        td5_link.setAttribute("valign","top");
1799        td5_link.setAttribute("colSpan","2");
1800        td5_link.appendChild(add_files);
1801        tr5.appendChild(td5_input);
1802        tr5.appendChild(td5_link);
1803        tbody_message.appendChild(tr5);
1804        var tr6 = document.createElement("TR");
1805        var td6_link  = document.createElement("TD");
1806        var td6_input = document.createElement("TD");
1807        tr6.appendChild(td6_link);
1808        td6_input.appendChild(divfiles);
1809        tr6.appendChild(td6_input);     
1810        tbody_message.appendChild(tr6);
1811//////////////////////////////////////////////////////////////////////////////////////////////////////
1812        var tr5 = document.createElement("TR");
1813        var td5 = document.createElement("TD");
1814        td5.innerHTML = "&nbsp;";
1815        var td_body = document.createElement("TD");
1816        td_body.setAttribute("colSpan","2");
1817        var div_body_position = document.createElement("DIV");
1818        div_body_position.id = "body_position_" + ID;
1819        td_body.appendChild(div_body_position);
1820        tr5.appendChild(td5);
1821        tr5.appendChild(td_body);
1822        tbody_message.appendChild(tr5);
1823// BEGIN MAKE THE SCROLL HEIGHT
1824        var defaultWidth = document.body.clientWidth - (is_ie ? 200 : 195);
1825        var _bar = document.getElementById("toolbar");
1826        var _offset = 0;
1827        if(_bar.style.visibility != 'hidden')
1828                _offset = _bar.offsetHeight ? _bar.offsetHeight :  _bar.clientHeight;           
1829        var _div = document.createElement("DIV");
1830        _div.id = "div_message_scroll_"+ID;
1831//      _div.style.background = 'WHITE';
1832        _div.style.height = document.body.clientHeight - _offset - 105;
1833        content.style.height = document.body.clientHeight - _offset - 80;
1834       
1835        _div.style.overflow = "auto";
1836        _div.style.width = defaultWidth;
1837        // END MAKE THE SCROLL HEIGHT
1838
1839        // Hide the contac tips and re-position the pallete color.
1840        _div.onscroll = function() {
1841                var intElemScrollTop = Element("div_message_scroll_"+ID).scrollTop;
1842                if (!is_ie)
1843                        ColorPalette.repos(intElemScrollTop);
1844                Tooltip.scrollChanged();
1845        };
1846//////////////////////////////////////////////////////////////////////////////////////////////////////
1847        _div.appendChild(form);
1848        content.appendChild(_div);
1849        table_message.appendChild(tbody_message);
1850        form.appendChild(table_message);
1851        connector.loadScript("rich_text_editor");
1852        RichTextEditor.loadEditor(ID);
1853//////////////////////////////////////////////////////////////////////////////////////////////////////
1854        draw_from_field(sel_from,tr1_1);
1855        return ID;
1856}
1857
1858//      Verify if any user is sharing his name/email address
1859//      for use in the new messages's "From " field.
1860function draw_from_field(sel_from,tr1_1){
1861
1862        var el_shared_users = Element("el_shared_users");
1863        // The element was loaded and populated...so return.
1864        if(el_shared_users){   
1865                // Nothing to work...so return.
1866                if(el_shared_users.options.length == 0)
1867                        return;
1868                tr1_1.style.display = '';
1869                for (var x = 0; x < el_shared_users.options.length; x++) {
1870                        var _option = document.createElement("OPTION");
1871                        _option.text = el_shared_users.options[x].text;
1872                        _option.value = el_shared_users.options[x].value;
1873                        sel_from.options[sel_from.options.length] = _option     ;
1874                }
1875                return;
1876        }
1877        // Get the shared folders.....
1878        var RegExp_name = new RegExp("(user)"+cyrus_delimiter+"(.*)$", "i");
1879        var sharedFolders = new Array();
1880        for(var i = 0; i < folders.length; i++) {
1881                var x = folders[i].folder_id;
1882        if (RegExp_name.test(x)){
1883                sharedFolders[sharedFolders.length] = x;
1884        }
1885    }
1886
1887    var matchUser = '#';
1888    var sharedUsers = new Array();
1889        // Filter the shared folders (only root folders) .....
1890        for(var i = 0; i < sharedFolders.length; i++) {
1891      if(!sharedFolders[i].match(matchUser)) {
1892                matchUser = sharedFolders[i];
1893                sharedUsers[sharedUsers.length] = matchUser.substring(("user"+cyrus_delimiter).length,matchUser.length);
1894      }
1895    }
1896
1897        // Handler function for cExecute
1898        var h_user = function(data) {
1899                if(data.length > 0) {
1900                        tr1_1.style.display = '';
1901                        var _option = document.createElement("OPTION");
1902                        _option.text =  '"'+data.myname+'" <'+Element("user_email").value+'>';
1903                        _option.value  = data.myname+";"+Element("user_email").value;
1904                        sel_from.options[sel_from.options.length] = _option;
1905       
1906                        var options = '';
1907                        for (var x = 0; x < data.length; x++)   {
1908                                var _option = document.createElement("OPTION");
1909                                _option.text = '"'+data[x].cn[0] + '" <'+data[x].mail[0]+'>';
1910                                _option.value = data[x].cn[0] + ';'+data[x].mail[0];
1911                                sel_from.options[sel_from.options.length] = _option     ;
1912                        }
1913                }
1914                var shared_users_from = Element("el_shared_users");
1915                if(!shared_users_from) {
1916                        shared_users_from = sel_from.cloneNode(true);
1917                        shared_users_from.id = "el_shared_users";
1918                        shared_users_from.style.display = 'none';
1919                        document.body.appendChild(shared_users_from);
1920                }
1921        }
1922        // First time, so execute.....
1923        cExecute ("$this.ldap_functions.getSharedUsersFrom&uids="+sharedUsers.join(';'), h_user);
1924}
1925
1926function changeBgColorToON(all_messages, begin, end){
1927        for (begin; begin<=end; begin++)
1928        {
1929                add_className(all_messages[begin], 'selected_msg');
1930                Element("check_box_message_" + all_messages[begin].id).checked = true;
1931        }
1932}
1933
1934function changeBgColor(event, msg_number){
1935        actual_tr = Element(msg_number);
1936
1937        if (event.shiftKey)
1938        {
1939                last_tr = Element(last_message_selected);
1940                if(!last_tr)
1941                        last_tr = actual_tr;
1942
1943                all_messages = actual_tr.parentNode.childNodes;
1944               
1945                for (var i=0; i < all_messages.length; i++)
1946                {
1947                        if (actual_tr.id == all_messages[i].id)
1948                                first_order = i;
1949                        if (last_tr.id == all_messages[i].id)
1950                                last_order = i;
1951                }
1952               
1953                if (parseInt(first_order) > parseInt(last_order))
1954                        changeBgColorToON(all_messages, last_order, first_order);
1955                else
1956                        changeBgColorToON(all_messages, first_order, last_order);
1957        }
1958        else{
1959                //if ( exist_className(actual_tr, 'selected_msg') )
1960                if ( Element('check_box_message_' + msg_number).checked )
1961                        add_className(actual_tr, 'selected_msg');
1962                else
1963                        remove_className(actual_tr, 'selected_msg');
1964        }
1965        last_message_selected = msg_number;
1966}
1967
1968function build_quota(data){
1969        id = "content_quota";
1970        q_limit = data['quota_limit'];
1971        var div = document.getElementById(id);
1972        if(!q_limit){
1973            div.innerHTML = '<span><font size="2" style="color:red"><strong>'+get_lang("Without Quota")+'</strong></font></span>';
1974        }
1975        else{
1976        if(div)
1977                div.innerHTML = '';
1978        value = data['quota_percent'];
1979        q_used = data['quota_used'];
1980        table = document.getElementById("table_quota");
1981        if(table)
1982                table.parentNode.removeChild(table);
1983        table = document.createElement("TABLE");       
1984        tbody = document.createElement("TBODY");       
1985        table.appendChild(tbody);
1986        table.id = "table_quota";
1987        table.width="102";
1988        table.border="0";
1989        table.cellSpacing = 0;
1990        table.cellPadding = 0;
1991       
1992        //tr1 = document.createElement("TR");
1993        td11 = document.createElement("TD");
1994        td11.align="center";
1995        td11.setAttribute("noWrap","true");
1996        td11.innerHTML += '&nbsp;' + value+"% ("+q_used+"M/"+q_limit+"M)";
1997        //tr1.appendChild(td11);
1998       
1999        tr2 = document.createElement("TR");
2000        td21 = document.createElement("TD");
2001        td21.setAttribute("noWrap","true");
2002        td21.height="15";
2003        td22 = document.createElement("TD");   
2004        td21.setAttribute("background","templates/default/images/dsunused.gif");
2005        table221 = document.createElement("TABLE");
2006        tbody221 = document.createElement("TBODY");
2007        table221.appendChild(tbody221);
2008        table221.style.width=value+"%";
2009        td21.width="102";
2010        table221.border="0";
2011        table221.cellSpacing = 0;
2012        table221.cellPadding = 0;
2013        tr221 = document.createElement("TR");
2014        td221 = document.createElement("TD");
2015        td221.height="15";
2016        if(value > 90) {
2017                if(value >= 100)
2018                        write_msg(get_lang("Your Mailbox is 100% full! You must free more space or will not receive messages."));
2019                else
2020                        write_msg(get_lang("Warning: Your Mailbox is almost full!"));
2021                td221.setAttribute("background","templates/default/images/dsalert.gif");
2022        }
2023        else if(value > 80)
2024                td221.setAttribute("background","templates/default/images/dswarn.gif");
2025        else
2026                td221.setAttribute("background","templates/default/images/dsused.gif");
2027       
2028        tr221.appendChild(td221);
2029        tbody221.appendChild(tr221);
2030        td21.appendChild(table221);     
2031        tr2.appendChild(td21);
2032        tr2.appendChild(td11);
2033
2034        //tr2.appendChild(td1);
2035
2036        tbody.appendChild(tr2); //Desenho
2037        //tbody.appendChild(tr1); //Letras
2038        div.appendChild(table);
2039        }
2040}
2041
2042function draw_quota(data){
2043        build_quota(data);
2044}
2045
2046function update_quota(folder_id){
2047        cExecute ("$this.imap_functions.get_quota&folder_id="+folder_id,build_quota);
2048}
2049
2050function draw_search(headers_msgs){
2051        Element("border_id_0").innerHTML = "&nbsp;&nbsp;" + get_lang('Search Result') + "&nbsp;&nbsp;";
2052
2053        var tbody = Element('tbody_box');
2054        for (var i=0; i<(headers_msgs.length); i++){
2055                var tr = this.make_tr_message(headers_msgs[i], headers_msgs[i].msg_folder);
2056                tbody.appendChild(tr);
2057        }
2058}
2059
2060function draw_search_header_box(){
2061        var table_message_header_box = Element("table_message_header_box");
2062        table_message_header_box.parentNode.removeChild(table_message_header_box);
2063
2064        var content_id_0 = Element("content_id_0");
2065        var table_element = document.createElement("TABLE");
2066        var tbody_element = document.createElement("TBODY");
2067        table_element.setAttribute("id", "table_message_header_box");
2068        table_element.className = "table_message_header_box";
2069        tr_element = document.createElement("TR");
2070        tr_element.className = "message_header";
2071        td_element1 = document.createElement("TD");
2072        td_element1.setAttribute("width", "1%");
2073        chk_box_element = document.createElement("INPUT");
2074        chk_box_element.id  = "chk_box_select_all_messages";
2075        chk_box_element.setAttribute("type", "checkbox");
2076        chk_box_element.className = "checkbox";
2077        chk_box_element.onclick = function(){select_all_messages(this.checked);};
2078        chk_box_element.onmouseover = function () {this.title=get_lang('Select all messages.')};
2079        chk_box_element.onkeydown = function (e){
2080                if (is_ie)
2081                {
2082                        if ((window.event.keyCode) == 46)
2083                        {
2084                                //delete_all_selected_msgs_imap();
2085                                delete_msgs(get_current_folder(),'selected','null');
2086                        }
2087                }
2088                else
2089                {
2090                        if ((e.keyCode) == 46)
2091                        {
2092                                //delete_all_selected_msgs_imap();
2093                                delete_msgs(get_current_folder(),'selected','null');
2094                        }
2095                }
2096        };
2097       
2098        td_element1.appendChild(chk_box_element);
2099        td_element2 = document.createElement("TD");
2100        td_element2.setAttribute("width", "3%");
2101        td_element3 = document.createElement("TD");
2102        td_element3.setAttribute("width", "30%");
2103        td_element3.id = "message_header_SORTFROM";
2104        td_element3.align = "left";
2105        td_element3.innerHTML = get_lang("From");
2106        td_element4 = document.createElement("TD");
2107        td_element4.setAttribute("width", "49%");
2108        td_element4.id = "message_header_SORTSUBJECT";
2109        td_element4.align = "left";
2110        td_element4.innerHTML = get_lang("Subject");   
2111        td_element5 = document.createElement("TD");
2112        td_element5.setAttribute("width", "10%");
2113        td_element5.id = "message_header_SORTARRIVAL";
2114        td_element5.align = "center";
2115        td_element5.innerHTML = "<B>"+get_lang("Date")+"</B>"; 
2116        td_element5.innerHTML += "<img src ='templates/default/images/arrow_descendant.gif'>";
2117        td_element6 = document.createElement("TD");
2118        td_element6.setAttribute("width", "10%");
2119        td_element6.id = "message_header_SORTSIZE";
2120        td_element6.align = "right";
2121        td_element6.innerHTML = get_lang("Size");
2122        tr_element.appendChild(td_element1);
2123        tr_element.appendChild(td_element2);
2124        tr_element.appendChild(td_element3);
2125        tr_element.appendChild(td_element4);
2126        tr_element.appendChild(td_element5);
2127        tr_element.appendChild(td_element6);
2128       
2129        tbody_element.appendChild(tr_element);
2130        table_element.appendChild(tbody_element);
2131        content_id_0.appendChild(table_element);
2132}
2133
2134function draw_search_division(msg){
2135        var tbody = Element('tbody_box');
2136        var tr = document.createElement("TR");
2137        var td = document.createElement("TD");
2138        td.colSpan = '7';
2139        td.width = '100%';
2140
2141        var action_info_table = document.createElement("TABLE");
2142        var action_info_tbody = document.createElement("TBODY");
2143       
2144        action_info_table.className = "action_info_table";
2145        action_info_table.width = "100%";
2146       
2147        var action_info_tr = document.createElement("TR");
2148       
2149        var action_info_th1 = document.createElement("TH");
2150        action_info_th1.width = "40%";
2151        action_info_th1.innerHTML = "&nbsp;";
2152
2153        var action_info_th2 = document.createElement("TH");
2154       
2155        action_info_th2.innerHTML = msg;
2156        action_info_th2.className = "action_info_th";
2157        action_info_th2.setAttribute("noWrap", "true");
2158       
2159        var action_info_th3 = document.createElement("TH");
2160        action_info_th3.width = "40%";
2161        action_info_th3.innerHTML = "&nbsp;";
2162       
2163        action_info_tr.appendChild(action_info_th1);
2164        action_info_tr.appendChild(action_info_th2);
2165        action_info_tr.appendChild(action_info_th3);
2166        action_info_tbody.appendChild(action_info_tr);
2167        action_info_table.appendChild(action_info_tbody);
2168
2169        td.appendChild(action_info_table);
2170        tr.appendChild(td);
2171        tbody.appendChild(tr);
2172}
2173
2174function draw_search_box(){
2175        var content_id_0 = Element("content_id_0");
2176        var table = document.createElement("TABLE");
2177        table.id = "table_box";
2178        table.width = 'auto';
2179        var tbody = document.createElement("TBODY");
2180        tbody.id = "tbody_box";
2181
2182        table.className = "table_box";
2183        table.setAttribute("frame", "below");
2184        table.setAttribute("rules", "none");
2185        table.setAttribute("cellpadding", "0");
2186        table.onkeydown = function (e){
2187                if (is_ie)
2188                {
2189                        if ((window.event.keyCode) == 46)
2190                        {
2191                                //delete_all_selected_msgs_imap();
2192                                delete_msgs(get_current_folder(),'selected','null');
2193                        }
2194                }
2195                else
2196                {
2197                        if ((e.keyCode) == 46)
2198                        {
2199                                //delete_all_selected_msgs_imap();
2200                                delete_msgs(get_current_folder(),'selected','null');
2201                        }
2202                }
2203        };
2204        if (is_ie)
2205                table.style.cursor = "hand";
2206       
2207        table.appendChild(tbody);
2208        content_id_0.appendChild(table);
2209}
2210        var idx_cc = 0;
2211function draw_plugin_cc(ID, addrs)      {
2212        connector.loadScript("ccQuickAdd");
2213
2214        var array_addrs = '';
2215        var array_name  = '';   
2216        var cc_data = new Array();
2217        if(typeof(addrs.name) != 'undefined') {
2218                array_name      = LTrim(addrs.name).split(" ");
2219                array_addrs = new Array(addrs.email);           
2220        }
2221        else {
2222                array_addrs = (typeof addrs == 'object' ? addrs.toString().split("\" ") : addrs.split("\" "));
2223                array_name      = LTrim(array_addrs[0]).replace('"','').split(" ");     
2224        }
2225
2226        var _split = array_name[0].split('@');
2227        cc_data[0] = _split[0];
2228        cc_data[1] = _split[0];
2229        cc_data[2] = '';
2230
2231        for (i=1; i < array_name.length; i++)
2232                cc_data[2] += array_name[i] + " ";                     
2233       
2234
2235        if(array_addrs.length > 1)                     
2236                cc_data[3] = array_addrs[1] ? array_addrs[1].replace("&lt;",'').replace("&gt;",'') : '';               
2237        else
2238                cc_data[3] = array_addrs[0];
2239       
2240        var sm_envelope_img1 = '<img style="cursor:'+ (is_ie ? 'hand' : 'pointer') +'" title="' + get_lang("Add Contact") +
2241        '" onclick="ccQuickAddOne.showList(\''+cc_data+'\')" src="./templates/default/images/user_card.gif">';
2242        var to_addybook_add = "<SPAN id='insert_plugin_"+idx_cc+"_"+ID+"'>";
2243        to_addybook_add += addrs;
2244        to_addybook_add +=  sm_envelope_img1;
2245        idx_cc++;
2246        to_addybook_add += "</SPAN>";
2247        return to_addybook_add;
2248}
2249function deny_email(email){
2250        connector.loadScript("filter");
2251        connector.loadScript("filters");
2252        var dn_em       = document.createElement("SPAN");
2253                dn_em.id = "tt_d";
2254                dn_em.onclick = function(){filter_rules.new_rule(email);};
2255                dn_em.setAttribute("title",get_lang("Block Sender"));
2256                dn_em.style.cursor = "pointer";         
2257                dn_em.innerHTML = "<img align='top' onclick=filter.new_rule('"+email+"') src='./templates/default/images/deny.gif'>";
2258        return dn_em;
2259       
2260}
2261function show_div_address_full(id, type) {
2262        var div_address_full = Element("div_"+type+"address_full_"+id);
2263        if(!div_address_full) {
2264                div_address_full = document.createElement("SPAN");
2265                div_address_full.id = "div_"+type+"address_full_"+id;   
2266                div_address_full.style.display="none"; 
2267                var _address = eval(type+"address_array['"+id+"']");
2268                var isOverLimit = (_address.length > 100);
2269               
2270                if(isOverLimit) {
2271                        alert("Esse campo possui muitos endereços ("+_address.length+" destinatários).\r\n"+
2272                        "Para evitar o travamento do navegador, o botão 'Adicionar Contato' foi desabilitado!");
2273                }
2274
2275                for(var idx = 1 ; idx  < _address.length;idx++) {
2276                        div_address_full.innerHTML += isOverLimit ?  '<br>'+_address[idx] : ','+draw_plugin_cc(id,_address[idx]);
2277                }               
2278                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>)";
2279                Element(type+"_"+id).appendChild(div_address_full);
2280        }
2281        Element('div_'+type+'address_'+id).style.display='none';
2282        div_address_full.style.display='';
2283}
2284function draw_footer_box(num_msgs){
2285        var span_R = Element("table_message"); 
2286        var span_options = Element("span_options");     
2287        if(!span_options) {
2288                span_options = document.createElement("TD");   
2289                span_options.style.fontSize = "12";
2290                span_options.id = "span_options";
2291                span_R.appendChild(span_options);
2292        }
2293
2294        span_options.innerHTML =
2295                '<span title="'+get_lang("Delete")+'" style="margin-left:8px" class="message_options" onclick=delete_msgs(\'null\',\'selected\',\'null\')>'+get_lang("Delete")+'</span> | '+
2296                '<span title="'+get_lang("Move")+'" class="message_options" onclick=wfolders.makeWindow(\"\",\"move_to\")>'+get_lang("Move")+'</span> | '+
2297                '<span title="'+get_lang("Print")+'" class="message_options" onclick=print_all()>'+get_lang("Print")+'</span> | '+
2298                '<span title="'+get_lang("Export")+'" class="message_options" onclick="export_all_selected_msgs()">'+get_lang("Export")+'</span>';
2299       
2300        if (use_spam_filter) {
2301                if ( get_current_folder() == 'INBOX'+cyrus_delimiter+'Spam' )   {
2302                        span_options.innerHTML += ' | <span title="'+get_lang("Not Spam")+'" class="message_options" onclick="nospam(\'selected\',\'null\',\'null\')">'+get_lang("Not Spam")+'</span>';
2303                }
2304                else {
2305                        span_options.innerHTML += ' | <span title="'+get_lang("Mark as Spam")+'" class="message_options" onclick="spam(\'null\', \'selected\',\'null\')">'+get_lang("Mark as Spam")+'</span>';
2306                }
2307        }
2308        var span_D = Element("span_D");
2309        if(!span_D){
2310                span_D = document.createElement("TD"); 
2311                span_D.align = "right";
2312                span_D.style.fontSize = "12";
2313                span_D.id = "span_D";
2314                span_R.appendChild(span_D);
2315        }
2316        span_D.innerHTML =
2317                 get_lang("List")+': '+
2318        '<span id="span_flag_SORTARRIVAL" style="'+(search_box_type == 'ALL' ? 'font-weight:bold;text-decoration:underline' : '')+'" title="'+get_lang("All")+'" class="message_options" onclick="if(\'ALL\' == \''+search_box_type+'\') return false;sort_box(\'ALL\',\''+sort_box_type+'\')">'+get_lang("All")+'</span>, '+
2319        '<span id="span_flag_UNSEEN" style="'+(search_box_type == 'UNSEEN' ? 'font-weight:bold;text-decoration:underline' : '')+'" title="'+get_lang("l_unseen")+'" class="message_options" onclick="if(\'UNSEEN\' == \''+search_box_type+'\') return false;sort_box(\'UNSEEN\',\''+sort_box_type+'\')">'+get_lang("l_unseen")+'</span>, '+
2320        '<span id="span_flag_SEEN" style="'+(search_box_type == 'SEEN' ? 'font-weight:bold;text-decoration:underline' : '')+'" title="'+get_lang("l_seen")+'" class="message_options" onclick="if(\'SEEN\' == \''+search_box_type+'\') return false;sort_box(\'SEEN\',\''+sort_box_type+'\')">'+get_lang("l_seen")+'</span>, '+
2321        '<span id="span_flag_ANSWERED" style="'+(search_box_type == 'ANSWERED' ? 'font-weight:bold;text-decoration:underline' : '')+'" title="'+get_lang("l_answered")+'" class="message_options" onclick="if(\'ANSWERED\' == \''+search_box_type+'\') return false;sort_box(\'ANSWERED\',\''+sort_box_type+'\')">'+get_lang("l_answered")+'</span>, '+
2322        '<span id="span_flag_FLAGGED" style="'+(search_box_type == 'FLAGGED' ? 'font-weight:bold;text-decoration:underline' : '')+'" title="'+get_lang("l_important")+'" class="message_options" onclick="if(\'FLAGGED\' == \''+search_box_type+'\') return false;sort_box(\'FLAGGED\',\''+sort_box_type+'\')">'+get_lang("l_important")+'</span>&nbsp;&nbsp;';
2323        draw_paging(num_msgs);
2324        Element("tot_m").innerHTML = num_msgs; 
2325}
Note: See TracBrowser for help on using the repository browser.