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

Revision 352, 86.7 KB checked in by niltonneto, 16 years ago (diff)

Correção do problema, referente ao ticket #249

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