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

Revision 617, 93.0 KB checked in by eduardoalex, 15 years ago (diff)

Ticket #403

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