source: branches/2.2.0.1/expressoMail1_2/js/draw_api.js @ 4062

Revision 4062, 139.3 KB checked in by rafaelraymundo, 13 years ago (diff)

Ticket #1594 - Permitir redimensionamento das colunas na lista emails

  • Property svn:eol-style set to native
  • Property svn:executable set to *
Line 
1 var openTab = {
2        'type' : [], // 8 types of tabs, further info. see expressolivre.org/dev/wiki/mail/Documentacao
3        'content_id' : [],
4        'imapUid' : [], // Stores the imap email number of current tab
5        'countFile' : [0,0,0,0,0,0,0,0,0,0], // Stores the number of files attached in current tab
6        'imapBox' : [], // Stores the folder name
7        'toPreserve' : [], // Check if the message should be removed from draft after send
8        'autosave_timer' : [] // The timeout timer for autosave function
9};
10var tabTypes = {
11        'new':4,
12        'forward':6,
13        'reply_with_history':7,
14        'reply_to_all_with_history':8,
15        'reply_without_history':9,
16        'reply_to_all_without_history':10,
17        'edit':5
18        }
19var currentTab,numBox = 0; // Open Tab and num of mailboxes opened at context
20// Objeto Map, talvez o ideal fosse adicionar este objeto à Api do egroupware, e carregá-lo
21// aqui no expressoMail.
22function Map()
23{
24        this.keys = new Array();
25        this.values = new Array();
26}
27
28Map.prototype.add = function(key, value)
29{
30        this.keys.push(key);
31        this.values.push(value);
32}
33
34Map.prototype.get = function(key)
35{
36        result = new Array();
37        for (i = 0; i < this.keys.length; i++)
38        {
39                if (this.keys[i] == key)
40                {
41                        result.push(this.values[i]);
42                }
43        }
44
45        if (result.length == 0)
46        {
47                return null;
48        }
49
50        return result;
51}
52
53var translatedFolders = new Map();
54
55function draw_tree_folders(folders){
56        // Check if the tree folders alredy exist.
57                translatedFolders = new Map();
58        if (Element('dftree_tree_folders')){
59                if (!expresso_offline) {
60                        var update_tree_folders = function(data){
61                                build_quota(data);
62                                var unseen_in_mailbox = 0;
63                                var unseen_in_shared_folders = 0;
64                                for (var i=0; i<data.length; i++){
65                                        if ( data[i].folder_unseen > 0 )
66                                        {
67                                                unseen_in_mailbox = parseInt( unseen_in_mailbox + data[ i ].folder_unseen );
68                                                if ( data[i].folder_id.indexOf( 'INBOX' ) !== 0 )
69                                                        unseen_in_shared_folders = parseInt( unseen_in_shared_folders + data[ i ].folder_unseen );
70                                        }
71
72                                        var folder_unseen = Element('dftree_'+data[i].folder_id+'_unseen');
73
74                                        if ((folder_unseen) && (data[i].folder_unseen > 0))
75                                        {
76                                                folder_unseen.innerHTML = data[i].folder_unseen;
77                                        }
78                                        else if (data[i].folder_unseen > 0)
79                                        {
80                                                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>'});
81                                                tree_folders.getNodeById(data[i].folder_id)._refresh();
82                                        }
83                                        else if (data[i].folder_unseen <= 0)
84                                        {
85                                                tree_folders.getNodeById(data[i].folder_id).alter({caption:lang_folder(data[i].folder_name)});
86                                                tree_folders.getNodeById(data[i].folder_id)._refresh();
87                                        }
88
89                                        if(data[i].folder_id == current_folder){
90                                                var old_new_m = isNaN(parseInt(Element('new_m').innerHTML)) ? parseInt(Element('new_m').firstChild.innerHTML) : parseInt(Element('new_m').innerHTML);
91                                                Element('new_m').innerHTML = data[i].folder_unseen ? '<font color="RED">'+data[i].folder_unseen+'</font>' : 0;
92                                                draw_paging(Element('tot_m').innerHTML);
93                                        }
94                                }
95
96                                var display_unseen_in_mailbox = tree_folders.getNodeById( 'root' );
97                                display_unseen_in_mailbox.alter({caption:get_lang("My Folders")});
98                                display_unseen_in_mailbox._refresh();
99
100                                var display_unseen_in_shared_folders = tree_folders.getNodeById( 'user' );
101                                if ( display_unseen_in_shared_folders )
102                                {
103                                        if ( unseen_in_shared_folders )
104                                                display_unseen_in_shared_folders.alter({caption:'<font style=color:red>[</font><span id="dftree_user_unseen" style="color:red">' + unseen_in_shared_folders +'</span><font style=color:red>]</font> ' + get_lang("Shared folders")});
105                                        else
106                                                display_unseen_in_shared_folders.alter({caption:get_lang("Shared folders")});
107                                        display_unseen_in_shared_folders._refresh();
108                                }
109                        }
110                        cExecute ("$this.imap_functions.get_folders_list&folder="+current_folder, update_tree_folders);
111                }
112
113                return;
114        }
115        else{
116                if (!expresso_offline) {
117                        tree_folders = new dFTree({name: 'tree_folders'});
118
119                        var n_root = new dNode({id:'root', caption: get_lang("My Folders")});
120                        tree_folders.add(n_root,'anything'); //Places the root; second argument can be anything.
121
122                        var unseen_in_mailbox = 0;
123                        var unseen_in_shared_folders = 0;
124                        for (var i=0; i<folders.length; i++){
125                                if (folders[i].folder_unseen > 0)
126                                {
127                                        unseen_in_mailbox = parseInt( unseen_in_mailbox + folders[ i ].folder_unseen );
128                                        if ( folders[i].folder_id.indexOf( 'INBOX' ) !== 0 )
129                                                unseen_in_shared_folders = parseInt( unseen_in_shared_folders + folders[ i ].folder_unseen );
130
131                                        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});
132
133                                        if( folders[i].folder_name.toLowerCase() == 'inbox' )
134                                                Element('new_m').innerHTML = '<font style="color:red">' + folders[i].folder_unseen + '</font>';
135                                }
136                                else
137                                        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});
138
139                                if (folders[i].folder_parent == '')
140                                        folders[i].folder_parent = 'root';
141                                else if (folders[i].folder_parent == 'user'){
142
143                                        if (!tree_folders.getNodeById('user')){
144                                                                                                tmpFolderId = folders[i].folder_id.split(cyrus_delimiter).pop();
145                                                                                                if (tmpFolderId != folders[i].folder_name)
146                                                                                                {
147                                                                                                        translatedFolders.add(tmpFolderId, folders[i].folder_name);
148                                                                                                }
149                                                var n_root_shared_folders = new dNode({id:'user', caption:get_lang("Shared folders"), plusSign:true});
150                                                tree_folders.add(n_root_shared_folders,'root');
151                                        }
152                                }
153                                tree_folders.add(nn,folders[i].folder_parent);
154                        }
155                }
156
157
158
159                var handlerChannel = function(data){
160                        if (data == null || typeof(data) == 'string')
161                                return;
162                        /*
163                        *  RSS NEWS
164                        */
165                        var root_rss = new dNode({
166                                id: "news_root",
167                                caption: get_lang('News')
168                        });
169                        tree_folders.add(root_rss, "root");
170                        for(i=0; i < data.length; i++)
171                        {
172                                var nodeNews = new dNode({
173                                        id: "NEWS/"+data[i].name,
174                                        caption: data[i].name,
175                                        onClick: "open_rss('"+data[i].rss_url+"')",
176                                        plusSign: 0
177                                });
178                                tree_folders.add(nodeNews,"news_root");
179                        }
180                        var noden=document.getElementById('lnews_roottree_folders');
181                        noden.style.backgroundImage="url(templates/"+template+"/images/menu/rss.png)";
182                }
183//              cExecute('$this.rss.getChannels',handlerChannel);
184
185
186                /**
187                 * Pastas locais
188                 */
189                if (preferences.use_local_messages==1 || expresso_offline) {
190                        if (!window.google || !google.gears) {
191                                if (!expresso_local_messages.installGears())
192                                        preferences.use_local_messages=0;
193                        }
194                        else{
195                                if (!window.google || !google.gears) {
196                                temp = confirm(get_lang("To use local messages you have to install google gears. Would you like to be redirected to gears installation page?"));
197                                if (temp) {
198                                       if(is_win && is_gecko && preferences.gears_firefox_windows != "")
199                                            location.href = preferences.gears_firefox_windows;
200                                       else if(!is_win && is_gecko && preferences.gears_firefox_linux != "")
201                                           location.href = preferences.gears_firefox_linux;
202                                       else if(is_ie && preferences.gears_ie != "")
203                                           location.href = preferences.gears_ie;
204                                       else
205                                            location.href = "http://gears.google.com/?action=install&message="+get_lang("To use local messages, install Google Gears")+"&return="+document.location.href;
206                                }
207                                else {
208                                        preferences.use_local_messages=0;
209                                }
210                        }
211                        else{
212                                if (expresso_offline)
213                                        tree_folders = new dFTree({
214                                                name: 'tree_folders'
215                                        });
216                                var root_local = new dNode({
217                                        id: "local_root",
218                                        caption: get_lang('local folders')
219                                });
220                                tree_folders.add(root_local, "root"); //coloca root local
221                                var local_folders = expresso_local_messages.list_local_folders();
222                                for (var i in local_folders) { //Coloca as pastas locais.
223                                        var node_root = "local_root";
224                                        var new_caption = local_folders[i][0];
225                                        if (local_folders[i][0].indexOf("/") != "-1") {
226                                                final_pos = local_folders[i][0].lastIndexOf("/");
227                                                node_root = "local_" + local_folders[i][0].substr(0, final_pos);
228                                                new_caption = local_folders[i][0].substr(final_pos + 1);
229                                        }
230                                        if (local_folders[i][1] > 0)
231                                                var nodeLocal = new dNode({
232                                                        id: "local_" + local_folders[i][0],
233                                                        caption: lang_folder(new_caption) + '<font style=color:red>&nbsp(</font><span id="local_unseen" style=color:red>' + local_folders[i][1] + '</span><font style=color:red>)</font>',
234                                                        onClick: "change_folder('local_" + local_folders[i][0] + "','" + new_caption + "')",
235                                                        plusSign: local_folders[i][2]
236                                                });
237                                        else
238                                                var nodeLocal = new dNode({
239                                                        id: "local_" + local_folders[i][0],
240                                                        caption: lang_folder(new_caption),
241                                                        onClick: "change_folder('local_" + local_folders[i][0] + "','" + new_caption + "')",
242                                                        plusSign: local_folders[i][2]
243                                                });
244                                                tree_folders.add(nodeLocal, node_root);
245                                        }
246                                }
247                        }
248                }
249
250                tree_folders.draw(Element('content_folders'));
251                if (!expresso_offline) {
252                        n_root.changeState();
253                        tree_folders.getNodeById('INBOX')._select();
254                }
255                else {
256                        root_local.changeState();
257                        tree_folders.getNodeById('local_Inbox')._select();
258                }
259
260                var trash_span=document.getElementById('lINBOX/'+trashfolder+'tree_folders');
261                var draft_span=document.getElementById('lINBOX/'+draftsfolder+'tree_folders');
262                var sent_span=document.getElementById('l'+this.preferences.save_in_folder+'tree_folders');
263                var sent_span_default=document.getElementById('lINBOX/'+sentfolder+'tree_folders');
264                var spam_span=document.getElementById('lINBOX/'+spamfolder+'tree_folders');
265                //local folders
266                var sent_local_conf = this.preferences.save_in_folder.replace("INBOX/","local_");
267                var sent_local_conf_span=document.getElementById('l'+sent_local_conf+'tree_folders');
268                var trash_local_span=document.getElementById('llocal_'+trashfolder+'tree_folders');
269                var draft_local_span=document.getElementById('llocal_'+draftsfolder+'tree_folders');
270                var sent_span_default=document.getElementById('llocal_'+sentfolder+'tree_folders');
271
272
273                if (trash_span)
274                        trash_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_trash.png)";
275
276                if (draft_span)
277                        draft_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_draft.png)"
278
279                if (sent_span)
280                        sent_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_sent.png)";
281                if (spam_span)
282                        spam_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_spam.png)";
283
284                if (sent_span_default)
285                        sent_span_default.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_sent.png)";
286                //Local folders
287
288                if (sent_local_conf_span)
289                        sent_local_conf_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_sent.png)";
290                if (trash_local_span)
291                        trash_local_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_trash.png)";
292                if (draft_local_span)
293                        draft_local_span.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_draft.png)"
294                if (sent_span_default)
295                        sent_span_default.style.backgroundImage="url(../phpgwapi/templates/"+template+"/images/foldertree_sent.png)";
296
297
298                draw_paging(Element('tot_m').innerHTML);
299                if(document.getElementById("nINBOX/"+trashfolder+"tree_folders"))
300                {
301                        var trash = document.createElement("SPAN");
302                        trash.id = 'empty_trash';
303                        trash.className = 'clean_folder';
304                        trash.style.cursor = 'pointer';
305                        trash.onclick = function () {empty_trash_imap();};
306                        trash.innerHTML = "["+get_lang("Clean")+"]";
307                        trash.title=get_lang("Empty trash");
308                        trash.onmouseover = function() {trash.style.color="red";};
309                        trash.onmouseout= function() {trash.style.color="#666666";};
310                        document.getElementById("nINBOX/"+trashfolder+"tree_folders").appendChild(trash);
311                }
312                if(document.getElementById("nINBOX/"+spamfolder+"tree_folders"))
313                {
314                                                var spam = document.createElement("SPAN");
315                                                spam.id = 'empty_spam';
316                                                spam.className = 'clean_folder';
317                                                spam.style.cursor = 'pointer';
318                                                spam.style.padding = '0 0 0 6px';
319                                                spam.onclick = function () {empty_spam_imap();};
320                                                spam.innerHTML = "["+get_lang("Clean")+"]";
321                                                spam.title=get_lang("Empty Spam Folder");
322                                                spam.onmouseover = function() {spam.style.color="red";};
323                                                spam.onmouseout= function() {spam.style.color="#666666";};
324                                                document.getElementById("nINBOX/"+spamfolder+"tree_folders").appendChild(spam);
325                           }
326
327
328                if(!expresso_offline)
329                        var display_unseen_in_mailbox = tree_folders.getNodeById( 'root' );
330                else
331                        var display_unseen_in_mailbox = tree_folders.getNodeById( 'local_root' );
332                display_unseen_in_mailbox.alter({caption:get_lang("My Folders")});
333                display_unseen_in_mailbox._refresh();
334
335                var display_unseen_in_shared_folders = tree_folders.getNodeById( 'user' );
336                if ( display_unseen_in_shared_folders )
337                {
338                        if ( unseen_in_shared_folders )
339                                display_unseen_in_shared_folders.alter({caption:'<font style=color:red>[</font><span id="dftree_user_unseen" style="color:red">' + unseen_in_shared_folders +'</span><font style=color:red>]</font> ' + get_lang("Shared folders")});
340                        else
341                                display_unseen_in_shared_folders.alter({caption:get_lang("Shared folders")});
342                        display_unseen_in_shared_folders._refresh();
343                }
344        }
345
346        if (!expresso_offline) {
347                var folder_create = "";
348                var nm1 = "";
349                if(tree_folders._folderPr.length > 0){
350                        var nm_folder = "";
351                        for(var i=0; i < tree_folders._folderPr.length; i++){
352                                nm_folder = tree_folders._folderPr[i].split(cyrus_delimiter);
353                                if(nm_folder[0] == "INBOX"){
354                                        if(nm1 == ""){
355                                                nm1 = nm_folder[1];
356                                                folder_create = "INBOX" + cyrus_delimiter + nm_folder[1] + ";";
357                                        }else{
358                                                if( nm1 != nm_folder[1]){
359                                                        folder_create += "INBOX" + cyrus_delimiter + nm_folder[1] + ";";
360                                                        nm1 = nm_folder[1];
361                                                }
362                                        }
363                                }
364                        }
365                }
366                if(folder_create != ""){
367                        if(confirm(get_lang("There are folders with invalid format. Do you want to fix them?"))){
368                                var handler_correct_folders = function(data){
369                                        //Timeout to release HTTPRequest , loadScript and update tree folders.
370                                        if(data)
371                                                setTimeout("connector.loadScript('TreeShow');ttreeBox.update_folder();",500);
372                                }
373                                cExecute("$this.imap_functions.create_extra_mailbox",handler_correct_folders,"nw_folders="+folder_create);
374                        }
375                }
376        }
377
378}
379
380function draw_tree_local_folders() {
381        /**
382         * Pastas locais
383         */
384        if(preferences.use_local_messages==1 || expresso_offline) {
385                var local_folders = expresso_local_messages.list_local_folders();
386                var has_changes = false;
387                for (var i in local_folders) { //Coloca as pastas locais.
388
389                        var new_caption = local_folders[i][0];
390                        if(local_folders[i][0].indexOf("/")!="-1") {
391                                final_pos = local_folders[i][0].lastIndexOf("/");
392                                new_caption = local_folders[i][0].substr(final_pos+1);
393                        }
394
395                        var folder_unseen = Element('dftree_local_'+local_folders[i][0]+'_unseen');
396
397                        if ((folder_unseen) && (local_folders[i][1] > 0))
398                        {
399                                folder_unseen.innerHTML = local_folders[i][1];
400                                has_changes = true;
401                        }
402                        else if (local_folders[i][1] > 0)
403                        {
404                                tree_folders.getNodeById("local_"+local_folders[i][0]).alter({caption:lang_folder(new_caption) + '<font style=color:red>&nbsp(</font><span id="dftree_local_'+local_folders[i][0]+'_unseen" style=color:red>'+local_folders[i][1]+'</span><font style=color:red>)</font>'});
405                                tree_folders.getNodeById("local_"+local_folders[i][0])._refresh();
406                                has_changes = true;
407                        }
408                        else if (local_folders[i][1] <= 0)
409                        {
410                                tree_folders.getNodeById("local_"+local_folders[i][0]).alter({caption:lang_folder(new_caption)});
411                                tree_folders.getNodeById("local_"+local_folders[i][0])._refresh();
412                                has_changes = true;
413                        }
414
415                        if("local_"+local_folders[i][0] == get_current_folder()){
416                                var old_new_m = isNaN(parseInt(Element('new_m').innerHTML)) ? parseInt(Element('new_m').firstChild.innerHTML) : parseInt(Element('new_m').innerHTML);
417                                if(!isNaN(old_new_m) && old_new_m < local_folders[i][1]){
418                                        Element('tot_m').innerHTML = parseInt(Element('tot_m').innerHTML) + (parseInt(local_folders[i][1])-old_new_m);
419                                }
420                                Element('new_m').innerHTML = local_folders[i][1] ? '<font color="RED">'+local_folders[i][1]+'</font>' : 0;
421                                draw_paging(Element('tot_m').innerHTML);
422                                has_changes = true;
423                        }
424                }
425                if(has_changes)
426                        tree_folders.getNodeById("local_root").open();
427
428        }
429}
430
431function update_menu(data){
432                /*
433                 * @AUTHOR Rodrigo Souza dos Santos
434                 * @DATE 2008/09/15
435                 * @BRIEF When occurs a error in imap server show the message that is in file "error.html".
436                 */
437                if ( data && data.imap_error )
438                {
439                        if(preferences.use_local_messages==1 && expresso_local_messages.is_offline_installed){
440                                conf = confirm(get_lang("The expresso imap server is currently down, expresso noticed you have offline mail module installed, would you like to use it?"));
441                                if(conf) {
442                                        window.onresize = function() {
443                                                var target = document.getElementById('divAppbox');
444                                                target.style.height= document.body.clientHeight - 83;
445                                        }
446                                        var target = document.getElementById('divAppbox');
447                                        document.getElementById("divAppboxHeader").innerHTML="";
448                                        target.style.height= document.body.clientHeight - 83;
449                                        expresso_local_messages.set_as_logged(account_id,0,true);
450                                        target.innerHTML = "<iframe src='offline.php?inside=1' width='100%' height='100%' frameBorder='0'></iframe>";
451                                        return false;
452                                }
453                        }
454                        connector.newRequest('error.html', 'templates/'+template+'/error.html', 'GET',
455                                function(data)
456                                {
457                                        var target = document.getElementById('divAppbox');
458                                        if ( target )
459                                                target.innerHTML = data;
460                                }
461                        );
462                        return false;
463                }
464
465                draw_tree_folders(data);
466                if(data) {
467                        build_quota(data);
468                        var f_unseen = Element('dftree_'+current_folder+'_unseen');
469                        if(f_unseen && f_unseen.innerHTML)
470                                Element('new_m').innerHTML = '<font face="Verdana" size="1" color="RED">'+f_unseen.innerHTML+'</font>';
471                        else
472                        {
473                                if( parseInt(Element('new_m').innerHTML) == 0 )
474                                        Element('new_m').innerHTML = 0;
475                        }
476                        folders = data;
477                }
478}
479
480var handler_draw_box = function(data){
481        draw_box(data, 'INBOX', true);
482        //alternate_border(0);
483}
484
485// Action on change folders.
486function change_folder(folder, folder_name){
487        if (openTab.imapBox[0] != folder)
488        {
489                current_folder = folder;
490                var handler_draw_box = function(data)
491                {
492                        if(!verify_session(data))
493                                return;
494                        alternate_border(0);
495                        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>';
496                        draw_box(data, folder, true);
497                        draw_paging(data.num_msgs);
498                        Element("tot_m").innerHTML = data.num_msgs;
499                        update_menu();
500                        return true;
501                }
502                proxy_mensagens.messages_list(current_folder,1,preferences.max_email_per_page,sort_box_type,search_box_type,sort_box_reverse,preferences.preview_msg_subject,preferences.preview_msg_tip,handler_draw_box);
503        }
504        else
505                alternate_border(0);
506}
507
508function open_folder(folder, folder_name){
509        if (current_folder!= folder) {
510                current_folder = folder;
511                var handler_draw_box = function(data){
512                        if(!verify_session(data))
513                                return false;
514                        numBox++;
515                        create_border(folder_name,numBox.toString());
516                        draw_box(data, current_folder, false);
517                        alternate_border(numBox);
518                        return true;
519                }
520                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);
521        }
522        else
523                alternate_border(numBox);
524        return true;
525}
526
527var lastPage = 1;
528var numPages = 5;
529var last_folder = 'INBOX';
530function draw_paging(num_msgs){
531        num_msgs = parseInt(num_msgs);
532        total_pages = 1;
533
534        if(last_folder != current_folder){
535                lastPage = 1;
536                current_page = 1;
537                last_folder = current_folder;
538        }
539
540        if(num_msgs > parseInt(preferences.max_email_per_page)) {
541                total_pages = parseInt(num_msgs/preferences.max_email_per_page);
542                if((num_msgs/preferences.max_email_per_page) > total_pages)
543                        total_pages++;
544        }
545
546        if(total_pages == 1) {
547                if(span_paging = document.getElementById("span_paging")) {
548                        span_paging.parentNode.removeChild(span_paging);
549                }
550                return;
551        }
552        span_paging = document.getElementById("span_paging");
553        if(!span_paging){
554                span_paging = document.createElement("DIV");
555                span_paging.id = "span_paging";
556                span_paging.className = "boxHeaderText";
557                span_paging.align="right";
558                document.getElementById("div_menu_c3").appendChild(span_paging);
559        }
560        span_paging.style.width="100%";
561        span_paging.innerHTML="";
562        msg_range_begin = 1;
563        msg_range_end = preferences.max_email_per_page;
564        if(current_page != 1) {
565                lnk_page = document.createElement("A");
566                lnk_page.setAttribute("href", "javascript:current_page=1;kill_current_box(); draw_paging("+num_msgs+"); proxy_mensagens.messages_list(get_current_folder(),"+msg_range_begin+","+msg_range_end+",'"+sort_box_type+"','"+search_box_type+"',"+sort_box_reverse+","+preferences.preview_msg_subject+","+preferences.preview_msg_tip+",function handler(data){ Element(\"border_id_0\").innerHTML = \"&nbsp;\" + lang_folder(data['folder']) + \"&nbsp;<font face='Verdana' size='1' color='#505050'>[<span id='new_m'>&nbsp;</span> / <span id='tot_m'></span>]</font>\"; current_folder = data['folder']; alternate_border(0); draw_box(data, get_current_folder());});");
567        }
568        else {
569                lnk_page = document.createElement("SPAN");
570        }
571        span_paging.appendChild(lnk_page);
572
573        lnk_page.innerHTML = "&lt;&lt;";
574        lnk_page.title = get_lang("First");
575        span_paging.innerHTML += "&nbsp;";
576
577        if(current_page == lastPage + numPages)
578                lastPage = current_page - 1;
579        else if((lastPage != 1 && lastPage == current_page) || current_page == total_pages)
580                lastPage = current_page - (numPages - 1);
581        else if(current_page == 1)
582                lastPage = 1;
583
584        if(lastPage < 1)
585                lastPage = 1;
586        else if(lastPage > 1 && (lastPage > (total_pages -(numPages - 1))))
587                lastPage = total_pages -(numPages - 1);
588
589        var     hasMarked = false;
590
591        for(i = lastPage; i <= total_pages; i++) {
592
593                if(current_page == i || (i == total_pages && !hasMarked)) {
594                        lnk_page = document.createElement("SPAN");
595                        span_paging.appendChild(lnk_page);
596                        lnk_page.innerHTML = "&nbsp;<b>"+i+"</b>&nbsp;";
597                        hasMarked = true;
598                        continue;
599                }
600                else{
601                        lnk_page = document.createElement("A");
602                        span_paging.appendChild(lnk_page);
603                        msg_range_begin = ((i*preferences.max_email_per_page)-(preferences.max_email_per_page-1));
604                        msg_range_end = (i*preferences.max_email_per_page);
605                        lnk_page.setAttribute("href", "javascript:current_page="+i+";kill_current_box(); draw_paging("+num_msgs+"); proxy_mensagens.messages_list(get_current_folder(),"+msg_range_begin+","+msg_range_end+",'"+sort_box_type+"','"+search_box_type+"',"+sort_box_reverse+","+preferences.preview_msg_subject+","+preferences.preview_msg_tip+",function handler(data){Element(\"border_id_0\").innerHTML = \"&nbsp;\" + lang_folder(data['folder']) + \"&nbsp;<font face='Verdana' size='1' color='#505050'>[<span id='new_m'>&nbsp;</span> / <span id='tot_m'></span>]</font>\"; current_folder = data['folder']; alternate_border(0); draw_box(data, get_current_folder());});");
606                }
607                lnk_page.innerHTML = "&nbsp;...&nbsp;";
608                if(i == (lastPage + numPages))
609                                break;
610                else if(lastPage == 1 || i != lastPage)
611                        lnk_page.innerHTML = "&nbsp;"+i+"&nbsp;";
612                span_paging.innerHTML += "&nbsp;";
613        }
614
615        if(current_page != total_pages) {
616                lnk_page = document.createElement("A");
617                msg_range_begin = ((total_pages*preferences.max_email_per_page)-(preferences.max_email_per_page-1));
618                msg_range_end = (total_pages*preferences.max_email_per_page);
619                lnk_page.setAttribute("href", "javascript:current_page="+total_pages+";kill_current_box(); draw_paging("+num_msgs+"); proxy_mensagens.messages_list(get_current_folder(),"+msg_range_begin+","+msg_range_end+",'"+sort_box_type+"','"+search_box_type+"',"+sort_box_reverse+","+preferences.preview_msg_subject+","+preferences.preview_msg_tip+",function handler(data){Element(\"border_id_0\").innerHTML = \"&nbsp;\" + lang_folder(data['folder']) + \"&nbsp;<font face='Verdana' size='1' color='#505050'>[<span id='new_m'>&nbsp;</span> / <span id='tot_m'></span>]</font>\"; current_folder = data['folder']; alternate_border(0); draw_box(data, get_current_folder());});");
620        }
621        else {
622                lnk_page = document.createElement("SPAN");
623        }
624        span_paging.innerHTML += "&nbsp;";
625        span_paging.appendChild(lnk_page);
626
627        lnk_page.title = get_lang("Last");
628        lnk_page.innerHTML = "&gt;&gt;";
629}
630
631// stores the percentages of the cells
632var colSizes = [ ["24","24","12","12","12","16","16","20%","*","11%","11%"], ["16","16","12","12","12","20%","20%","*","10%","10%"] ];
633// stores the alignments of the cells
634var colAligns = [ ['','','','','','','','left','left','center','center'], ['','','','','','left','left','left','center','center'] ];
635var objCell = null;
636var adjCell = null;
637var cellClick = null;
638var cellResized = false;
639var maxWidth=0;
640var tblWidth=0;
641var bodyWidth=0;
642
643function changeCursorState(ev) {
644        if (cellResized)
645                cellResized = false;
646        var el = ev.target||ev.srcElement;
647        if (el.tagName != "TD")
648                el=getFirstParentOfType(el, "TD")
649        el.style.cursor ="hand";
650        el.style.cursor ="pointer";
651        var cellMouseX = (ev.clientX-parseInt(getColumnPosition(el, ev)));
652        var cellWidth = el.offsetWidth;
653        var tbl = getFirstParentOfType(el,"TABLE");
654        if (tbl.emptyBody)
655                return;
656        if ((((cellWidth-cellMouseX)<15)||((el.style.cursor=="e-resize")&&(detectLeftButton())))&&((el.className=="th_resizable")&&(el.cellIndex+1<el.parentNode.cells.length))){
657                if (tbl) tbl.style.cursor = "e-resize";
658                el.style.cursor ="e-resize";
659        }
660        else{
661                if (tbl) tbl.style.cursor = "pointer";
662                el.style.cursor ="hand";
663                el.style.cursor ="pointer";
664        }
665}
666
667function resizeColumn(ev) {
668        if (!objCell || !adjCell) {
669                stopColResize(ev);
670                return;
671        }
672        if (document.getElementById("table_message_header_box_"+numBox).emptyBody)
673                return;
674        if (objCell.style.cursor == "e-resize" && detectLeftButton(ev)) {
675                var cellIndex = objCell.cellIndex;
676                var adjIndex = adjCell.cellIndex;
677                var cellWidth = (ev.clientX-parseInt(getColumnPosition(objCell, ev)));
678
679                var tbl = getMessagesTable(objCell);
680                var trM = tbl.rows;
681                var tblType = ( (tbl.id=="table_box") ? 0 : 1);
682
683                if (cellWidth < 10) cellWidth = 10;
684                var adjWidth = maxWidth - cellWidth;
685                if (adjWidth < 10) {
686                        cellWidth = (cellWidth+adjWidth)-10;
687                        adjWidth = 10;
688                }
689
690                colSizes[tblType][adjIndex] = (colSizes[tblType][adjIndex]=="*" ? "*" : getPct(is_ie ? adjWidth : adjWidth-2));
691                colSizes[tblType][cellIndex] = (colSizes[tblType][cellIndex]=="*" ? "*" : getPct(cellWidth));
692
693                document.getElementById("table_message_ruler").style.left = ev.clientX;
694        }
695        ev.returnValue = false;
696        return (false);
697}
698
699function getPct(tdWidth) {
700        var suf = tdWidth.toString().substr(tdWidth.length-1,1);
701        if ( suf != "%" && suf != "*")
702                return (Math.round((tdWidth/bodyWidth)*10000)/100).toString()+"%";
703        else
704                return tdWidth;
705}
706
707function detectLeftButton(ev) {
708    ev = ev || window.event;
709    var button = ev.which || ev.button;
710    return (button == 1);
711}
712
713function startColResize(ev) {
714        var el = ev.target||ev.srcElement;
715        if (el.tagName != "TD")
716                el=getFirstParentOfType(el, "TD")
717        if (is_ie)
718                ev.cancelBubble = true;
719        else
720                ev.stopPropagation();
721        if (!el) return;
722        if (!is_ie) ev.preventDefault();
723        if (document.getElementById("table_message_header_box_"+numBox).emptyBody)
724                return;
725        if (el.style.cursor == "e-resize" && detectLeftButton(ev)) {
726                var incIndex = ( (el.parentNode.cells.length > el.cellIndex + 1) ? 1 : -1 );
727                var msgTable = getMessagesTable(el);
728                var bodyRows = msgTable.rows;
729                objCell = el;
730                adjCell = el.parentNode.cells[el.cellIndex+incIndex];
731                var tbl = getFirstParentOfType(el, "TABLE");
732                if (is_ie) {
733                        tbl.detachEvent("onmousemove",changeCursorState);
734                        document.attachEvent("onmousemove",resizeColumn);
735                        document.attachEvent("onmouseup",stopColResize);
736                        document.attachEvent("onselect",selectCancel);
737                        tbl.attachEvent("onselectstart",selectCancel);
738                }
739                else {
740                        tbl.removeEventListener("mousemove",changeCursorState,false);
741                        document.addEventListener("mousemove",resizeColumn,false);
742                        document.addEventListener("mouseup",stopColResize,false);
743                        document.addEventListener("select",selectCancel,false);
744                        tbl.addEventListener("selectstart",selectCancel,false);
745                }
746                cellClick = objCell.onclick;
747                objCell.onclick = "";
748                maxWidth = objCell.offsetWidth+adjCell.offsetWidth;
749                if (tblWidth==0) {
750                        tblWidth = tbl.offsetWidth;
751                        bodyWidth = msgTable.offsetWidth;
752                }
753                document.getElementById("table_message_ruler").style.display = "block";
754                document.getElementById("table_message_ruler").style.left = ev.clientX;
755                if (document.getElementById("content_id_"+numBox)==null)
756                        document.getElementById("table_message_ruler").style.height = document.getElementById("content_id_search_"+numBox).offsetHeight;
757                else
758                        document.getElementById("table_message_ruler").style.height = document.getElementById("content_id_"+numBox).offsetHeight;
759        }
760}
761
762function stopColResize(ev) {
763        if (!objCell)
764                return;
765        if (is_ie)
766                ev.cancelBubble = true;
767        else
768                ev.stopPropagation();
769        var tbl = getFirstParentOfType(objCell, "TABLE");
770        if (is_ie) {
771                tbl.detachEvent("onselectstart",selectCancel);
772                document.detachEvent("onselect",selectCancel);
773                document.detachEvent("onmousemove",resizeColumn);
774                document.detachEvent("onmouseup",stopColResize);
775                tbl.attachEvent("onmousemove",changeCursorState);
776        }
777        else {
778                tbl.removeEventListener("selectstart",selectCancel,false);
779                document.removeEventListener("select",selectCancel,false);
780                document.removeEventListener("mousemove",resizeColumn,false);
781                document.removeEventListener("mouseup",stopColResize,false);
782                tbl.addEventListener("mousemove",changeCursorState,false);
783        }
784        var trM = getMessagesTable(objCell).rows;
785        var adjIndex = adjCell.cellIndex;
786        document.getElementById("table_message_ruler").style.display = "none";
787        syncColumns();
788        maxWidth = 0;
789        objCell.onclick = cellClick;
790        objCell = null;
791        adjCell = null;
792        cellResized = true;
793}
794
795function getMessagesTable(el) {
796        var hT;
797        if (el.tagName == "TABLE")
798                hT = el;
799        else
800                hT = getFirstParentOfType(el,"TABLE");
801        return (hT.parentNode.nextSibling.childNodes[0]);
802}
803
804function getColumnPosition(oNode, pNode){
805        if (!pNode && !is_webkit){
806                var pos = getOffset(oNode);
807                return [pos.left, pos.top];
808        }
809        pNode = pNode||document.body;
810
811        var oCurrentNode = oNode;
812        var iLeft = 0;
813        var iTop = 0;
814
815        while ((oCurrentNode)&&(oCurrentNode != pNode)){
816                iLeft+=oCurrentNode.offsetLeft-oCurrentNode.scrollLeft;
817                iTop+=oCurrentNode.offsetTop-oCurrentNode.scrollTop;
818                oCurrentNode=oCurrentNode.offsetParent;
819        }
820
821        return [iLeft, iTop];
822}
823
824function getFirstParentOfType(obj, tag){
825        while (obj&&obj.tagName != tag&&obj.tagName != "BODY"){
826                obj=obj.parentNode;
827        }
828        return obj;
829}
830
831function syncColumns() {
832        var thisCell;
833        var tbl = (document.getElementById("content_id_"+numBox)==null ? 1 : 0);
834        if (objCell)
835                thisCell = objCell;
836        else
837                thisCell = document.getElementById("table_message_header_box_"+numBox).rows[0].cells[0];
838        var tbH = getFirstParentOfType(thisCell,"TABLE");
839        var tbM = getMessagesTable(thisCell);
840        var trM = tbM.rows;
841        for (var r=0;r<trM.length;r++) {
842                for (var c=0;c<trM[r].cells.length;c++) {
843                        trM[r].cells[c].setAttribute("width",colSizes[tbl][c]);
844                        if (is_mozilla && !is_webkit) {
845                                document.getElementById("colgroup_head_"+numBox).childNodes[c].setAttribute("width",colSizes[tbl][c]);
846                                trM[r].cells[c].innerHTML = trM[r].cells[c].innerHTML;
847                        }
848                        else {
849                                tbH.rows[0].cells[c].setAttribute("width",trM[r].cells[c].offsetWidth);
850                        }
851                }
852        }
853}
854
855function resizeMailList() {
856        var innerWidth = (window.innerWidth?window.innerWidth:document.body.clientWidth);
857        var scrollWidth = (innerWidth - 20 - getColumnPosition(Element("exmail_main_body"),"BODY")[0]);
858        document.getElementById("table_message_header_box_"+numBox).style.width = (scrollWidth-2)+'px';
859        if (document.getElementById("table_resultsearch_"+numBox)==null)
860                document.getElementById("table_box").style.width = scrollWidth+'px';
861        else
862                document.getElementById("table_resultsearch_"+numBox).style.width = scrollWidth+'px';
863        syncColumns();
864}
865
866function selectCancel(ev) {
867        return (false);
868}
869
870function buildColGroup(tbl) {
871        var col_element;
872        var colgr_element = document.createElement("COLGROUP");
873        if (tbl==null) tbl = 0;
874        for (i=0;i<colSizes[tbl].length;i++) {
875                col_element = document.createElement("COL");
876                //col_element.setAttribute("width", colSizes[0][i]);
877                col_element.setAttribute("align", colAligns[tbl][i]);
878                colgr_element.appendChild(col_element);
879        }
880        return (colgr_element);
881}
882
883function createTDElement(table_list,col_index,class_name,td_align,td_id) {
884        var td_element = document.createElement("TD");
885        td_element.setAttribute("width",colSizes[table_list][col_index]);
886        if (class_name) td_element.className = class_name;
887        if (td_align) td_element.align = td_align;
888        if (td_id) td_element.id = td_id;
889        return (td_element);
890}
891
892// Draw the inbox and another folders
893function draw_box(headers_msgs, msg_folder, alternate){
894        if (alternate)
895                kill_current_box();
896
897        if(is_ie)
898                document.getElementById("border_table").width = "99.5%";
899
900        openTab.content_id[numBox] = document.getElementById("content_id_"+numBox);
901        openTab.content_id[numBox].innerHTML = "";
902        openTab.imapBox[numBox] = msg_folder;
903        openTab.type[numBox] = 0;
904
905        table_message_header_box = document.getElementById("table_message_header_box_"+numBox);
906        if (table_message_header_box == null){
907                var table_element = document.createElement("TABLE");
908                var colgr_element = buildColGroup();
909                colgr_element.setAttribute("id","colgroup_head_"+numBox);
910                var tbody_element = document.createElement("TBODY");
911                //add events for column resizing
912                if (is_ie) {
913                        table_element.attachEvent("onmousemove",changeCursorState);
914                        table_element.attachEvent("onmousedown",startColResize);
915                }
916                else {
917                        table_element.addEventListener("mousemove",changeCursorState,false);
918                        table_element.addEventListener("mousedown",startColResize,false);
919                }
920                table_element.setAttribute("id", "table_message_header_box_"+numBox);
921                table_element.className = "table_message_header_box";
922                if (!is_ie)
923                        table_element.style.width = "98.8%";
924                //if table is empty
925                table_element.emptyBody = false;
926
927                tr_element = document.createElement("TR");
928                tr_element.className = "message_header";
929
930                td_element1 = createTDElement(0,0);
931                chk_box_element = document.createElement("INPUT");
932                chk_box_element.id  = "chk_box_select_all_messages";
933                chk_box_element.setAttribute("type", "checkbox");
934                chk_box_element.className = "checkbox";
935                chk_box_element.onclick = function(){select_all_messages(this.checked);};
936                chk_box_element.onmouseover = function () {this.title=get_lang('Select all messages.')};
937                chk_box_element.onkeydown = function (e){
938                        if (is_ie)
939                        {
940                                if ((window.event.keyCode) == 46)
941                                        proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
942                        }
943                        else
944                        {
945                                if ((e.keyCode) == 46)
946                                        proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
947                        }
948                };
949
950                td_element1.appendChild(chk_box_element);
951
952                td_element2 = createTDElement(0,1);
953                td_element3 = createTDElement(0,7,"th_resizable","left","message_header_SORTFROM_"+numBox);
954                td_element3.onclick = function () {sort_box(search_box_type,'SORTFROM');};
955                td_element3.innerHTML = get_lang("Who");
956
957                td_element4 = createTDElement(0,8,"th_resizable","left","message_header_SORTSUBJECT_"+numBox);
958                td_element4.onclick = function () {sort_box(search_box_type,'SORTSUBJECT');};
959                td_element4.innerHTML = get_lang("Subject");
960
961                td_element5 = createTDElement(0,9,"th_resizable","center","message_header_SORTARRIVAL_"+numBox);
962                td_element5.onclick = function () {sort_box(search_box_type,'SORTARRIVAL');};
963                td_element5.innerHTML = get_lang("Date");
964
965                td_element6 = createTDElement(0,10,"th_resizable","left","message_header_SORTSIZE_"+numBox);
966                td_element6.onclick = function () {sort_box(search_box_type,'SORTSIZE');}
967                td_element6.innerHTML = get_lang("Size");
968
969                tr_element.appendChild(td_element1);
970                tr_element.appendChild(td_element2);
971
972                var td_element21 = createTDElement(0,2);
973                td_element21.innerHTML = "&nbsp;";
974
975                var td_element22 = createTDElement(0,3);
976                td_element22.innerHTML = "&nbsp;";
977
978                var td_element23 = createTDElement(0,4);
979                td_element23.innerHTML = "&nbsp;";
980
981                var td_element24 = createTDElement(0,5);
982                td_element24.innerHTML = "&nbsp;";
983
984                var td_element25 = createTDElement(0,6);
985                td_element25.innerHTML = "&nbsp;";
986
987                tr_element.appendChild(td_element21);
988                tr_element.appendChild(td_element22);
989                tr_element.appendChild(td_element23);
990                tr_element.appendChild(td_element24);
991                tr_element.appendChild(td_element25);
992                tr_element.appendChild(td_element3);
993                tr_element.appendChild(td_element4);
994                tr_element.appendChild(td_element5);
995                tr_element.appendChild(td_element6);
996
997                tbody_element.appendChild(tr_element);
998                table_element.appendChild(tbody_element);
999                table_element.appendChild(colgr_element);
1000
1001                var _divScroll = document.getElementById("divScrollHead_"+numBox);
1002
1003                if(!_divScroll){
1004                        _divScroll = document.createElement("DIV");
1005                        _divScroll.id = "divScrollHead_"+numBox;
1006        }
1007
1008                _divScroll.style.overflowY = "hidden";
1009                _divScroll.style.overflowX = "hidden";
1010                _divScroll.style.width  ="100%";
1011
1012                if (is_mozilla){
1013                        _divScroll.style.width  ="99.3%";
1014                }
1015
1016                _divScroll.appendChild(table_element);
1017                openTab.content_id[numBox].appendChild(_divScroll);
1018
1019        }
1020        draw_header_box();
1021        var table_element = document.createElement("TABLE");
1022        var colgr_element = buildColGroup();
1023        colgr_element.setAttribute("id","colgroup_main_"+numBox);
1024
1025        var tbody_element = document.createElement("TBODY");
1026        table_element.id = "table_box";
1027        table_element.className = "table_box";
1028        table_element.borderColorDark = "#bbbbbb";
1029        table_element.frame = "void";
1030        table_element.rules = "rows";
1031        table_element.cellPadding = "0";
1032        table_element.cellSpacing = "0";
1033
1034        table_element.onkeydown = function (e){
1035                if (is_ie)
1036                {
1037                        if ((window.event.keyCode) == 46)
1038                        {
1039                                //delete_all_selected_msgs_imap();
1040                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
1041                        }
1042                }
1043                else
1044                {
1045                        if ((e.keyCode) == 46)
1046                        {
1047                                //delete_all_selected_msgs_imap();
1048                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
1049                        }
1050                }
1051        };
1052        if (is_ie)
1053                table_element.style.cursor = "hand";
1054
1055        tbody_element.setAttribute("id", "tbody_box");
1056        table_element.appendChild(tbody_element);
1057        table_element.appendChild(colgr_element);
1058
1059        var _divScroll = document.getElementById("divScrollMain_"+numBox);
1060
1061        if(!_divScroll){
1062                _divScroll = document.createElement("DIV");
1063                _divScroll.id = "divScrollMain_"+numBox;
1064        }
1065
1066        _divScroll.style.overflowY = "scroll";
1067        _divScroll.style.overflowX = "hidden";
1068        _divScroll.style.width  ="100%";
1069
1070        if (is_mozilla){
1071                _divScroll.style.overflow = "-moz-scrollbars-vertical";
1072                _divScroll.style.width  ="100%";
1073        }
1074        _divScroll.appendChild(table_element);
1075        openTab.content_id[numBox].appendChild(_divScroll);
1076
1077        var f_unseen = 0;
1078
1079        document.getElementById("table_message_header_box_"+numBox).emptyBody = false;
1080                if (headers_msgs.num_msgs == 0){
1081                document.getElementById("table_message_header_box_"+numBox).emptyBody = true;
1082                tr_info = document.createElement("TR");
1083                td_info = document.createElement("TD");
1084                h3_info = document.createElement("H3");
1085                        td_info.setAttribute("background", "#FFF");
1086                td_info.setAttribute("width","100%");
1087                h3_info.style.padding = "10px";
1088                h3_info.setAttribute("id", "msg_info");
1089                h3_info.align = "center";
1090                h3_info.innerHTML = get_lang("This mail box is empty");
1091                td_info.appendChild(h3_info);
1092                        tr_info.appendChild(td_info);
1093                tbody_element.appendChild(tr_info);
1094                }
1095        for (var i=0; i < headers_msgs.length; i++){
1096                        if ((headers_msgs[i].Unseen == 'U') || (headers_msgs[i].Recent == 'N'))
1097                                f_unseen++;
1098                        tr_element = make_tr_message(headers_msgs[i], msg_folder, headers_msgs.offsetToGMT);
1099                        if (tr_element){
1100                                tbody_element.appendChild(tr_element);
1101                                add_className(tr_element, i%2 != 0 ? 'tr_msg_read2' : 'tr_msg_read');
1102                        }
1103                        _dragArea.makeDragged(tr_element, headers_msgs[i].msg_number, headers_msgs[i].subject, true);
1104        }
1105
1106        if ((preferences.use_shortcuts == '1') && (headers_msgs[0]))
1107                select_msg(headers_msgs[0].msg_number, 'null', true);
1108
1109        var tdFolders  =  Element("folderscol");
1110        tdFolders.style.display = preferences.hide_folders == '1'  ? "none" : "";
1111        if ( !currentTab )
1112                alternate_border(numBox);
1113        draw_footer_box(headers_msgs.num_msgs);
1114        Element('main_table').style.display = '';
1115        if(is_ie6)        // Stupid Fixing on IE6.
1116                setTimeout("resizeWindow()",1);
1117        else
1118                resizeWindow();
1119        if(debug) {
1120                var _eTime = new Date();
1121                _eTime = _eTime.getTime();
1122                alert("Carregou em "+(_eTime - _bTime)+" ms");
1123        }
1124        var msg_folder = Element('msg_folder').value;
1125        var msg_number = Element('msg_number').value;
1126        if(!msg_folder && msg_number) {
1127                new_message('new','null');
1128        }
1129        else if(msg_folder && msg_number){
1130                cExecute("$this.imap_functions.get_info_msg&msg_number="+ msg_number + "&msg_folder=" + url_encode(msg_folder), show_msg);
1131                Element('msg_folder').value = '';
1132                Element('msg_number').value = '';
1133        }
1134        var scripts = new Array("InfoContact",
1135                                                        "TreeShow");
1136        connector.loadAllScripts(scripts);
1137        // Loading Quota View Folder Component (if exists...)
1138        if(Element("table_quota"))
1139                connector.loadScript("InfoQuota");
1140
1141        // creates the dotted ruler which helps user to visualize resizing of columns
1142        var ruler_element = document.getElementById("table_message_ruler");
1143        if (ruler_element == null) {
1144                ruler_element = document.createElement("DIV");
1145                ruler_element.setAttribute("id", "table_message_ruler");
1146                ruler_element.className = "table_message_ruler";
1147                ruler_element.style.top = getColumnPosition(document.getElementById("content_id_0"),"BODY")[1];
1148                document.getElementById("exmail_main_body").appendChild(ruler_element);
1149    }
1150
1151}
1152
1153// Passar o parâmetro offset para esta função
1154function make_tr_message(headers_msgs, msg_folder, offsetToGMT){
1155                if (typeof offsetToGMT == 'undefined')
1156                {
1157                    // In older local messages headers_msgs.offsetToGMT is undefined.
1158                    offsetToGMT = typeof headers_msgs.offsetToGMT != 'undefined'?headers_msgs.offsetToGMT:0;
1159                }
1160                var tr_element = document.createElement('tr');
1161                if(typeof(preferences.line_height) != 'undefined')
1162                        tr_element.style.height = preferences.line_height;
1163                tr_element.id = headers_msgs.msg_number;
1164
1165                tr_element.msg_sample = "";
1166                //if(headers_msgs.msg_sample && headers_msgs.msg_sample.preview_msg_subject != "")
1167                if(headers_msgs.msg_sample && preferences.preview_msg_subject == "1")
1168                {
1169                        tr_element.msg_sample = headers_msgs.msg_sample.body.substr(0,120) + "..."; //trecho do body que sera exibido com o assunto;
1170                }
1171
1172                tr_element.tip = "";
1173                if(headers_msgs.msg_sample && preferences.preview_msg_tip == "1")
1174                {
1175                        tr_element.tip = headers_msgs.msg_sample.body.substr(3,300) + "..."; //trecho do body que sera exibido no tool-tip;
1176                }
1177
1178                if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N')){
1179                        if ((headers_msgs.Flagged == 'F') || parseInt(preferences.use_important_flag) && headers_msgs.Importance.toLowerCase().indexOf("high")!=-1 )
1180                                add_className(tr_element, 'flagged_msg');
1181                        add_className(tr_element, 'tr_msg_unread');
1182                }
1183                else{
1184                        if ((headers_msgs.Flagged == 'F') || parseInt(preferences.use_important_flag) && headers_msgs.Importance.toLowerCase().indexOf("high")!=-1 )
1185                                add_className(tr_element,'flagged_msg');
1186                }
1187
1188                if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N'))
1189                        add_className(tr_element, 'tr_msg_unread');
1190
1191                if (headers_msgs.Flagged == 'F')
1192                        add_className(tr_element,'flagged_msg');
1193
1194                td_element1 = createTDElement(0,0,"td_msg");
1195                chk_box_element = document.createElement("INPUT");
1196                chk_box_element.setAttribute("type", "checkbox");
1197                chk_box_element.className = "checkbox";
1198                chk_box_element.setAttribute("id", "check_box_message_"+headers_msgs.msg_number);
1199                chk_box_element.onclick = function(e){
1200                        if (is_ie)
1201                                changeBgColor(window.event,headers_msgs.msg_number);
1202                        else
1203                                changeBgColor(e,headers_msgs.msg_number);
1204                };
1205                td_element1.appendChild(chk_box_element);
1206
1207                td_element2 = createTDElement(0,1,"td_msg");
1208                if (headers_msgs.attachment && headers_msgs.attachment.number_attachments > 0)
1209                        td_element2.innerHTML = "<img src ='templates/"+template+"/images/clip.gif' title='" + url_decode(headers_msgs.attachment.names) + "'>";
1210
1211                td_element21 = createTDElement(0,2,"td_msg",null,"td_message_answered_"+headers_msgs.msg_number);
1212
1213                if (headers_msgs.attachment && headers_msgs.attachment.number_attachments > 0) {
1214                        attach_name = headers_msgs.attachment.names.split(", ");
1215                        for(var item in attach_name)
1216                        {
1217                                if (url_decode(attach_name[item]) != 'smime.p7s' && url_decode(attach_name[item]) != 'smime.p7m'){
1218                                        td_element21.innerHTML = "<img src ='templates/"+template+"/images/clip.gif' title='" + url_decode(attach_name[item]) + "'>";
1219                                        break;
1220                                }
1221                        }
1222                }
1223
1224                if ((headers_msgs.Forwarded == 'F')  || (headers_msgs.Draft == 'X' && headers_msgs.Answered == 'A')){
1225                        td_element21.onclick=function(){search_emails(headers_msgs.subject.replace(/^(re: ?|fw: ?|enc: ?|res: ?|fwd: ?)*/gi,''),true);};
1226                        td_element21.innerHTML = "<img src ='templates/"+template+"/images/forwarded.gif' title='"+get_lang('Forwarded')+"'>";
1227                        headers_msgs.Draft = ''
1228                        headers_msgs.Answered = '';
1229                        headers_msgs.Forwarded = 'F';
1230                }
1231                else if (headers_msgs.Draft == 'X')
1232                        td_element21.innerHTML = "<img src ='templates/"+template+"/images/draft.gif' title='"+get_lang('Draft')+"'>";
1233                else if (headers_msgs.Answered == 'A'){
1234                        td_element21.onclick=function(){search_emails(headers_msgs.subject.replace(/^(re: ?|fw: ?|enc: ?|res: ?|fwd: ?)*/gi,''),true);};
1235                        td_element21.innerHTML = "<img src ='templates/"+template+"/images/answered.gif' title='"+get_lang('Answered')+"'>";
1236                    }else
1237                        td_element21.innerHTML = "&nbsp;&nbsp;&nbsp;";
1238
1239                td_element22 = createTDElement(0,1,"td_msg",null,"td_message_signed_"+headers_msgs.msg_number);
1240                switch(headers_msgs.ContentType)
1241                {
1242                        case "signature":
1243                        {
1244                                td_element22.innerHTML = "<img src ='templates/"+template+"/images/signed_msg.gif' title='" + get_lang('Signed message') + "'>";
1245                                break;
1246                        }
1247                        case "cipher":
1248                        {
1249                                td_element22.innerHTML = "<img src ='templates/"+template+"/images/lock.gif' title='" + get_lang('Crypted message') + "'>";
1250                                break;
1251                        }
1252                        default:
1253                        {
1254                                break;
1255                        }
1256                }
1257
1258                td_element23 = createTDElement(0,4,"td_msg",null,"td_message_important_"+headers_msgs.msg_number);
1259
1260                if (headers_msgs.Flagged == 'F' || (parseInt(preferences.use_important_flag) && headers_msgs.Importance.toLowerCase().indexOf("high") != -1 ))
1261                {
1262                        td_element23.innerHTML = "<img src ='templates/"+template+"/images/important.gif' title='"+get_lang('Important')+"'>";
1263                }
1264                else
1265                        td_element23.innerHTML = "&nbsp;&nbsp;&nbsp;";
1266
1267                td_element24 = createTDElement(0,5,"td_msg",null,"td_message_sent_"+headers_msgs.msg_number);
1268                td_element24.innerHTML = "&nbsp;&nbsp;&nbsp;";
1269                // preload image
1270                var _img_sent = new Image();
1271                _img_sent.src    = "templates/"+template+"/images/sent.gif";
1272
1273
1274
1275                td_element25 = createTDElement(0,6,"td_msg",null,"td_message_unseen_s"+headers_msgs.msg_number);
1276                if ((headers_msgs.Unseen == 'U') || (headers_msgs.Recent == 'N'))
1277                        td_element25.innerHTML = "<img src ='templates/"+template+"/images/unseen.gif' title='"+get_lang('Unseen')+"'>";
1278                else
1279                        td_element25.innerHTML = "<img src ='templates/"+template+"/images/seen.gif' title='"+get_lang('Seen')+"'>";
1280
1281
1282                td_element3 = createTDElement(0,7,"td_resizable","left","td_who_"+ headers_msgs.msg_number);
1283                var _onclick = function(){InfoContact.hide();proxy_mensagens.get_msg(headers_msgs.msg_number, msg_folder,true, show_msg);};
1284                td_element3.onclick = _onclick;
1285                td_element3.innerHTML = '&nbsp;';
1286
1287                test = true;
1288                if(msg_folder.indexOf(sentfolder) !=-1 ||msg_folder.indexOf(preferences.save_in_folder) !=-1 || msg_folder.replace("local_","INBOX/").indexOf(preferences.save_in_folder) !=-1)
1289                    test = false;
1290
1291                if(headers_msgs.from.email.toLowerCase() == Element("user_email").value.toLowerCase() && !(preferences.from_to_sent == "1" && test) && !(msg_folder.substr(0,5) == "user/"))
1292                {
1293                        td_element3.onmouseover = function () {this.title=headers_msgs.to.email;};
1294                        if (headers_msgs.Draft == 'X')
1295                                td_element3.innerHTML += "<span style=\"color:red\">("+get_lang("Draft")+") </span>";
1296                        else{
1297                                if(headers_msgs.to.email != null && headers_msgs.to.email.toLowerCase() != Element("user_email").value)
1298                                        td_element24.innerHTML = "<img valign='center' src ='templates/"+template+"/images/sent.gif' title='"+get_lang('Sent')+"'>";
1299                               
1300                                if (headers_msgs.to) {
1301                                        if (headers_msgs.to.name != null)
1302                                                td_element3.innerHTML += headers_msgs.to.name;
1303                                        else if(headers_msgs.to.email != null) {
1304                                                td_element3.innerHTML += headers_msgs.to.email;
1305                                        }
1306                                        else {
1307                                                td_element3.innerHTML += get_lang("without destination");
1308                                        }
1309                                }
1310                        }
1311                }
1312                else{
1313                        if (headers_msgs.Draft == 'X'){
1314                                td_element3.innerHTML = "<span style=\"color:red\">("+get_lang("Draft")+") </span>";
1315                        }
1316                        else{
1317                                var spanSender = document.createElement("SPAN");
1318                                spanSender.onmouseover = function (event) {this.style.textDecoration = "underline";try {InfoContact.begin(this,headers_msgs.from.email)} catch(e){};};
1319                                spanSender.onmouseout = function (){ try {this.style.textDecoration = "none"; clearTimeout(InfoContact.timeout);} catch(e){}};
1320                                spanSender.innerHTML =  headers_msgs.from.name != null ? headers_msgs.from.name : headers_msgs.from.email;
1321                                if (spanSender.innerHTML.indexOf(" ") == '-1' && spanSender.innerHTML.length > 25){
1322                                        spanSender.innerHTML = spanSender.innerHTML.substring(0,25) + "...";
1323                                }
1324                                else if (spanSender.innerHTML.length > 40 ){
1325                                        spanSender.innerHTML = spanSender.innerHTML.substring(0,40) + "...";
1326                                }
1327                                td_element3.appendChild(spanSender);
1328                        }
1329                }
1330
1331                td_element4 = createTDElement(0,8,"td_resizable","left");
1332                td_element4.onclick = _onclick;
1333                td_element4.innerHTML = !is_ie ? "<a nowrap id='a_message_"+tr_element.id+"'>&nbsp;" : "&nbsp;";
1334
1335                if ((headers_msgs.subject)&&(headers_msgs.subject.length > 50))
1336                {
1337                        //Modificacao para evitar que o truncamento do assunto quebre uma NCR - #1189
1338                        pos = headers_msgs.subject.indexOf("&",45);
1339                        if ((pos > 0) && (pos <= 50) && ((headers_msgs.subject.charAt(pos+5) == ";") || (headers_msgs.subject.charAt(pos+6) == ";")))
1340                                td_element4.innerHTML += headers_msgs.subject.substring(0,pos+6) + "..." + "<span style=\"color:#b3b3b3;\">  " + tr_element.msg_sample +"</span>";
1341                        else
1342                                td_element4.innerHTML += headers_msgs.subject.substring(0,50) + "..." + "<span style=\"color:#b3b3b3;\">  " + tr_element.msg_sample +"</span>";//modificacao feita para exibir o trecho do body ao lado do assunto da mensagem;
1343                }
1344                else
1345                {
1346                        td_element4.innerHTML += headers_msgs.subject + "<span style=\"color:#b3b3b3;\">  " + tr_element.msg_sample + "</span>";//modificacao feita para exibir o trecho do body ao lado do assunto da mensagem;
1347                }
1348
1349                td_element4.title=tr_element.tip;
1350                if(!is_ie){
1351                        td_element4.innerHTML += "</a>";
1352                }
1353
1354
1355                td_element5 = createTDElement(0,9,"td_resizable","center");
1356                td_element5.onclick = _onclick;
1357
1358                var norm = function (arg) {return (arg < 10 ? '0'+arg : arg);};
1359                var weekDays = ['Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday'];
1360
1361                var today = new Date();
1362                today.setHours(23);
1363                today.setMinutes(59);
1364                today.setSeconds(59);
1365                today.setMilliseconds(999)
1366
1367                var udate_local = null;
1368                var date_msg = null;
1369
1370                // old local messages can capture headers_msgs.udate as "hh:mm" or "dd/mm/yyyy"
1371                if (headers_msgs.udate.toString().match(/\d{2}:\d{2}/) || headers_msgs.udate.toString().match(/\d{2}\/\d{2}\/\d{4}/))
1372                {
1373                    temp_msg_day = headers_msgs.msg_day.split('/');
1374                    temp_msg_hour = headers_msgs.msg_hour.split(':');
1375                    date_msg = new Date(temp_msg_day[2], temp_msg_day[1]-1, temp_msg_day[0], temp_msg_hour[0], temp_msg_hour[1]);
1376                }
1377                else
1378                    {
1379                        // The new date implementation
1380                        // Using offset between user defined timezone and GMT
1381                        // Date object converts time to local timezone, so we have to adjust it
1382                        udate_local = headers_msgs.udate*1000 + offsetToGMT*1000 + today.getTimezoneOffset()*60*1000;
1383                        date_msg = new Date(udate_local);
1384                    }
1385
1386                if (today.getTime() - date_msg.getTime() < 86400000)
1387                        td_element5.innerHTML = norm(date_msg.getHours()) + ':' + norm(date_msg.getMinutes());
1388                else
1389                        if (today.getTime() - date_msg.getTime() < 172800000)
1390                                td_element5.innerHTML = get_lang('Yesterday');
1391                        else
1392                                if (today.getTime() - date_msg.getTime() < 259200000)
1393                                        td_element5.innerHTML = get_lang(weekDays[date_msg.getDay()]);
1394                                else
1395                                        td_element5.innerHTML = norm(date_msg.getDate()) + '/' + norm(date_msg.getMonth()+1) + '/' +date_msg.getFullYear();
1396                td_element5.title = norm(date_msg.getDate()) + '/' + norm(date_msg.getMonth()+1) + '/' +date_msg.getFullYear();
1397                td_element5.alt = td_element5.title;
1398
1399                td_element6 = createTDElement(0,10,"td_resizable","center");
1400                td_element6.onclick = _onclick;
1401                td_element6.setAttribute("noWrap","true");
1402                td_element6.innerHTML = borkb(headers_msgs.Size);
1403
1404                tr_element.appendChild(td_element1);
1405                tr_element.appendChild(td_element2);
1406                tr_element.appendChild(td_element21);
1407                tr_element.appendChild(td_element22);
1408                tr_element.appendChild(td_element23);
1409                        tr_element.appendChild(td_element24);
1410                tr_element.appendChild(td_element25);
1411                tr_element.appendChild(td_element3);
1412                tr_element.appendChild(td_element4);
1413                tr_element.appendChild(td_element5);
1414                tr_element.appendChild(td_element6);
1415                return tr_element;
1416}
1417
1418function sort_box(search, sort){
1419        if (cellResized)
1420                return;
1421        var message_header = Element("message_header_"+search);
1422        var handler_draw_box = function(data){
1423                draw_box(data, current_folder,true);
1424                //Mostrar as msgs nao lidas de acordo com o filtro de relevancia
1425        var msgs_unseen = 0;
1426                draw_paging(data.num_msgs);
1427                Element("new_m").innerHTML = '<font style="color:'+(data.tot_unseen == 0 ? '': 'red')+'">' + data.tot_unseen + '</font>';
1428                Element("tot_m").innerHTML = data.num_msgs;
1429        }
1430
1431        if(sort_box_type == sort && search_box_type == search){
1432                sort_box_reverse = sort_box_reverse ? 0 : 1;
1433        }
1434        else if(sort_box_type != sort){
1435                if ( (sort == 'SORTFROM') || (sort == 'SORTSUBJECT') )
1436                        sort_box_reverse = 0;
1437                else
1438                        sort_box_reverse = 1;
1439        }
1440
1441        // Global variable.
1442        sort_box_type = sort;
1443        search_box_type = search;
1444
1445        proxy_mensagens.messages_list(current_folder,1,preferences.max_email_per_page,sort,search,sort_box_reverse,preferences.preview_msg_subject,preferences.preview_msg_tip,handler_draw_box);
1446        current_page = 1;
1447        //Comentado para nao sobrepor o numero de msgs nao lidas ao utilizar os filtros
1448        //update_menu();
1449}
1450function draw_header_box(){
1451        switch(sort_box_type){
1452                case 'SORTFROM':
1453                        type_name = get_lang("Who");
1454                        break;
1455                case 'SORTSUBJECT':
1456                        type_name = get_lang("Subject");
1457                        break;
1458                case 'SORTARRIVAL':
1459                        type_name = get_lang("Date");
1460                        break;
1461                case 'SORTSIZE':
1462                        type_name = get_lang("Size");
1463                        break;
1464                default:
1465                        type_name = get_lang("Date");
1466                        break;
1467        }
1468        document.getElementById("message_header_SORTFROM_"+numBox).innerHTML    = get_lang("Who");
1469        document.getElementById("message_header_SORTSUBJECT_"+numBox).innerHTML = get_lang("Subject");
1470        document.getElementById("message_header_SORTARRIVAL_"+numBox).innerHTML = get_lang("Date");
1471        document.getElementById("message_header_SORTSIZE_"+numBox).innerHTML    = get_lang("Size");
1472        document.getElementById("message_header_"+(sort_box_type.lastIndexOf("SORT") != "-1" ? sort_box_type : "SORTARRIVAL")+"_"+numBox ).innerHTML = "<B>"+type_name+"</B><img src ='templates/"+template+"/images/arrow_"+(sort_box_reverse == 1 ? 'desc' : 'asc')+"endant.gif'>";
1473}
1474function draw_message(info_msg, ID){
1475        var content = document.getElementById('content_id_' + ID);
1476
1477        var menuHidden = Element("folderscol").style.display == 'none' ? true : false;
1478         //////////////////////////////////////////////////////////////////////////////////////////////////////
1479        //Make the next/previous buttom.
1480        //////////////////////////////////////////////////////////////////////////////////////////////////////
1481        var next_previous_msg_td = document.createElement("TD");
1482        next_previous_msg_td.setAttribute("noWrap","true");
1483        next_previous_msg_td.align = "right";
1484        next_previous_msg_td.width = "40px";
1485        var img_next_msg = document.createElement("IMG");
1486        img_next_msg.id = 'msg_opt_next_' + ID;
1487        img_next_msg.src = './templates/'+template+'/images/down.button.png';
1488        img_next_msg.title = get_lang('Next');
1489        img_next_msg.style.cursor = 'pointer';
1490
1491        var folder_id = ID.match(/\d+/)[0];
1492        var folder;
1493
1494        //Correção para fazer funcionar e-mails assinados no formato encapsulado.
1495       // folder_id = info_msg.original_ID ? info_msg.original_ID: info_msg.msg_number;
1496        if ((folder = document.getElementById(info_msg.original_ID)) == null)
1497        //if ((folder = document.getElementById(info_msg.msg_number)) == null)
1498            folder = document.getElementById(info_msg.msg_number);
1499        if (!folder){
1500                delete_border(ID);
1501                return;
1502                }
1503        if (folder){ // mensagem local criptografada nao tem ID da pasta local
1504                if (folder.nextSibling){
1505                        var nextMsgBox = folder.nextSibling.name?folder.nextSibling.name:info_msg.msg_folder;
1506
1507                        if (nextMsgBox == "INBOX/decifradas")// teste para ver se a mensagem vem da pasta oculta decifradas
1508                                        nextMsgBox = get_current_folder();
1509
1510                        img_next_msg.onclick = function()
1511                        {
1512                                currentTab = ID;
1513                                openTab.type[ID] = 2;
1514                                proxy_mensagens.get_msg(folder.nextSibling.id,nextMsgBox,true,show_msg);
1515                        };
1516                }
1517                else
1518                {
1519                        img_next_msg.src = "./templates/"+template+"/images/down.gray.button.png";
1520                        img_next_msg.style.cursor = 'default';
1521
1522                }
1523        }
1524        else
1525        {
1526                img_next_msg.src = "./templates/"+template+"/images/down.gray.button.png";
1527                img_next_msg.style.cursor = 'default';
1528                if (!proxy_mensagens.is_local_folder(get_current_folder()) && !(info_msg.msg_folder == "INBOX/decifradas")) // testa se a mensagem e local
1529                {
1530                        img_next_msg.onclick = function()
1531                                {
1532                                        delete_border(ID);
1533                                };
1534                }
1535        }
1536        var img_space = document.createElement("SPAN");
1537        img_space.innerHTML = "&nbsp;";
1538        var img_previous_msg = document.createElement("IMG");
1539        img_previous_msg.id = 'msg_opt_previous_' + ID;
1540        img_previous_msg.src = './templates/'+template+'/images/up.button.png';
1541        img_previous_msg.title = get_lang('Previous');
1542        img_previous_msg.style.cursor = 'pointer';
1543
1544        if (!folder){
1545                        delete_border(ID);
1546                return;
1547                }
1548        if (folder){ // mensagem local criptografada nao tem ID da pasta local
1549                if (folder.previousSibling)
1550                {
1551                        var previousMsgBox = folder.previousSibling.name?folder.previousSibling.name:info_msg.msg_folder;
1552
1553                        if (previousMsgBox == "INBOX/decifradas") // teste para ver se a mensagem vem da pasta oculta decifradas
1554                                        previousMsgBox = get_current_folder();
1555
1556                        img_previous_msg.onclick = function()
1557                        {
1558                                currentTab = ID;
1559                                openTab.type[ID] = 2;
1560                                proxy_mensagens.get_msg(folder.previousSibling.id,previousMsgBox,true,show_msg);
1561                        };
1562                }
1563                else
1564                {
1565                        img_previous_msg.src = "./templates/"+template+"/images/up.gray.button.png";
1566                        img_previous_msg.style.cursor = 'default';
1567                }
1568        }
1569        else
1570        {
1571                img_previous_msg.src = "./templates/"+template+"/images/up.gray.button.png";
1572                img_previous_msg.style.cursor = 'default';
1573                if (!proxy_mensagens.is_local_folder(get_current_folder()) && !(info_msg.msg_folder == "INBOX/decifradas")) // testa se a mensagem e local
1574                {
1575                        img_previous_msg.onclick = function()
1576                        {
1577                                delete_border(ID);
1578                        };
1579                }
1580        }
1581        next_previous_msg_td.appendChild(img_previous_msg);
1582        next_previous_msg_td.appendChild(img_space);
1583        next_previous_msg_td.appendChild(img_next_msg);
1584        //////////////////////////////////////////////////////////////////////////////////////////////////////
1585        //Make the header message.
1586        //////////////////////////////////////////////////////////////////////////////////////////////////////
1587        var table_message = document.createElement("TABLE");
1588        var tbody_message = document.createElement("TBODY");
1589        table_message.border = "0";
1590        table_message.width = "100%";
1591
1592        //////////////////////////////////////////////////////////////////////////////////////////////////////
1593        //Make the options message.
1594        //////////////////////////////////////////////////////////////////////////////////////////////////////
1595        var tr0 = document.createElement("TR");
1596        tr0.className = "tr_message_header";
1597        var td0 = document.createElement("TD");
1598        var table_message_options = document.createElement("TABLE");
1599        table_message_options.width = "100%";
1600        table_message_options.border = '0';
1601        table_message_options.className = 'table_message';
1602        var tbody_message_options = document.createElement("TBODY");
1603        var tr = document.createElement("TR");
1604        var td = document.createElement("TD");
1605        td.setAttribute("noWrap","true");
1606        var _name = '';
1607        var _maxChar = menuHidden ? 40 : 15;
1608
1609        if (info_msg.from.name)
1610        {
1611                var spanName = document.createElement("SPAN");
1612                        spanName.innerHTML = info_msg.from.name;
1613                _name = spanName.innerHTML.length > _maxChar ? spanName.innerHTML.substring(0,_maxChar) + "..." : spanName.innerHTML;
1614        }
1615        else
1616                _name = info_msg.from.email.length > _maxChar ? info_msg.from.email.substring(0,_maxChar) + "..." : info_msg.from.email;
1617
1618        td.innerHTML = _name.bold() + ', ' + info_msg.smalldate;
1619        if (info_msg.attachments && info_msg.attachments.length > 0)
1620                td.innerHTML += "&nbsp<img style='cursor:pointer' onclick='javascript:Element(\"option_hide_more_"+ID+"\").onclick()' src ='templates/"+template+"/images/clip.gif' title='"+info_msg.attachments[0].name+"'>";
1621
1622        if (typeof(info_msg.signature) == 'string')
1623        {
1624                if (info_msg.signature != "void")
1625                        td.innerHTML += '&nbsp;<img style="cursor:pointer" onclick="alert(\''+ get_lang("This message is signed, and you can trust.") + info_msg.signature +'\');" src="templates/'+template+'/images/signed.gif">';
1626                else
1627                        td.innerHTML += "&nbsp;<img style='cursor:pointer' onclick='alert(\""+get_lang("This message is signed, but it is invalid. You should not trust on it.")+"\");' title='"+get_lang("Voided message")+"' src='templates/"+template+"/images/invalid.gif'>";
1628        }
1629       
1630        if (info_msg.DispositionNotificationTo)
1631        {
1632                td.innerHTML += '&nbsp;<img id="disposition_notification_'+ID+'" style="cursor:pointer" alt="'+ get_lang('Message with read notification') + '" title="'+ get_lang('Message with read notification') + '" src="templates/'+template+'/images/notification.gif">';
1633        }
1634
1635        // NORMAL MSG
1636        if(info_msg.Draft != 'X')
1637        {
1638        var options = document.createElement("TD");
1639        options.width = "30%";
1640        options.setAttribute("noWrap","true");
1641        var option_hide_more = document.createElement("SPAN");
1642        option_hide_more.className = 'message_options';
1643        option_hide_more.onmouseover=function () { this.className='message_options_active'; };
1644        option_hide_more.onmouseout=function () { this.className='message_options' };
1645        options.align = 'right';
1646        option_hide_more.value = 'more_options';
1647        option_hide_more.id = 'option_hide_more_'+ID;
1648        option_hide_more.onclick = function(){
1649                if (this.value == 'more_options'){
1650                        this.innerHTML = "<b><u>"+get_lang('Hide details')+"</u></b>";
1651                        this.value = 'hide_options';
1652                        Element('table_message_others_options_'+ID).style.display = '';
1653                }
1654                else{
1655                        this.innerHTML = get_lang('Show details');
1656                        this.value = 'more_options';
1657                        Element('table_message_others_options_'+ID).style.display = 'none';
1658                }
1659                resizeWindow();
1660        };
1661        var option_mark = document.createElement('TD');
1662        option_mark.align = "left";
1663        option_mark.width = "50%";
1664        var option_mark_as = '<span>'+get_lang("Mark as")+'</span>: ';
1665        var option_mark_as_unseen = document.createElement("SPAN");
1666        option_mark_as_unseen.className = "message_options";
1667        option_mark_as_unseen.onclick = function () { changeLinkState(this,'seen');
1668                proxy_mensagens.proxy_set_message_flag(folder_id,'unseen');
1669                write_msg(get_lang('Message marked as ')+get_lang("Unseen"));
1670        };
1671        option_mark_as_unseen.onmouseover=function () { this.className='message_options_active'; };
1672        option_mark_as_unseen.onmouseout=function () { this.className='message_options' };
1673        option_mark_as_unseen.innerHTML = get_lang("Unseen");
1674
1675        var option_mark_important = document.createElement("SPAN");
1676        option_mark_important.className = 'message_options';
1677        option_mark_important.style.paddingLeft = "10px";
1678        option_mark_important.onmouseover=function () { this.className='message_options_active'; };
1679        option_mark_important.onmouseout=function () { this.className='message_options' };
1680
1681        if (info_msg.Flagged == "F"){
1682                option_mark_important.onclick = function() {
1683                        var _this = this;
1684                        proxy_mensagens.proxy_set_message_flag(folder_id,'unflagged', function(success){
1685                                if (success) {
1686                                        changeLinkState(_this, 'important');
1687                                        write_msg(get_lang('Message marked as ') + get_lang("Normal"));
1688                                }
1689                        } );
1690                       
1691                };
1692                option_mark_important.innerHTML = get_lang("Normal");
1693        }
1694        else{
1695                option_mark_important.onclick = function() { changeLinkState(this,'normal');
1696                        proxy_mensagens.proxy_set_message_flag(folder_id,'flagged');
1697                        write_msg(get_lang('Message marked as ')+get_lang("Important"));
1698                };
1699                option_mark_important.innerHTML = get_lang("Important");
1700        }
1701        option_mark.innerHTML = option_mark_as;
1702        option_mark.appendChild(option_mark_as_unseen);
1703        option_mark.appendChild(option_mark_important);
1704        option_hide_more.innerHTML = get_lang('Show details');
1705        options.appendChild(option_hide_more);
1706
1707        var space0 = document.createElement("SPAN");
1708        space0.innerHTML = '&nbsp;|&nbsp;';
1709        var space1 = document.createElement("SPAN");
1710        space1.innerHTML = '&nbsp;|&nbsp;';
1711        var space2 = document.createElement("SPAN");
1712        space2.innerHTML = '&nbsp;|&nbsp;';
1713
1714        var option_forward = document.createElement("SPAN");
1715        option_forward.id = 'msg_opt_forward_'+ID;
1716        option_forward.className = 'message_options';
1717        option_forward.onclick = function(){new_message('forward', ID);};
1718        option_forward.onmouseover=function () { this.className='message_options_active'; };
1719        option_forward.onmouseout=function () { this.className='message_options' };
1720        option_forward.innerHTML = get_lang('Forward');
1721        options.appendChild(space1);
1722        options.appendChild(option_forward);
1723        var option_reply = document.createElement("SPAN");
1724        option_reply.id = 'msg_opt_reply_'+ID;
1725        option_reply.className = 'message_options';
1726        option_reply.onclick = function(){new_message('reply_with_history', ID);};
1727        option_reply.innerHTML = get_lang('Reply');
1728        option_reply.onmouseover=function () { this.className='message_options_active'; };
1729        option_reply.onmouseout=function () { this.className='message_options' };
1730
1731        options.appendChild(space2);
1732
1733        var option_reply_options = document.createElement('IMG');
1734        option_reply_options.id = 'msg_opt_reply_options_'+ID;
1735        option_reply_options.src = '../expressoMail1_2/templates/default/images/down.png';
1736        option_reply_options.value = 'show';
1737
1738        option_reply_options.onmouseover = function(){
1739                option_reply_options.src= '../expressoMail1_2/templates/default/images/over.png';
1740        };
1741        option_reply_options.onmouseout = function(){
1742                if (this.value == 'show')
1743                {
1744                        option_reply_options.src= '../expressoMail1_2/templates/default/images/down.png';
1745                }
1746                else
1747                {
1748                        option_reply_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
1749                }
1750        };
1751        option_reply_options.onclick = function(){
1752                if (this.value != 'hide'){
1753                        this.value = 'hide';
1754                        option_reply_options.src= '../expressoMail1_2/templates/default/images/pressed.png';
1755                        Element('tr_other_options_'+ID).style.display = '';
1756
1757                }
1758                else{
1759                        this.value = 'show';
1760                        option_reply_options.src= '../expressoMail1_2/templates/default/images/down.png';
1761                        Element('tr_other_options_'+ID).style.display = 'none';
1762                }
1763        };
1764        options.appendChild(option_reply_options);
1765        options.appendChild(option_reply);
1766
1767        tr.appendChild(td);
1768        tr.appendChild(option_mark);
1769        tr.appendChild(options);
1770        tr.appendChild(next_previous_msg_td);
1771        tbody_message_options.appendChild(tr);
1772
1773        ////////// OTHER OPTIONS ////////////////////
1774        var tr_other_options = document.createElement("TR");
1775        tr_other_options.id = 'tr_other_options_' + ID;
1776        tr_other_options.style.display = 'none';
1777
1778        var td_other_options = document.createElement("TD");
1779        td_other_options.colSpan = '3';
1780        var div_other_options = document.createElement("DIV");
1781
1782        var option_mark_as_unseen = '<span class="message_options" onclick="proxy_mensagens.proxy_set_messages_flag(\'unseen\','+info_msg.msg_number+');write_msg(\''+get_lang('Message marked as ')+get_lang("Unseen")+'.\');">'+get_lang("Unseen")+'</span>, ';
1783        var option_mark_as_important                    = '<span class="message_options" onclick="proxy_mensagens.proxy_set_messages_flag(\'flagged\','+info_msg.msg_number+');write_msg(\''+get_lang('Message marked as ')+get_lang("Important")+'.\');">'+get_lang("Important")+'</span>, ';
1784        var option_mark_as_normal                               = '<span class="message_options" onclick="proxy_mensagens.proxy_set_messages_flag(\'unflagged\','+info_msg.msg_number+');write_msg(\''+get_lang('Message marked as ')+get_lang("Normal")+'.\');">'+get_lang("Normal")+'</span> | ';
1785
1786        var option_move = '<span class="message_options" onclick=wfolders.makeWindow("'+ID+'","move_to");>'+get_lang("Move")+'</span> | ';
1787        var option_reply_to_all = '<span onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options" onclick=new_message("reply_to_all_with_history","'+ID+'");>'+get_lang("Reply to all")+'</span> | ';
1788        var option_reply_without_history = '<span onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options" onclick=new_message("reply_without_history","'+ID+'");>'+get_lang("Reply without history")+'</span> | ';
1789        var option_reply_to_all_without_history = '<span onmouseover="this.className=\'reply_options_active\'" onmouseout="this.className=\'reply_options\'" class="reply_options" onclick=new_message("reply_to_all_without_history","'+ID+'");>'+get_lang("Reply to all without history")+'</span>';
1790
1791        div_other_options.innerHTML = option_reply_to_all + option_reply_without_history + option_reply_to_all_without_history;
1792        if (use_spam_filter) {
1793                if(info_msg.msg_folder == 'INBOX'+cyrus_delimiter+'Spam')
1794                        div_other_options.innerHTML += ' | <span class="message_options" onclick="nospam('+info_msg.msg_number+',\'null\', \''+info_msg.msg_folder+'\')";>'+get_lang("Not Spam")+'</span>';
1795                else
1796                        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>';
1797        }
1798        td_other_options.align = 'right';
1799        td_other_options.style.paddingTop = '3px';
1800        td_other_options.appendChild(div_other_options);
1801
1802
1803        tr_other_options.appendChild(td_other_options);
1804        tbody_message_options.appendChild(tr_other_options);
1805        ////////// END OTHER OPTIONS ////////////////
1806
1807                ////////// BEGIN SIGNATURE //////////////////
1808        if (info_msg.signature && info_msg.signature.length > 0)
1809        {
1810            var tr_signature = document.createElement("TR");
1811            var td_signature = document.createElement("TD");
1812            td_signature.className = 'tr_message_header';
1813            tr_signature.id = 'tr_signature_'+ID;
1814            td_signature.colSpan = "5";
1815            tr_signature.style.display = 'none';
1816            for (i in info_msg.signature)
1817                {
1818                    if(typeof(info_msg.signature[i]) == 'object')
1819                        {
1820                            var aux = '';
1821                            for (ii in info_msg.signature[i])
1822                                {
1823                                    if(info_msg.signature[i][ii].indexOf("###") > -1)
1824                                        {
1825                                         aux += get_lang(info_msg.signature[i][ii].substring(0,info_msg.signature[i][ii].indexOf("###"))) + info_msg.signature[i][ii].substring(info_msg.signature[i][ii].indexOf("###")+3);
1826                                        }
1827                                    else
1828                                        {
1829                                         aux += info_msg.signature[i][ii];
1830                                        }
1831                                }
1832                            td_signature.innerHTML += "<a onclick=\"javascript:alert('" + aux + "')\"><b><font color=\"#0000FF\">" + get_lang("More") + "...</font></b></a>";
1833                            continue;
1834                        }
1835                    if(info_msg.signature[i].indexOf("#@#") > -1)
1836                        {
1837                         td_signature.innerHTML += '<span style=color:red><strong>'+get_lang(info_msg.signature[i].substring(0,info_msg.signature[i].indexOf("#@#")))+'</strong> '+info_msg.signature[i].substring(info_msg.signature[i].indexOf("#@#")+3)+'</span> <br /> ';
1838                        }
1839                    if(info_msg.signature[i].indexOf("###") > -1)
1840                        {
1841                         td_signature.innerHTML += '<span><strong>'+get_lang(info_msg.signature[i].substring(0,info_msg.signature[i].indexOf("###")))+'</strong> '+info_msg.signature[i].substring(info_msg.signature[i].indexOf("###")+3)+'</span> <br /> ';
1842                        }
1843                }
1844            var signature_status_pos = info_msg.signature[0].indexOf('Message untouched');
1845            td_signature.id = "td_signature_"+ID;
1846            if(signature_status_pos < 0 )
1847                {
1848                    td.innerHTML += '&nbsp;<img style="cursor:pointer" src="templates/'+template+'/images/signed_error.gif" title="'+get_lang("Details")+'">';
1849                    tr_signature.style.display = '';
1850                }
1851            else
1852                {
1853                    td.innerHTML += '&nbsp;<img style="cursor:pointer" src="templates/'+template+'/images/signed_table.gif" title="'+get_lang("Details")+'">';
1854                }
1855            td.onclick = function(){
1856            var _height = Element("div_message_scroll_"+ID).style.height;
1857            _height = parseInt(_height.replace("px",""));
1858            var _offset = 130;
1859            if (this.value == 'more_cert'){
1860                this.value = 'hide_cert';
1861                Element("div_message_scroll_"+ID).style.height = (_height + _offset)+"px";
1862                Element('tr_signature_'+ID).style.display = 'none';
1863                Element('td_signature_'+ID).style.display = 'none';
1864
1865            }
1866            else{
1867                //this.innerHTML += "Mais Informaᅵᅵes";
1868                this.value = 'more_cert';
1869                Element("div_message_scroll_"+ID).style.height = (_height - _offset)+"px";
1870                Element('tr_signature_'+ID).style.display = '';
1871                Element('td_signature_'+ID).style.display = '';
1872            }
1873        };
1874
1875            tr_signature.appendChild(td_signature);
1876            tbody_message_options.appendChild(tr_signature);
1877        }
1878        //////////// END SIGNATURE ////////////////
1879
1880        table_message_options.appendChild(tbody_message_options);
1881        td0.appendChild(table_message_options);
1882        tr0.appendChild(td0);
1883        tbody_message.appendChild(tr0);
1884        }
1885        // IF DRAFT
1886        else
1887        {
1888                var options = document.createElement("TD");
1889                options.width = "1%";
1890                options.setAttribute("noWrap","true");
1891                var option_edit   = ' | <span class="message_options" onclick="new_message(\'edit\',\''+ID+'\');">'+get_lang('Edit')+'</span>';
1892                var option_print = ' | <span class="message_options" onclick="print_msg(\''+info_msg.msg_folder+'\',\''+info_msg.msg_number+'\',\''+ID+'\');">'+get_lang('Print')+'</span>';
1893                var option_hide_more = document.createElement("SPAN");
1894                option_hide_more.className = 'message_options';
1895                options.align = 'right';
1896                option_hide_more.value = 'more_options';
1897                option_hide_more.id = 'option_hide_more_'+ID;
1898                option_hide_more.innerHTML = get_lang('Show details');
1899                option_hide_more.onclick = function(){
1900                        var _height = Element("div_message_scroll_"+ID).style.height;
1901                        _height = parseInt(_height.replace("px",""));
1902                        var _offset = 35;
1903                        if (this.value == 'more_options'){
1904                                this.innerHTML = "<b><u>"+get_lang('Hide details')+"</u></b>";
1905                                this.value = 'hide_options';
1906                                Element("div_message_scroll_"+ID).style.height = (_height - _offset)+"px";
1907                                Element('table_message_others_options_'+ID).style.display = '';
1908                        }
1909                        else{
1910                                this.innerHTML = get_lang('Show details');
1911                                this.value = 'more_options';
1912                                Element("div_message_scroll_"+ID).style.height = (_height + _offset)+"px";
1913                                Element('table_message_others_options_'+ID).style.display = 'none';
1914                        }
1915                };
1916                options.appendChild(option_hide_more);
1917                options_actions = document.createElement('SPAN');
1918                options_actions.innerHTML = option_edit + option_print;
1919                options.appendChild(options_actions);
1920                tr.appendChild(td);
1921                tr.appendChild(options);
1922                tr.appendChild(next_previous_msg_td);
1923                tbody_message_options.appendChild(tr);
1924                table_message_options.appendChild(tbody_message_options);
1925                td0.appendChild(table_message_options);
1926                tr0.appendChild(td0);
1927                tbody_message.appendChild(tr0);
1928               
1929                var important_message = document.createElement("INPUT");
1930                important_message.id = "is_important_"+ID;
1931                important_message.name = "is_important";
1932                important_message.type = "HIDDEN";
1933                important_message.value = (info_msg.Importance == "" || info_msg.Importance == "Normal") ? "0": "1";
1934               
1935                options.appendChild(important_message);
1936        }
1937        //////////////////////////////////////////////////////////////////////////////////////////////////////
1938        // END options message.
1939        //////////////////////////////////////////////////////////////////////////////////////////////////////
1940
1941        var table_message_others_options = document.createElement("TABLE");
1942        table_message_others_options.id = 'table_message_others_options_' + ID;
1943        table_message_others_options.width = "100%";
1944        table_message_others_options.style.display = 'none';
1945        table_message_others_options.className = "table_message";
1946        var tbody_message_others_options = document.createElement("TBODY");
1947        var tr1 = document.createElement("TR");
1948        tr1.className = "tr_message_header";
1949        var td1 = document.createElement("TD");
1950        td1.innerHTML = get_lang("From: ");
1951        td1.appendChild(deny_email(info_msg.from.email));
1952        td1.width = "7%";
1953
1954        if (info_msg.sender){
1955                var tr111 = document.createElement("TR");
1956                tr111.className = "tr_message_header";
1957                var td111 = document.createElement("TD");
1958                td111.innerHTML = get_lang("Sent by")+": ";
1959                td111.appendChild(deny_email(info_msg.sender.email));
1960                td111.setAttribute("noWrap","true");
1961                var sender = document.createElement("TD");
1962                sender.id = "sender_"+ID;
1963                var sender_values = document.createElement("INPUT");
1964                sender_values.id = "sender_values_"+ID;
1965                sender_values.type = "HIDDEN";
1966                sender_values.value = info_msg.sender.full; //Veio do IMAP, sem images nem links.
1967                sender.innerHTML += draw_plugin_cc(ID, info_msg.sender.full);
1968                sender.className = "header_message_field";
1969                tr111.appendChild(td111);
1970                tr111.appendChild(sender);
1971                tr111.appendChild(sender_values);
1972                tbody_message_others_options.appendChild(tr111);
1973        }
1974
1975        var from = document.createElement("TD");
1976        from.id = "from_"+ID;
1977        from.innerHTML = info_msg.from.full;
1978        if (info_msg.Draft != "X"){
1979                from.innerHTML += draw_plugin_cc(ID, info_msg.from);
1980                tbody_message_others_options.appendChild(tr1);
1981        }
1982        from.className = "header_message_field";
1983        var from_values = document.createElement("INPUT");
1984        from_values.id = "from_values_"+ID;
1985        from_values.type = "HIDDEN";
1986        from_values.value = info_msg.from.full; //Veio do IMAP, sem images nem links.
1987
1988        var local_message = document.createElement("INPUT");
1989        local_message.id = "is_local_"+ID;
1990        local_message.name = "is_local";
1991        local_message.type = "HIDDEN";
1992        local_message.value = (info_msg.local_message)?"1":"0";
1993
1994        tr1.appendChild(td1);
1995        tr1.appendChild(from);
1996        tr1.appendChild(from_values);
1997        tr1.appendChild(local_message);
1998
1999        if (info_msg.reply_to){
2000                var tr11 = document.createElement("TR");
2001                tr11.className = "tr_message_header";
2002                var td11 = document.createElement("TD");
2003                td11.innerHTML = get_lang("Reply to")+": ";
2004                td11.setAttribute("noWrap","true");
2005                var reply_to = document.createElement("TD");
2006                reply_to.id = "reply_to_"+ID;
2007
2008                var reply_to_values = document.createElement("INPUT");
2009                reply_to_values.id = "reply_to_values_"+ID;
2010                reply_to_values.type = "HIDDEN";
2011                reply_to_values.value = info_msg.reply_to; //Veio do IMAP, sem images nem links.
2012                reply_to.innerHTML = draw_plugin_cc(ID, info_msg.reply_to);
2013                reply_to.className = "header_message_field";
2014                tr11.appendChild(td11);
2015                tr11.appendChild(reply_to);
2016                tr11.appendChild(reply_to_values);
2017                tbody_message_others_options.appendChild(tr11);
2018        }
2019        //////////////////////////////////////////////////////////////////////////////////////////////////////
2020        var tr2 = document.createElement("TR");
2021        tr2.className = "tr_message_header";
2022        var td2 = document.createElement("TD");
2023        td2.innerHTML = get_lang("To: ");
2024        var to = document.createElement("TD");
2025        to.id = "to_"+ID;
2026
2027        var to_values = document.createElement("INPUT");
2028        to_values.id = "to_values_"+ID;
2029        to_values.type = "HIDDEN";
2030        to_values.value = info_msg.toaddress2; //Veio do IMAP, sem images nem links.
2031
2032        // Salva a pasta da mensagem
2033        var input_current_folder = document.createElement('input');
2034        input_current_folder.id = "input_folder_"+ID;
2035        input_current_folder.name = "input_folder";
2036        input_current_folder.type = "hidden";
2037        input_current_folder.value = info_msg.msg_folder;
2038        td2.appendChild(input_current_folder);
2039        // fim
2040        // ALEXANDRE LUIZ CORREIA
2041        if(info_msg.toaddress2 != null )
2042        {
2043                toaddress_array[ID] = info_msg.toaddress2.split(",");
2044               
2045                if (toaddress_array[ID].length > 1)
2046                {
2047                        to.innerHTML += draw_plugin_cc(ID, toaddress_array[ID][0]);
2048                        var div_toaddress = document.createElement("SPAN");
2049                        div_toaddress.id = "div_toaddress_"+ID;
2050                        div_toaddress.style.display="";
2051                        div_toaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','to');>"+get_lang('more')+"</a>)";
2052                        to.appendChild(div_toaddress);
2053                }
2054                else
2055                {
2056                        toAdd = toaddress_array[ID].toString()
2057                        if( trim(toAdd) != "" ) {
2058                                toAdd = toAdd.replace("<","&lt;").replace(">","&gt;");
2059                        } else {
2060                                toAdd = get_lang("without destination");
2061                        }
2062                       
2063                        to.innerHTML += draw_plugin_cc(ID,toAdd);
2064                }
2065       
2066                to.className = "header_message_field";
2067                tr2.appendChild(td2);
2068                tr2.appendChild(to);
2069                tr2.appendChild(to_values);
2070        }
2071       
2072        tbody_message_others_options.appendChild(tr2);
2073
2074        if (info_msg.cc){
2075                var tr3 = document.createElement("TR");
2076                tr3.className = "tr_message_header";
2077                var td3 = document.createElement("TD");
2078                td3.innerHTML = "CC: ";
2079                var cc = document.createElement("TD");
2080                cc.id = "cc_"+ID;
2081
2082                var cc_values = document.createElement("INPUT");
2083                cc_values.id = "cc_values_"+ID;
2084                cc_values.type = "HIDDEN";
2085                cc_values.value = info_msg.cc;
2086
2087                ccaddress_array[ID] = info_msg.cc.split(",");
2088                if (ccaddress_array[ID].length > 1){
2089                        var div_ccaddress = document.createElement("SPAN");
2090                        div_ccaddress.id = "div_ccaddress_"+ID;
2091                        var div_ccaddress_full = document.createElement("SPAN");
2092                        div_ccaddress_full.id = "div_ccaddress_full_"+ID;
2093                        div_ccaddress.style.display="";
2094                        cc.innerHTML = draw_plugin_cc(ID, ccaddress_array[ID][0]);
2095                        div_ccaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','cc');>"+get_lang('more')+"</a>)";
2096                        cc.appendChild(div_ccaddress);
2097                }
2098                else{
2099                        cc.innerHTML = draw_plugin_cc(ID, info_msg.cc);
2100                }
2101                cc.className = "header_message_field";
2102                tr3.appendChild(td3);
2103                tr3.appendChild(cc);
2104                tr3.appendChild(cc_values);
2105                tbody_message_others_options.appendChild(tr3);
2106        }
2107
2108        /*
2109         * @AUTHOR Rodrigo Souza dos Santos
2110         * @MODIFY-DATE 2008/09/11
2111         * @BRIEF Adding routine to create bcc field if there is one.
2112         */
2113        if (info_msg.bcc)
2114        {
2115                var tr3 = document.createElement("tr");
2116                tr3.className = "tr_message_header";
2117                var td3 = document.createElement("td");
2118                td3.innerHTML = get_lang("BCC") + " : ";
2119                var cco = document.createElement("td");
2120                cco.id = "cco_"+ID;
2121
2122                var cco_values = document.createElement("input");
2123                cco_values.id = "cco_values_"+ID;
2124                cco_values.type = "hidden";
2125                cco_values.value = info_msg.bcc;
2126
2127                ccoaddress_array[ID] = info_msg.bcc.split(",");
2128                if (ccoaddress_array[ID].length > 1){
2129                        var div_ccoaddress = document.createElement("SPAN");
2130                        div_ccoaddress.id = "div_ccoaddress_"+ID;
2131                        var div_ccoaddress_full = document.createElement("SPAN");
2132                        div_ccoaddress_full.id = "div_ccoaddress_full_"+ID;
2133                        div_ccoaddress.style.display="";
2134
2135                        //cco.innerHTML = draw_plugin_cc(ID, ccoaddress_array[ID][0]);
2136                        cco.innerHTML = ccoaddress_array[ID][0];
2137                        div_ccoaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+ID+"','cco');>"+get_lang('more')+"</a>)";
2138                        cco.appendChild(div_ccoaddress);
2139                }
2140                else{
2141                        //cco.innerHTML = draw_plugin_cc(ID, info_msg.cco);
2142                        cco.innerHTML = info_msg.bcc;
2143                }
2144                cco.className = "header_message_field";
2145                tr3.appendChild(td3);
2146                tr3.appendChild(cco);
2147                tr3.appendChild(cco_values);
2148                tbody_message_others_options.appendChild(tr3);
2149        }
2150
2151        var tr4 = document.createElement("TR");
2152        tr4.className = "tr_message_header";
2153        var td4 = document.createElement("TD");
2154        td4.innerHTML = get_lang("Date: ");
2155        var date = document.createElement("TD");
2156        date.id = "date_"+ID;
2157        date.innerHTML = info_msg.fulldate;
2158        var date_day = document.createElement("INPUT");
2159        date_day.id = "date_day_"+ID;
2160        date_day.type = "HIDDEN";
2161        date_day.value = info_msg.msg_day;
2162        var date_hour = document.createElement("INPUT");
2163        date_hour.id = "date_hour_"+ID;
2164        date_hour.type = "HIDDEN";
2165        date_hour.value = info_msg.msg_hour
2166        date.className = "header_message_field";
2167        tr4.appendChild(td4);
2168        tr4.appendChild(date);
2169        tr4.appendChild(date_day);
2170        tr4.appendChild(date_hour);
2171        tbody_message_others_options.appendChild(tr4);
2172
2173        var tr5 = document.createElement("TR");
2174        tr5.className = "tr_message_header";
2175        var td5 = document.createElement("TD");
2176        td5.innerHTML = get_lang("Subject");
2177        var subject = document.createElement("TD");
2178        subject.id = "subject_"+ID;
2179        subject.innerHTML = info_msg.subject;
2180        subject.className = "header_message_field";
2181        tr5.appendChild(td5);
2182        tr5.appendChild(subject);
2183        tbody_message_others_options.appendChild(tr5);
2184        if ( info_msg.attachments && info_msg.attachments.length > 0 ){
2185        var tr6 = document.createElement("TR");
2186                tr6.className = "tr_message_header";
2187                var td6 = document.createElement("TD");
2188                td6.innerHTML = get_lang("Attachments: ");
2189
2190                var attachments = document.createElement("TD");
2191                td6.vAlign = "top";
2192                attachments.align='left';
2193                if(info_msg.attachments.length >= 1) {
2194                        if(info_msg.attachments.length > 1) {
2195                                var link_attachment      = document.createElement("A");
2196                                 if(proxy_mensagens.is_local_folder(current_folder))
2197                                        link_attachment.setAttribute("href", "javascript:expresso_local_messages.download_all_local_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
2198                                else
2199                                        link_attachment.setAttribute("href", "javascript:download_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
2200                                link_attachment.innerHTML = " "+info_msg.attachments.length+' '+get_lang('files')+' :: '+get_lang('Download all atachments');
2201                                attachments.appendChild(link_attachment);
2202                        }
2203                        if(parseInt(preferences.remove_attachments_function))
2204                        {
2205                                attachments.appendChild(document.createTextNode('  '));
2206                                var del_attachments = document.createElement("A");
2207                                del_attachments.setAttribute("href", "javascript:remove_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
2208                                del_attachments.innerHTML = get_lang('remove all attachments');
2209                                attachments.appendChild(del_attachments);
2210                        }
2211                        attachments.appendChild(document.createElement('BR'));
2212                }
2213
2214                attachments.id = "attachments_" + ID;
2215                for (var i=0; i<info_msg.attachments.length; i++){
2216                        var link_attachment = document.createElement("A");
2217                        link_attachment.setAttribute("href", proxy_mensagens.link_anexo(info_msg,i));
2218                        link_attachment.innerHTML = url_decode(info_msg.attachments[i].name);
2219                        link_attachment.innerHTML += " ("+borkb(info_msg.attachments[i].fsize)+")";
2220                       
2221                        if((url_decode(info_msg.attachments[i].name).indexOf(".ics")!=-1) ||
2222                                        (url_decode(info_msg.attachments[i].name).indexOf(".vcard")!=-1))
2223                        {
2224                                //Link para importar calendário
2225                                var link_import_attachment = new Image();
2226                                link_import_attachment.src = "templates/"+template+"/images/new.png";
2227                                link_import_attachment.setAttribute("onclick","javascript:import_calendar('"+info_msg.msg_folder+"&msg_number="+info_msg.msg_number+"&msg_part="+info_msg.attachments[i].pid+"&idx_file="+i+"&encoding="+info_msg.attachments[i].encoding+"'); return false;");
2228                                link_import_attachment.title = get_lang("Import to calendar");
2229                                link_import_attachment.align = "top";
2230                                link_import_attachment.style.marginLeft = "5px";
2231                                link_import_attachment.style.cursor = "pointer";
2232                                link_attachment.appendChild(link_import_attachment);
2233                        }
2234                       
2235                        link_attachment.innerHTML += '<br/>';
2236                        attachments.appendChild(link_attachment);
2237                }
2238                tr6.appendChild(td6);
2239                tr6.appendChild(attachments);
2240                tbody_message_others_options.appendChild(tr6);
2241        }
2242
2243
2244        var div = document.createElement("DIV");
2245        div.id = "div_message_scroll_"+ID;
2246        div.style.background = 'WHITE';
2247        div.style.overflow = "auto";
2248        div.style.width = "100%";
2249        table_message_others_options.appendChild(tbody_message_others_options);
2250        var tr = document.createElement("TR");
2251        var td = document.createElement("TD");
2252        td.colSpan = '2';
2253        div.appendChild(table_message_others_options);
2254        var imgTag = info_msg.body.match(/(<img[^>]*src[^>=]*=['"]?[^'">]*["']?[^>]*>)|(<[^>]*(style[^=>]*=['"][^>]*background(-image)?:[^:;>]*url\()[^>]*>)/gi);
2255        var newBody = info_msg.body;
2256        if(!info_msg.showImg && imgTag)
2257        {
2258                var domains = '';
2259                var blocked = false;
2260                var forbidden = true;
2261
2262                if (preferences.notification_domains != null && typeof(preferences.notification_domains) != 'undefined')
2263                {
2264                        domains = preferences.notification_domains.split(',');
2265                        for(var j = 0; j < imgTag.length; j++)
2266                        {
2267                                for (var i = 0; i < domains.length; i++)
2268                                {
2269                                        if (imgTag[j].match(/cid:([\w\d]){5,}/) || imgTag[j].match(/src=\"\.\/inc\/show_embedded_attach\.php/g))
2270                                        {
2271                                                forbidden = false;
2272                                                continue;
2273                                        }
2274                                        imgSource = imgTag[j].match(/=['"](http:\/\/)+[^'"\/]*/);
2275                                        if (imgSource && imgSource.toString().substr(5).match(domains[i]))
2276                                                forbidden = false;
2277                                }
2278                                if (forbidden)
2279                                {
2280                                        newBody = newBody.replace(imgTag[j],"<img src='templates/"+template+"/images/forbidden.jpg'>");
2281                                        blocked=true;
2282                                }
2283                        }
2284                        if (blocked)
2285                        {
2286                                var showImgLink = document.createElement('DIV');
2287                                showImgLink.id="show_img_link_"+ID;
2288                                showImgLink.onclick = function(){show_msg_img(info_msg.msg_number,info_msg.msg_folder)};
2289                                showImgLink.className="show_img_link";
2290                                showImgLink.innerHTML = get_lang("Show images from")+": "+info_msg.from.email;
2291                                td.appendChild(showImgLink);
2292                        }
2293                }
2294        }
2295        td.appendChild(div);
2296        tr.appendChild(td)
2297        tbody_message.appendChild(tr);
2298
2299
2300        //////////////////////////////////////////////////////////////////////////////////////////////////////
2301        //Make the body message.
2302        ///////////////////////////////////////////////////////////////////////////////////////////////////////
2303        var tr = document.createElement("TR");
2304        tr.className = "tr_message_body";
2305        var td = document.createElement("TD");
2306        //td.setAttribute("colSpan","2");
2307        newBody = newBody.replace("<body","<span");
2308        newBody = newBody.replace("<BODY","<span");
2309        while ( ( /<span[^>]*><span[^>]*>/ig ).test( newBody ) )
2310                newBody = newBody.replace( /(<span[^>]*>)<span[^>]*>/ig, '$1' );
2311
2312        var _body = document.createElement( 'div' );
2313        _body.id = 'body_' + ID;
2314        _body.innerHTML = newBody;
2315        _body.style.fontSize = '16px';
2316
2317        var _elements = _body.getElementsByTagName( '*' );
2318        for( var i = 0; i < _elements.length; i++ )
2319                if ( _elements[ i ].attributes && _elements[ i ].attributes.getNamedItem( 'id' ) )
2320                        _elements[ i ].attributes.removeNamedItem( 'id' );
2321
2322        div.appendChild( _body );
2323
2324        function mailto( link )
2325        {
2326                var mail = link.href.substr( 7 );
2327                link.onclick = function( )
2328                {
2329                        new_message_to( mail );
2330                        return false;
2331                };
2332        }
2333        var links = div.getElementsByTagName( 'a' );
2334        for ( var i = 0; i < links.length; i++ ){
2335                try{
2336                        if ( links.item( i ).href.indexOf( 'mailto:' ) === 0 ){
2337                                mailto( links.item( i ) );
2338                        }
2339                        else{
2340                                var anchor_pattern = "http://"+location.host+location.pathname+"#";
2341                               
2342                                if ( ( links.item( i ).href.indexOf( 'javascript:' ) !== 0 ) &&
2343                                        (links.item( i ).href.indexOf(anchor_pattern) !== 0) ) //se não for âncora
2344                                                links.item( i ).setAttribute( 'target', '_blank' );
2345                        }
2346                }catch(e){
2347                }
2348        }
2349        //////////////////////////////////////////////////////////////////////////////////////////////////////
2350        //Make the thumbs of the message.
2351        //////////////////////////////////////////////////////////////////////////////////////////////////////
2352        if ((info_msg.thumbs)&&(info_msg.thumbs.length > 0)){
2353                var table_message_thumbs = document.createElement("TABLE");
2354                table_message_thumbs.width = "80%";
2355                table_message_thumbs.style.borderTop = "2px solid rgb(170, 170, 170)";
2356                var tbody_message_thumbs = document.createElement("TBODY");
2357                var tr = document.createElement("TR");
2358                tr.className = "tr_message_body";
2359                var td = document.createElement("TD");
2360                td.setAttribute("colSpan","2");
2361                td.id = "body_thumbs_"+ID;
2362                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>";
2363                var _link_attachments = '';
2364                if(info_msg.thumbs.length > 1){
2365                        _link_attachments       = document.createElement("A");
2366                        _link_attachments.className = "message_options";
2367                         if(proxy_mensagens.is_local_folder(current_folder))
2368                                _link_attachments.setAttribute("href", "javascript:expresso_local_messages.download_all_local_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
2369                        else
2370                                _link_attachments.setAttribute("href", "javascript:download_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
2371                        _link_attachments.innerHTML = get_lang('Download all atachments');
2372                }
2373
2374                if(_link_attachments){
2375                        td.innerHTML += " :: ";
2376                        td.appendChild(_link_attachments);
2377                }
2378
2379                td.innerHTML += "<BR><img src='templates/"+template+"/images/menu/ktip.png'>"+get_lang("<b>Tip:</b> For faster save, click over the image with <u>right button</u>.");
2380                td.innerHTML += "<BR>";
2381
2382                for (var i=0; i<info_msg.thumbs.length; i++){
2383                        if ((i % 4) == 0)
2384                                td.innerHTML += "<BR>";
2385                        td.innerHTML += info_msg.thumbs[i];
2386                        td.innerHTML += "&nbsp;&nbsp;";
2387                }
2388                tr.appendChild(td);
2389                tbody_message_thumbs.appendChild(tr);
2390                table_message_thumbs.appendChild(tbody_message_thumbs);
2391                div.appendChild(table_message_thumbs);
2392        }
2393        //////////////////////////////////////////////////////////////////////////////////////////////////////
2394        table_message.appendChild(tbody_message);
2395        content.appendChild(table_message);
2396        resizeWindow();
2397        var msg_number = document.createElement('INPUT');
2398        msg_number.id = "msg_number_" + ID;
2399        msg_number.type = "hidden";
2400        msg_number.value = info_msg.msg_number;
2401        content.appendChild(msg_number);
2402        //////////////////////////////////////////////////////////////////////////////////////////////////////
2403
2404        //Exibe o cabecalho da mensagem totalmente aberto caso esteja setado nas preferencias do usuario
2405        if (preferences.show_head_msg_full == 1)
2406        {
2407                option_hide_more.onclick();
2408                if (Element('div_toaddress_'+ID) != null)
2409                        show_div_address_full(ID,'to');
2410                if (Element('div_ccaddress_'+ID) != null)
2411                        show_div_address_full(ID,'cc');
2412        }
2413
2414}
2415function changeLinkState(el,state){
2416        el.innerHTML = get_lang(state);
2417        switch (state){
2418                case 'important':
2419                        {
2420                                el.onclick = function(){changeLinkState(el,'normal');proxy_mensagens.proxy_set_message_flag(currentTab.substr(0,currentTab.indexOf("_r")),'flagged'); write_msg(get_lang('Message marked as ')+get_lang("Important"))}
2421                                break;
2422                        }
2423                case 'normal':
2424                        {
2425                                el.onclick = function(){
2426                                        var _this = this;
2427                                        proxy_mensagens.proxy_set_message_flag(currentTab.substr(0,currentTab.indexOf("_r")),'unflagged', function(success){
2428                                                if (success) {
2429                                                        changeLinkState(_this, 'important');
2430                                                        write_msg(get_lang('Message marked as ') + get_lang("Normal"));
2431                                                }
2432                                        } );
2433                                }
2434                                break;
2435                        }
2436                case 'unseen':
2437                        {
2438                                el.onclick = function(){  changeLinkState(el,'seen');proxy_mensagens.proxy_set_message_flag(currentTab.substr(0,currentTab.indexOf("_r")),'unseen');write_msg(get_lang('Message marked as ')+get_lang("unseen"))}
2439                                break;
2440
2441                        }
2442                case 'seen':
2443                        {
2444                                el.onclick = function(){  changeLinkState(el,'unseen');proxy_mensagens.proxy_set_message_flag(currentTab.substr(0,currentTab.indexOf("_r")),'seen');write_msg(get_lang('Message marked as ')+get_lang("seen"))}
2445                                break;
2446
2447                        }
2448                default:
2449                        {
2450                                break;
2451                        }
2452        }
2453}
2454function draw_new_message(border_ID){
2455        connector.loadScript("color_palette");
2456        connector.loadScript("rich_text_editor");
2457        connector.loadScript('wfolders');
2458        if(typeof(RichTextEditor) == 'undefined' || typeof(ColorPalette) == 'undefined' || typeof(wfolders) == 'undefined')
2459                return false;
2460
2461        var ID = create_border("",border_ID);
2462        if (ID == false)
2463                return false;
2464        hold_session = true;
2465
2466        var footer_menu = Element("footer_menu");
2467        if (footer_menu) {
2468                footer_menu.style.display = 'none';
2469        }
2470/////////////////////////////////////////////////////////////////////////////////////////////////////////
2471        var form = document.createElement("FORM");
2472        form.name = "form_message_"+ID;
2473        form.method = "POST";
2474        form.onsubmit = function(){return false;}
2475        if(!is_ie)
2476                form.enctype="multipart/form-data";
2477        else
2478                form.encoding="multipart/form-data";
2479/////////////////////////////////////////////////////////////////////////////////////////////////////////
2480        //ConstructMenuNewMessage(ID);
2481////////////////////////////////////////////////////////////////////////////////////////////////////////
2482        var content = Element('content_id_' + ID);
2483        var table_message = document.createElement("TABLE");
2484        table_message.width = "100%";
2485        var tbody_message = document.createElement("TBODY");
2486        var tr0 = document.createElement("TR");
2487        tr0.className = "tr_message_header";
2488        var td0 = document.createElement("TD");
2489        td0.colSpan = '3';
2490
2491        var table_menu_new_message = document.createElement("TABLE");
2492        table_menu_new_message.width = "100%";
2493        table_menu_new_message.border = '0';
2494        table_menu_new_message.className = 'table_message';
2495        var tbody_menu_new_message = document.createElement("TBODY");
2496        var tr_menu_new_message = document.createElement("TR");
2497        var td_menu_new_message = document.createElement("TD");
2498        td_menu_new_message.setAttribute("noWrap","true");
2499
2500        if ((preferences.save_in_folder == '-1') || (preferences.save_in_folder == '')){
2501                //var option_send = '<span class="message_options" onclick=send_message("'+ID+'","null","null");>'+get_lang("Send")+'</span> | ';
2502                var option_send   = '<input type="button" id="send_button_'+ID+'" class="em_button_like_span" tabindex="1" value="'+get_lang("Send and not file")+'" onclick=send_message("'+ID+'","null","null");>' + ' | ';
2503                if(!expresso_offline)
2504                        var option_send_and_file= '<span class="message_options" onclick=wfolders.makeWindow("'+ID+'","send_and_file");>'+get_lang("Send and file")+'</span> | ';
2505                else
2506                        var option_send_and_file='';
2507        }
2508        else{
2509                //var option_send = '<span class="message_options" onclick="send_message(\''+ID+'\',\''+preferences.save_in_folder+'\',\'null\');">'+get_lang("Send")+'</span> | ';
2510                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\');">' + ' | ';
2511                var option_send_and_file='';
2512                wfolders.alert = true;
2513        }
2514//      var option_save_as              = '<span class="message_options" onclick=wfolders.makeWindow("'+ID+'","save");>'+get_lang("Save as")+'</span> | ';
2515        if (!expresso_offline) {
2516                var option_save = '<span id="save_message_options_'+ID+'" class="message_options" onclick="save_msg('+ID+');">'+get_lang("Save")+'</span> | ';
2517                var option_search = '<span class="message_options" onclick=openListUsers("'+ID+'");>'+get_lang("Search")+'</span>';
2518        }
2519        else {
2520                var option_save = '<input type="hidden" id="save_message_options_'+ID+'">';
2521                var option_search = '';
2522        }
2523        td_menu_new_message.innerHTML = option_send + option_send_and_file + option_save + option_search;
2524
2525        tr_menu_new_message.appendChild(td_menu_new_message);
2526        tbody_menu_new_message.appendChild(tr_menu_new_message);
2527        table_menu_new_message.appendChild(tbody_menu_new_message);
2528
2529        content.appendChild(table_menu_new_message);
2530        tr0.appendChild(td0);
2531        tbody_message.appendChild(tr0);
2532////////////////////////////////////////////////////////////////////////////////////////////////////////
2533        var tr1_1 = document.createElement("TR");
2534        tr1_1.style.display = 'none';
2535        var td1_1 = document.createElement("TD");
2536        td1_1.innerHTML = get_lang("From")+":";
2537        td1_1.setAttribute("noWrap","true");
2538        td1_1.style.width = "1%";
2539
2540        var td_from = document.createElement("TD");
2541        td_from.setAttribute("noWrap","true");
2542        td_from.style.width = "100%";
2543
2544        var sel_from = document.createElement('SELECT');
2545        sel_from.id = "from_"+ID;
2546        sel_from.name = "input_from";
2547        sel_from.style.width = "70%";
2548        sel_from.setAttribute("wrap","soft");
2549        td_from.appendChild(sel_from);
2550        tr1_1.appendChild(td1_1);
2551        tr1_1.appendChild(td_from);
2552        tbody_message.appendChild(tr1_1);
2553///////////////////////////////////////////////////////////////////////
2554        var tr1_2 = document.createElement("TR");
2555        tr1_2.id = "tr_replyto_"+ID;
2556        var td1_2 = document.createElement("TD");
2557        tr1_2.style.display = 'none';
2558        td1_2.innerHTML = get_lang("Reply to")+":";
2559        td1_2.setAttribute("noWrap","true");
2560        td1_2.style.width = "1%";
2561
2562        var td_replyto = document.createElement("TD");
2563        td_replyto.setAttribute("noWrap","true");
2564        td_replyto.style.width = "100%";
2565
2566        var input_replyto = document.createElement('INPUT');
2567        input_replyto.id = "replyto_"+ID;
2568        input_replyto.name = "input_replyto";
2569        input_replyto.setAttribute("tabIndex","1");
2570        input_replyto.style.width = "100%";
2571        input_replyto.setAttribute("wrap","soft");
2572        input_replyto.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer)); search_contacts('onfocus', this.id);};
2573        input_replyto.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
2574
2575        if (!is_ie)
2576        {
2577                input_replyto.rows = 2;
2578                input_replyto.onkeydown = function (e)
2579        {
2580            if ((e.keyCode) == 120) //F9
2581            {
2582                emQuickSearch(input_replyto.value, 'replyto', ID);
2583            }
2584            else
2585            {
2586                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
2587                {
2588                    e.preventDefault();
2589                    search_contacts(e.keyCode,this.id);
2590                }
2591            }
2592        }
2593        input_replyto.onkeyup = function (e)
2594
2595        {
2596            if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
2597            {
2598                search_contacts(e.keyCode,this.id);
2599            }
2600        }
2601        }
2602        else
2603        {
2604                input_replyto.rows = 3;
2605                input_replyto.onkeyup = function (e)
2606        {
2607            if ((window.event.keyCode) == 120) //F9
2608            {
2609                emQuickSearch(input_replyto.value, 'replyto', ID);
2610            }
2611            else
2612            {
2613                search_contacts(window.event.keyCode,this.id);
2614            }
2615        }
2616        }
2617        td_replyto.appendChild(input_replyto);
2618
2619        var img_search = document.createElement("IMG");
2620        img_search.src = "./templates/"+template+"/images/search.gif";
2621        img_search.onclick = function () {emQuickSearch(document.getElementById('replyto_'+ID).value, 'replyto', ID)}
2622        img_search.title = get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.');
2623        var span_search = document.createElement("SPAN");
2624        span_search.innerHTML = get_lang('Search');
2625
2626        var td1_2_img_search = document.createElement("TD");
2627        td1_2_img_search.setAttribute("noWrap","true");
2628        var td1_2_span_search = document.createElement("TD");
2629        td1_2_span_search.setAttribute("noWrap","true");
2630
2631        td1_2_img_search.appendChild(img_search);
2632        td1_2_span_search.appendChild(span_search);
2633
2634        tr1_2.appendChild(td1_2);
2635        tr1_2.appendChild(td_replyto);
2636        tr1_2.appendChild(td1_2_img_search);
2637        tbody_message.appendChild(tr1_2);
2638////////////////////////////////////////////////////////////////////////////////////////////////////////
2639        var tr1 = document.createElement("TR");
2640        var td1 = document.createElement("TD");
2641        td1.innerHTML = get_lang("To")+":";
2642        td1.setAttribute("noWrap","true");
2643        td1.style.width = "1%";
2644
2645        var td_to = document.createElement("TD");
2646        td_to.setAttribute("noWrap","true");
2647        td_to.style.width = "100%";
2648
2649        var input_to = document.createElement('TEXTAREA');
2650        input_to.id = "to_"+ID;
2651        input_to.name = "input_to";
2652        input_to.setAttribute("tabIndex","1");
2653        input_to.style.width = "100%";
2654        input_to.setAttribute("wrap","soft");
2655        input_to.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer)); search_contacts('onfocus', this.id);};
2656        input_to.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
2657        if (!is_ie)
2658        {
2659                input_to.rows = 2;
2660                input_to.onkeydown = function (e)
2661                {
2662                        if ((e.keyCode) == 120) //F9
2663                        {
2664                                emQuickSearch(input_to.value, 'to', ID);
2665                        }
2666                        else
2667                        {
2668                                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
2669                                {
2670                                        e.preventDefault();
2671                                        search_contacts(e.keyCode,this.id);
2672                                }
2673                        }
2674                }
2675                input_to.onkeyup = function (e)
2676                {
2677                        if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
2678                        {
2679                                search_contacts(e.keyCode,this.id);
2680                        }
2681                }
2682        }
2683        else
2684        {
2685                input_to.rows = 3;
2686                input_to.onkeyup = function (e)
2687                {
2688                        if ((window.event.keyCode) == 120) //F9
2689                        {
2690                                emQuickSearch(input_to.value, 'to', ID);
2691                        }
2692                        else
2693                        {
2694                                search_contacts(window.event.keyCode,this.id);
2695                        }
2696                }
2697        }
2698        td_to.appendChild(input_to);
2699
2700        var forwarded_local_message = document.createElement("INPUT"); //Hidden para indicar se é um forward de uma mensagem local
2701        forwarded_local_message.id = "is_local_forward"+ID;
2702        forwarded_local_message.name = "is_local_forward";
2703        forwarded_local_message.type = "HIDDEN";
2704        forwarded_local_message.value = "0";
2705        td_to.appendChild(forwarded_local_message);
2706
2707        if (!expresso_offline) {
2708                var img_search = document.createElement("IMG");
2709                img_search.src = "./templates/"+template+"/images/search.gif";
2710                img_search.title = get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.');
2711                img_search.onclick = function () {emQuickSearch(document.getElementById('to_'+ID).value, 'to', ID);};
2712        }
2713        else {
2714                var img_search = document.createElement("SPAN");
2715        }
2716
2717        var span_search = document.createElement("SPAN");
2718        span_search.innerHTML = get_lang('Search');
2719
2720        var td1_img_search = document.createElement("TD");
2721        td1_img_search.setAttribute("noWrap","true");
2722        var td1_span_search = document.createElement("TD");
2723        td1_span_search.setAttribute("noWrap","true");
2724
2725        td1_img_search.appendChild(img_search);
2726        td1_span_search.appendChild(span_search);
2727
2728        tr1.appendChild(td1);
2729        tr1.appendChild(td_to);
2730        tr1.appendChild(td1_img_search);
2731
2732        tbody_message.appendChild(tr1);
2733//////////////////////////////////////////////////////////////////////////////////////////////////////
2734        var tr2 = document.createElement("TR");
2735        tr2.id = "tr_cc_"+ID;
2736        tr2.style.display = 'none';
2737        var td2 = document.createElement("TD");
2738        td2.innerHTML = "Cc:";
2739        td2.setAttribute("noWrap","true");
2740        td2.style.width = "1%";
2741
2742        var td_cc = document.createElement("TD");
2743        td_cc.setAttribute("noWrap","true");
2744        td_cc.style.width = "100%";
2745
2746        var input_cc = document.createElement('TEXTAREA');
2747        input_cc.id = "cc_"+ID;
2748        input_cc.name = "input_cc";
2749        input_cc.setAttribute("tabIndex","1");
2750        input_cc.style.width = "100%";
2751        input_cc.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer)); search_contacts('onfocus',this.id);};
2752        input_cc.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
2753        if (!is_ie)
2754        {
2755                input_cc.rows = 2;
2756                input_cc.onkeydown = function (e)
2757                {
2758                        if ((e.keyCode) == 120) //F9
2759                        {
2760                                emQuickSearch(input_cc.value, 'cc', ID);
2761                        }
2762                        else
2763                        {
2764                                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
2765                                {
2766                                        e.preventDefault();
2767                                        search_contacts(e.keyCode,this.id);
2768                                }
2769                        }
2770                }
2771                input_cc.onkeyup = function (e)
2772                {
2773                        if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
2774                        {
2775                                search_contacts(e.keyCode,this.id);
2776                        }
2777                }
2778        }
2779        else if (is_ie)
2780        {
2781                input_cc.rows = 3;
2782                input_cc.onkeyup = function (e)
2783                {
2784                        if ((window.event.keyCode) == 120) //F9
2785                        {
2786                                emQuickSearch(input_cc.value, 'cc', ID);
2787                        }
2788                        else
2789                        {
2790                                search_contacts(window.event.keyCode,this.id);
2791                        }
2792                }
2793        }
2794
2795        td_cc.appendChild(input_cc);
2796        var img_search = document.createElement("IMG");
2797        img_search.src = "./templates/"+template+"/images/search.gif";
2798        img_search.onclick = function () {emQuickSearch(document.getElementById('cc_'+ID).value, 'cc', ID)}
2799        img_search.title = get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.');
2800        var span_search = document.createElement("SPAN");
2801        span_search.innerHTML = get_lang('Search');
2802
2803        var td2_img_search = document.createElement("TD");
2804        td2_img_search.setAttribute("noWrap","true");
2805        var td2_span_search = document.createElement("TD");
2806        td2_span_search.setAttribute("noWrap","true");
2807
2808        td2_img_search.appendChild(img_search);
2809        td2_span_search.appendChild(span_search);
2810
2811        tr2.appendChild(td2);
2812        tr2.appendChild(td_cc);
2813        tr2.appendChild(td2_img_search);
2814        tbody_message.appendChild(tr2);
2815//////////////////////////////////////////////////////////////////////////////////////////////////////
2816        var tr3 = document.createElement("TR");
2817        tr3.id = "tr_cco_"+ID;
2818        tr3.style.display = 'none';
2819        var td3 = document.createElement("TD");
2820        td3.setAttribute("noWrap","true");
2821        td3.innerHTML = get_lang("CCo")+":";
2822        td3.style.width = "1%";
2823
2824        var td_cco = document.createElement("TD");
2825        td_cco.setAttribute("noWrap","true");
2826        td_cco.style.width = "100%";
2827
2828        var input_cco = document.createElement('TEXTAREA');
2829        input_cco.id = "cco_"+ID;
2830        input_cco.name = "input_cco";
2831        input_cco.setAttribute("tabIndex","1");
2832        input_cco.style.width = "100%";
2833        input_cco.onfocus = function(){clearTimeout(parseInt(setTimeOutLayer)); search_contacts('onfocus',this.id);};
2834        input_cco.onblur = function(){setTimeOutLayer=setTimeout('search_contacts("lostfocus","'+this.id+'")',100);};
2835
2836        if (!is_ie)
2837        {
2838                input_cco.rows = 2;
2839                input_cco.onkeydown = function (e)
2840                {
2841                        if ((e.keyCode) == 120) //F9
2842                        {
2843                                emQuickSearch(input_cco.value, 'cco', ID);
2844                        }
2845                        else
2846                        {
2847                                if (((e.keyCode == 13) || ((e.keyCode == 38)||(e.keyCode == 40))) && (document.getElementById('tipDiv').style.visibility!='hidden'))
2848                                {
2849                                        e.preventDefault();
2850                                        search_contacts(e.keyCode,this.id);
2851                                }
2852                        }
2853                }
2854                input_cco.onkeyup = function (e)
2855                {
2856                        if ((e.keyCode != 13) && (e.keyCode != 38) && (e.keyCode != 40))
2857                        {
2858                                search_contacts(e.keyCode,this.id);
2859                        }
2860                }
2861        }
2862        else if (is_ie)
2863        {
2864                input_cco.rows = 3;
2865                input_cco.onkeyup = function (e)
2866                {
2867                        if ((window.event.keyCode) == 120) //F9
2868                        {
2869                                emQuickSearch(input_cco.value, 'cco', ID);
2870                        }
2871                        else
2872                        {
2873                                search_contacts(window.event.keyCode,this.id);
2874                        }
2875                }
2876        }
2877
2878        td_cco.appendChild(input_cco);
2879        var img_search = document.createElement("IMG");
2880        img_search.src = "./templates/"+template+"/images/search.gif";
2881        img_search.title = get_lang('Search') + " | " + get_lang('Use F9 Key as shortcut.');
2882        img_search.onclick = function () {emQuickSearch(document.getElementById('cco_'+ID).value, 'cco', ID);};
2883        var span_search = document.createElement("SPAN");
2884        span_search.innerHTML = get_lang('Search');
2885
2886        var td3_img_search = document.createElement("TD");
2887        td3_img_search.setAttribute("noWrap","true");
2888        var td3_span_search = document.createElement("TD");
2889        td3_span_search.setAttribute("noWrap","true");
2890
2891        td3_img_search.appendChild(img_search);
2892        td3_span_search.appendChild(span_search);
2893
2894        tr3.appendChild(td3);
2895        tr3.appendChild(td_cco);
2896        tr3.appendChild(td3_img_search);
2897        tbody_message.appendChild(tr3);
2898//////////////////////////////////////////////////////////////////////////////////////////////////////
2899        var tr_link = document.createElement("TR");
2900        tr_link.id = "tr_link_"+ID;
2901        var td1_link = document.createElement("TD");
2902        var td2_link = document.createElement("TD");
2903        td1_link.innerHTML = "&nbsp;";
2904        var a_cc_link = document.createElement('A');
2905        a_cc_link.innerHTML = get_lang('Add CC');
2906        a_cc_link.id = "a_cc_link_"+ID;
2907        a_cc_link.setAttribute("href","javascript:void(0)");
2908        a_cc_link.setAttribute("tabIndex","-1");
2909        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;}
2910        td2_link.appendChild(a_cc_link);
2911        var space = document.createElement("span");
2912        space.id ="space_link_"+ID;
2913        space.innerHTML="&nbsp;|&nbsp;";
2914        td2_link.appendChild(space);
2915        var a_cco_link = document.createElement('A');
2916        a_cco_link.innerHTML = get_lang('Add BCC');
2917        a_cco_link.id = "a_cco_link_"+ID;
2918        a_cco_link.setAttribute("href","javascript:void(0)");
2919        a_cco_link.setAttribute("tabIndex","-1");
2920        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;}
2921        td2_link.appendChild(a_cco_link);
2922        var space = document.createElement("span");
2923        space.id ="space_link_2_"+ID;
2924        space.innerHTML="&nbsp;|&nbsp;";
2925        td2_link.appendChild(space);
2926        var a_replyto_link = document.createElement('A');
2927        a_replyto_link.innerHTML = get_lang('Reply to');
2928        a_replyto_link.id = "a_replyto_link_"+ID;
2929        a_replyto_link.setAttribute("href","javascript:void(0)");
2930        a_replyto_link.setAttribute("tabIndex","-1");
2931        a_replyto_link.onclick = function () {this.style.display='none';document.getElementById('tr_replyto_'+ID).style.display='';document.getElementById('space_link_2_'+ID).style.display='none';input_replyto.focus(); return false;}
2932        td2_link.appendChild(a_replyto_link);
2933        tr_link.appendChild(td1_link);
2934        tr_link.appendChild(td2_link);
2935        tbody_message.appendChild(tr_link);
2936//////////////////////////////////////////////////////////////////////////////////////////////////////
2937        var tr4 = document.createElement("TR");
2938        var td4 = document.createElement("TD");
2939        //td4.setAttribute("noWrap","true");
2940        td4.innerHTML = get_lang("Subject")+":";
2941        var td_subject = document.createElement("TD");
2942        var input_subject = document.createElement('input');
2943        input_subject.id = "subject_"+ID;
2944        input_subject.name = "input_subject";
2945        input_subject.setAttribute("tabIndex","1");
2946        input_subject.style.width = "90%";
2947        input_subject.setAttribute("autocomplete","off");
2948        td_subject.appendChild(input_subject);
2949        tr4.appendChild(td4);
2950        tr4.appendChild(td_subject);
2951        tbody_message.appendChild(tr4);
2952//////////////////////////////////////////////////////////////////////////////////////////////////////
2953        var tr5 = document.createElement("TR");
2954        var td5 = document.createElement("TD");
2955        td5.innerHTML = "&nbsp;";
2956        var td_return_receipt = document.createElement("TD");
2957        td_return_receipt.setAttribute("noWrap","true");
2958        td_return_receipt.innerHTML = get_lang("Return receipt")+":";
2959                if (is_ie)
2960                {
2961                        var input_return_receipt = document.createElement('input name=input_return_receipt');
2962                }
2963                else
2964                {
2965                        var input_return_receipt = document.createElement('input');
2966                        input_return_receipt.name = "input_return_receipt";
2967                }
2968        input_return_receipt.type = "checkbox";
2969        input_return_receipt.className = "checkbox";
2970        input_return_receipt.id = "return_receipt_"+ID;
2971
2972        if(preferences.return_recipient_deafault != '0'){
2973             if (is_ie){
2974                input_return_receipt.checked=true;
2975             }
2976             else{
2977                input_return_receipt.defaultChecked=true;
2978             }
2979        }
2980
2981        input_return_receipt.setAttribute("tabIndex","-1");
2982        td_return_receipt.appendChild(input_return_receipt);
2983
2984        // Workaround para resolver problema ao enviar e-mails
2985        if((preferences.use_assinar_criptografar != '0'))
2986        {
2987                if(parseInt(preferences.use_signature_digital_cripto)==1)
2988                {
2989                        td_return_receipt.innerHTML +=  "&nbsp;&nbsp;" + get_lang("Digitally sign message?")+"";
2990
2991                        if (is_ie)
2992                        {
2993                                var input_return_digital = document.createElement('input name=input_return_digital');
2994                        }
2995                        else
2996                        {
2997                        var input_return_digital = document.createElement('input');
2998                                input_return_digital.name = "input_return_digital";
2999                        }
3000
3001                        input_return_digital.type = "checkbox";
3002                        input_return_digital.className = "checkbox";
3003                        input_return_digital.id = "return_digital_"+ID;
3004                        input_return_digital.setAttribute("tabIndex","-1");
3005                        if(parseInt(preferences.use_signature_digital)==1)
3006                        {
3007                            if (is_ie)
3008                            {
3009                                input_return_digital.checked=true;
3010                            }
3011                            else
3012                            {
3013                                input_return_digital.defaultChecked=true;
3014                            }
3015                        }
3016                        td_return_receipt.appendChild(input_return_digital);
3017                        td_return_receipt.innerHTML +=  "&nbsp;&nbsp;" + get_lang("Digitally crypt message?")+"";
3018
3019                        if (is_ie)
3020                        {
3021                                var input_return_cripto = document.createElement('input name=input_return_cripto');
3022                        }
3023                        else
3024                        {
3025                        var input_return_cripto = document.createElement('input');
3026                                input_return_cripto.name = "input_return_cripto";
3027                        }
3028
3029                        input_return_cripto.type = "checkbox";
3030                        input_return_cripto.className = "checkbox";
3031                        input_return_cripto.id = "return_cripto_"+ID;
3032                        input_return_cripto.setAttribute("tabIndex","-1");
3033                        input_return_cripto.defaultChecked=false;
3034
3035                        if(parseInt(preferences.use_signature_cripto)==1)
3036                        {
3037                            if (is_ie)
3038                            {
3039                                input_return_cripto.checked=true;
3040                            }
3041                            else
3042                            {
3043                                input_return_cripto.defaultChecked=true;
3044                            }
3045                        }
3046
3047                        td_return_receipt.appendChild(input_return_cripto);
3048                }
3049        }
3050        td_return_receipt.innerHTML += "";
3051        tr5.appendChild(td5);
3052        tr5.appendChild(td_return_receipt);
3053        tbody_message.appendChild(tr5);
3054        if (parseInt(preferences.use_important_flag))
3055        {
3056                var trn = document.createElement("TR");
3057                var tdn = document.createElement("TD");
3058                tdn.innerHTML = "&nbsp;";
3059                var td_important_msg = document.createElement("TD");
3060                td_important_msg.setAttribute("noWrap","true");
3061                td_important_msg.innerHTML = get_lang("Important message")+":";
3062                var input_important_message = document.createElement('input');
3063                input_important_message.type = "checkbox";
3064                input_important_message.className = "checkbox";
3065                input_important_message.id = "important_message_"+ID;
3066                input_important_message.name = "input_important_message";
3067                input_important_message.setAttribute("tabIndex","-1");
3068                td_important_msg.appendChild(input_important_message);
3069                trn.appendChild(tdn);
3070                trn.appendChild(td_important_msg);
3071                tbody_message.appendChild(trn);
3072        }
3073
3074        var add_files = document.createElement("A");
3075        add_files.setAttribute("href", "javascript:void(0)");
3076        add_files.onclick = function () { addFile(ID); return false;};
3077        add_files.innerHTML =  get_lang("Attachments: add+");
3078        add_files.setAttribute("tabIndex","-1");
3079        var divfiles = document.createElement("DIV");
3080        divfiles.id = "divFiles_"+ID;
3081        var tr5 = document.createElement("TR");
3082        var td5_link = document.createElement("TD");
3083        var td5_input = document.createElement("TD");
3084        td5_input.innerHTML = "&nbsp;"
3085        td5_link.setAttribute("valign","top");
3086        td5_link.setAttribute("colSpan","2");
3087        td5_link.appendChild(add_files);
3088        tr5.appendChild(td5_input);
3089        tr5.appendChild(td5_link);
3090        tbody_message.appendChild(tr5);
3091        var tr6 = document.createElement("TR");
3092        var td6_link  = document.createElement("TD");
3093        var td6_input = document.createElement("TD");
3094        tr6.appendChild(td6_link);
3095        td6_input.appendChild(divfiles);
3096        tr6.appendChild(td6_input);
3097        tbody_message.appendChild(tr6);
3098//////////////////////////////////////////////////////////////////////////////////////////////////////
3099        var tr5 = document.createElement("TR");
3100        var td5 = document.createElement("TD");
3101        td5.innerHTML = "&nbsp;";
3102        var td_body = document.createElement("TD");
3103        td_body.setAttribute("colSpan","2");
3104        var div_body_position = document.createElement("DIV");
3105        div_body_position.id = "body_position_" + ID;
3106        td_body.appendChild(div_body_position);
3107        tr5.appendChild(td5);
3108        tr5.appendChild(td_body);
3109        tbody_message.appendChild(tr5);
3110        var _div = document.createElement("DIV");
3111        _div.id = "div_message_scroll_"+ID;
3112        _div.style.overflow = "auto";
3113        _div.style.width = "100%";
3114
3115        // Hide the contac tips and re-position the pallete color.
3116        _div.onscroll = function() {
3117                var intElemScrollTop = Element("div_message_scroll_"+ID).scrollTop;
3118                if (!is_ie)
3119                        ColorPalette.repos(intElemScrollTop);
3120                Tooltip.scrollChanged();
3121        };
3122//////////////////////////////////////////////////////////////////////////////////////////////////////
3123        _div.appendChild(form);
3124        content.appendChild(_div);
3125        table_message.appendChild(tbody_message);
3126        form.appendChild(table_message);
3127        RichTextEditor.loadEditor(ID);
3128//////////////////////////////////////////////////////////////////////////////////////////////////////
3129        if(!expresso_offline)
3130                draw_from_field(sel_from,tr1_1);
3131        resizeWindow();
3132        return ID;
3133}
3134
3135//      Verify if any user is sharing his name/email address
3136//      for use in the new messages's "From " field.
3137function draw_from_field(sel_from,tr1_1){
3138
3139        var el_shared_users = Element("el_shared_users");
3140        // The element was loaded and populated...so return.
3141        if(el_shared_users){
3142                // Nothing to work...so return.
3143                if(el_shared_users.options.length == 0)
3144                        return;
3145                tr1_1.style.display = '';
3146                for (var x = 0; x < el_shared_users.options.length; x++) {
3147                        var _option = document.createElement("OPTION");
3148                        _option.text = el_shared_users.options[x].text;
3149                        _option.value = el_shared_users.options[x].value;
3150                        sel_from.options[sel_from.options.length] = _option     ;
3151                }
3152                return;
3153        }
3154        // Get the shared folders.....
3155        var sharedFolders = new Array();
3156        for(var i = 0; i < folders.length; i++) {
3157                var x = folders[i].folder_id;
3158                if (folders[i].folder_parent == 'user'){
3159                        sharedFolders[sharedFolders.length] = x;
3160                }
3161        }
3162
3163        var matchUser = '#';
3164        var sharedUsers = new Array();
3165        // Filter the shared folders (only root folders) .....
3166        for(var i = 0; i < sharedFolders.length; i++) {
3167                matchUser = sharedFolders[i];
3168                sharedUsers[sharedUsers.length] = matchUser.substring(("user"+cyrus_delimiter).length,matchUser.length);
3169        }
3170
3171        // Handler function for cExecute
3172        var h_user = function(data) {
3173                if(data.length > 0) {
3174                        tr1_1.style.display = '';
3175                        var _option = document.createElement("OPTION");
3176                        _option.text =  '"'+data.myname+'" <'+Element("user_email").value+'>';
3177                        _option.value  = data.myname+";"+Element("user_email").value;
3178                        sel_from.options[sel_from.options.length] = _option;
3179
3180                        var options = '';
3181                        for (var x = 0; x < data.length; x++)   {
3182                                var _option = document.createElement("OPTION");
3183                                _option.text = '"'+data[x].cn[0] + '" <'+data[x].mail[0]+'>';
3184                                _option.value = data[x].cn[0] + ';'+data[x].mail[0]+';'+data[x].save_shared[0]+';'+data[x].uid[0];
3185                                sel_from.options[sel_from.options.length] = _option     ;
3186                        }
3187                }
3188                var shared_users_from = Element("el_shared_users");
3189                if(!shared_users_from) {
3190                        shared_users_from = sel_from.cloneNode(true);
3191                        shared_users_from.id = "el_shared_users";
3192                        shared_users_from.style.display = 'none';
3193                        document.body.appendChild(shared_users_from);
3194                }
3195        }
3196        // First time, so execute.....
3197        cExecute ("$this.ldap_functions.getSharedUsersFrom&uids="+sharedUsers.join(';'), h_user);
3198}
3199
3200function changeBgColorToON(all_messages, begin, end){
3201        for (begin; begin<=end; begin++)
3202        {
3203                add_className(all_messages[begin], 'selected_msg');
3204                Element("check_box_message_" + all_messages[begin].id).checked = true;
3205        }
3206}
3207function updateBoxBgColor(box){
3208        // Set first TR Class
3209        var _className = 'tr_msg_read2';
3210        for(var i = 0; i < box.length;i++){
3211                if(exist_className(box[i],_className))
3212                        remove_className(box[i], _className);
3213                _className = (_className == 'tr_msg_read2' ? 'tr_msg_read' : 'tr_msg_read2');
3214                if(!exist_className(box[i],_className))
3215                        add_className( box[i], _className);
3216        }
3217}
3218
3219function changeBgColor(event, msg_number){
3220        actual_tr = Element(msg_number);
3221
3222        if (event.shiftKey)
3223        {
3224                last_tr = Element(last_message_selected);
3225                if(!last_tr)
3226                        last_tr = actual_tr;
3227
3228                all_messages = actual_tr.parentNode.childNodes;
3229
3230                for (var i=0; i < all_messages.length; i++)
3231                {
3232                        if (actual_tr.id == all_messages[i].id)
3233                                first_order = i;
3234                        if (last_tr.id == all_messages[i].id)
3235                                last_order = i;
3236                }
3237
3238                if (parseInt(first_order) > parseInt(last_order))
3239                        changeBgColorToON(all_messages, last_order, first_order);
3240                else
3241                        changeBgColorToON(all_messages, first_order, last_order);
3242        }
3243        else{
3244                //if ( exist_className(actual_tr, 'selected_msg') )
3245                if ( Element('check_box_message_' + msg_number).checked )
3246                        add_className(actual_tr, 'selected_msg');
3247                else
3248                        remove_className(actual_tr, 'selected_msg');
3249        }
3250        last_message_selected = msg_number;
3251}
3252
3253function build_quota(data){
3254        id = "content_quota";
3255        q_limit = data['quota_limit'];
3256        var div = document.getElementById(id);
3257        if(!q_limit){
3258                div.innerHTML = '<span><font size="2" style="color:red"><strong>'+get_lang("Without Quota")+'</strong></font></span>';
3259        }
3260        else{
3261        if(div)
3262                div.innerHTML = '';
3263        value = data['quota_percent'];
3264        q_used = data['quota_used'];
3265        table = document.getElementById("table_quota");
3266        if(table)
3267                table.parentNode.removeChild(table);
3268        table = document.createElement("TABLE");
3269        tbody = document.createElement("TBODY");
3270        table.appendChild(tbody);
3271        table.id = "table_quota";
3272        table.width="102";
3273        table.border="0";
3274        table.cellSpacing = 0;
3275        table.cellPadding = 0;
3276
3277        //tr1 = document.createElement("TR");
3278        td11 = document.createElement("TD");
3279        td11.align="center";
3280        td11.setAttribute("noWrap","true");
3281        td11.innerHTML += '&nbsp;<span class="boxHeaderText">' + value+"% ("+borkb(q_used*1024)+"/"+borkb(q_limit*1024)+")</span>";
3282        //tr1.appendChild(td11);
3283
3284        tr2 = document.createElement("TR");
3285        td21 = document.createElement("TD");
3286        td21.setAttribute("noWrap","true");
3287        td21.height="15";
3288        td22 = document.createElement("TD");
3289        td21.setAttribute("background","../phpgwapi/templates/"+template+"/images/dsunused.gif");
3290        table221 = document.createElement("TABLE");
3291        tbody221 = document.createElement("TBODY");
3292        table221.appendChild(tbody221);
3293        table221.style.width=value+"%";
3294        td21.width="102";
3295        table221.border="0";
3296        table221.cellSpacing = 0;
3297        table221.cellPadding = 0;
3298        tr221 = document.createElement("TR");
3299        td221 = document.createElement("TD");
3300        td221.height="15";
3301        if(value > 90) {
3302                if(value >= 100)
3303                        write_msg(get_lang("Your Mailbox is 100% full! You must free more space or will not receive messages."));
3304                else
3305                        write_msg(get_lang("Warning: Your Mailbox is almost full!"));
3306                td221.setAttribute("background","templates/"+template+"/images/dsalert.gif");
3307        }
3308        else if(value > 80)
3309                td221.setAttribute("background","templates/"+template+"/images/dswarn.gif");
3310        else
3311                td221.className = 'dsused';
3312
3313        tr221.appendChild(td221);
3314        tbody221.appendChild(tr221);
3315        td21.appendChild(table221);
3316        tr2.appendChild(td21);
3317        tr2.appendChild(td11);
3318
3319        //tr2.appendChild(td1);
3320
3321        tbody.appendChild(tr2); //Desenho
3322        //tbody.appendChild(tr1); //Letras
3323        div.appendChild(table);
3324        }
3325}
3326
3327function draw_quota(data){
3328        build_quota(data);
3329}
3330
3331function update_quota(folder_id){
3332        cExecute ("$this.imap_functions.get_quota&folder_id="+folder_id,build_quota);
3333}
3334
3335function draw_search(headers_msgs){
3336        Element("border_id_0").innerHTML = "&nbsp;&nbsp;" + get_lang('Search Result') + "&nbsp;&nbsp;";
3337
3338        var tbody = Element('tbody_box');
3339        for (var i=0; i<(headers_msgs.length); i++){
3340            // passa parâmetro offset
3341                var tr = this.make_tr_message(headers_msgs[i], headers_msgs[i].msg_folder);
3342                if (tr)
3343                        tbody.appendChild(tr);
3344        }
3345}
3346
3347function draw_search_header_box(){
3348        var table_message_header_box = Element("table_message_header_box");
3349        table_message_header_box.parentNode.removeChild(table_message_header_box);
3350
3351        var content_id_0 = Element("content_id_0");
3352        var table_element = document.createElement("TABLE");
3353        var tbody_element = document.createElement("TBODY");
3354        table_element.setAttribute("id", "table_message_header_box");
3355        table_element.className = "table_message_header_box";
3356        tr_element = document.createElement("TR");
3357        tr_element.className = "message_header";
3358        td_element1 = document.createElement("TD");
3359        td_element1.setAttribute("width", "1%");
3360        chk_box_element = document.createElement("INPUT");
3361        chk_box_element.id  = "chk_box_select_all_messages";
3362        chk_box_element.setAttribute("type", "checkbox");
3363        chk_box_element.className = "checkbox";
3364        chk_box_element.onclick = function(){select_all_messages(this.checked);};
3365        chk_box_element.onmouseover = function () {this.title=get_lang('Select all messages.')};
3366        chk_box_element.onkeydown = function (e){
3367                if (is_ie)
3368                {
3369                        if ((window.event.keyCode) == 46)
3370                        {
3371                                //delete_all_selected_msgs_imap();
3372                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
3373                        }
3374                }
3375                else
3376                {
3377                        if ((e.keyCode) == 46)
3378                        {
3379                                //delete_all_selected_msgs_imap();
3380                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
3381                        }
3382                }
3383        };
3384
3385        td_element1.appendChild(chk_box_element);
3386        td_element2 = document.createElement("TD");
3387        td_element2.setAttribute("width", "3%");
3388        td_element3 = document.createElement("TD");
3389        td_element3.setAttribute("width", "30%");
3390        td_element3.id = "message_header_SORTFROM";
3391        td_element3.align = "left";
3392        td_element3.innerHTML = get_lang("From");
3393        td_element4 = document.createElement("TD");
3394        td_element4.setAttribute("width", "49%");
3395        td_element4.id = "message_header_SORTSUBJECT";
3396        td_element4.align = "left";
3397        td_element4.innerHTML = get_lang("Subject");
3398        td_element5 = document.createElement("TD");
3399        td_element5.setAttribute("width", "10%");
3400        td_element5.id = "message_header_SORTARRIVAL";
3401        td_element5.align = "center";
3402        td_element5.innerHTML = "<B>"+get_lang("Date")+"</B>";
3403        td_element5.innerHTML += "<img src ='templates/"+template+"/images/arrow_descendant.gif'>";
3404        td_element6 = document.createElement("TD");
3405        td_element6.setAttribute("width", "10%");
3406        td_element6.id = "message_header_SORTSIZE";
3407        td_element6.align = "right";
3408        td_element6.innerHTML = get_lang("Size");
3409        tr_element.appendChild(td_element1);
3410        tr_element.appendChild(td_element2);
3411        tr_element.appendChild(td_element3);
3412        tr_element.appendChild(td_element4);
3413        tr_element.appendChild(td_element5);
3414        tr_element.appendChild(td_element6);
3415
3416        tbody_element.appendChild(tr_element);
3417        table_element.appendChild(tbody_element);
3418        content_id_0.appendChild(table_element);
3419}
3420
3421function draw_search_division(msg){
3422        var tbody = Element('tbody_box');
3423        var tr = document.createElement("TR");
3424        var td = document.createElement("TD");
3425        td.colSpan = '7';
3426        td.width = '100%';
3427
3428        var action_info_table = document.createElement("TABLE");
3429        var action_info_tbody = document.createElement("TBODY");
3430
3431        action_info_table.className = "action_info_table";
3432        action_info_table.width = "100%";
3433
3434        var action_info_tr = document.createElement("TR");
3435
3436        var action_info_th1 = document.createElement("TH");
3437        action_info_th1.width = "40%";
3438        action_info_th1.innerHTML = "&nbsp;";
3439
3440        var action_info_th2 = document.createElement("TH");
3441
3442        action_info_th2.innerHTML = msg;
3443        action_info_th2.className = "action_info_th";
3444        action_info_th2.setAttribute("noWrap", "true");
3445
3446        var action_info_th3 = document.createElement("TH");
3447        action_info_th3.width = "40%";
3448        action_info_th3.innerHTML = "&nbsp;";
3449
3450        action_info_tr.appendChild(action_info_th1);
3451        action_info_tr.appendChild(action_info_th2);
3452        action_info_tr.appendChild(action_info_th3);
3453        action_info_tbody.appendChild(action_info_tr);
3454        action_info_table.appendChild(action_info_tbody);
3455
3456        td.appendChild(action_info_table);
3457        tr.appendChild(td);
3458        tbody.appendChild(tr);
3459}
3460
3461function draw_search_box(){
3462        var content_id_0 = Element("content_id_0");
3463        var table = document.createElement("TABLE");
3464        table.id = "table_box";
3465        table.width = 'auto';
3466        var tbody = document.createElement("TBODY");
3467        tbody.id = "tbody_box";
3468
3469        table.className = "table_box";
3470        table.setAttribute("frame", "below");
3471        table.setAttribute("rules", "none");
3472        table.setAttribute("cellpadding", "0");
3473        table.onkeydown = function (e){
3474                if (is_ie)
3475                {
3476                        if ((window.event.keyCode) == 46)
3477                        {
3478                                //delete_all_selected_msgs_imap();
3479                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
3480                        }
3481                }
3482                else
3483                {
3484                        if ((e.keyCode) == 46)
3485                        {
3486                                //delete_all_selected_msgs_imap();
3487                                proxy_mensagens.delete_msgs(get_current_folder(),'selected','null');
3488                        }
3489                }
3490        };
3491        if (is_ie)
3492                table.style.cursor = "hand";
3493
3494        table.appendChild(tbody);
3495        content_id_0.appendChild(table);
3496}
3497        var idx_cc = 0;
3498function draw_plugin_cc(ID, addrs)
3499{
3500        connector.loadScript("ccQuickAdd");
3501
3502        var array_addrs = '';
3503        var array_name  = '';
3504        var cc_data = new Array();
3505        if(typeof(addrs.name) != 'undefined') {
3506                array_name      = LTrim(addrs.name).split(" ");
3507                array_addrs = new Array(addrs.email);
3508        }
3509        else {
3510                array_addrs = (typeof addrs == 'object' ? addrs.toString().split("\" ") : addrs.split("\" "));
3511                array_name      = LTrim(array_addrs[0]).replace('"','').split(" ");
3512        }
3513
3514        var _split = array_name[0].split('@');
3515        cc_data[0] = _split[0];
3516        cc_data[1] = _split[0];
3517        cc_data[2] = '';
3518
3519        for (i=1; i < array_name.length; i++)
3520                cc_data[2] += array_name[i] + " ";
3521
3522
3523        if(array_addrs.length > 1)
3524                cc_data[3] = array_addrs[1] ? array_addrs[1].replace("&lt;",'').replace("&gt;",'') : '';
3525        else
3526                cc_data[3] = array_addrs[0];
3527
3528        var sm_envelope_img1 = '<img style="cursor:'+ (is_ie ? 'hand' : 'pointer') +'" title="' + get_lang("Add Contact") +
3529        '" onclick="ccQuickAddOne.showList(\''+cc_data+'\')" src="./templates/'+template+'/images/user_card.png">';
3530        var to_addybook_add = "<SPAN id='insert_plugin_"+idx_cc+"_"+ID+"'>";
3531        to_addybook_add += addrs;
3532        to_addybook_add +=  sm_envelope_img1;
3533        idx_cc++;
3534        to_addybook_add += "</SPAN>";
3535        return to_addybook_add;
3536}
3537function deny_email(email){
3538        connector.loadScript("filter");
3539        connector.loadScript("filters");
3540        var dn_em       = document.createElement("SPAN");
3541                dn_em.id = "tt_d";
3542                dn_em.onclick = function(){filter.new_rule(email);};
3543                dn_em.setAttribute("title",get_lang("Block Sender"));
3544                dn_em.style.cursor = "pointer";
3545                dn_em.innerHTML = "<img align='top' src='./templates/"+template+"/images/deny.gif'>";
3546        return dn_em;
3547
3548}
3549function show_div_address_full(id, type) {
3550        var div_address_full = Element("div_"+type+"address_full_"+id);
3551        if(!div_address_full) {
3552                div_address_full = document.createElement("SPAN");
3553                div_address_full.id = "div_"+type+"address_full_"+id;
3554                div_address_full.style.display="none";
3555                var _address = eval(type+"address_array['"+id+"']");
3556                var isOverLimit = (_address.length > 100);
3557
3558                if(isOverLimit) {
3559                        alert("Esse campo possui muitos endereços ("+_address.length+" destinatários).\r\n"+
3560                        "Para evitar o travamento do navegador, o botão 'Adicionar Contato' foi desabilitado!");
3561                }
3562
3563                for(var idx = 1 ; idx  < _address.length;idx++) {
3564                        div_address_full.innerHTML += isOverLimit ?  '<br>'+_address[idx] : ','+draw_plugin_cc(id,_address[idx]);
3565                }
3566                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>)";
3567                Element(type+"_"+id).appendChild(div_address_full);
3568        }
3569        Element('div_'+type+'address_'+id).style.display='none';
3570        div_address_full.style.display='';
3571}
3572function draw_footer_box(num_msgs){
3573        folder = get_current_folder();
3574        connector.loadScript('wfolders');
3575        var span_R = Element("table_message");
3576        var span_options = Element("span_options");
3577        if(!span_options) {
3578                span_options = document.createElement("TD");
3579                span_options.style.fontSize = "12";
3580                span_options.id = "span_options";
3581                span_R.appendChild(span_options);
3582        }
3583
3584        var change_font_color = 'onmouseover="var last_class = this.className;'+
3585                                'if (this.className != \'message_options_over\')'+
3586                                'this.className=\'message_options_active\'; '+
3587                                'this.onmouseout=function(){this.className=last_class;}"';
3588
3589        span_options.innerHTML =
3590                '<span class="message_options_trash"><span ' + change_font_color + ' title="'+get_lang("Delete")+'" class="message_options" onclick=proxy_mensagens.delete_msgs(\'null\',\'selected\',\'null\')>'+get_lang("Delete")+'</span></span>'+
3591                '<span class="message_options_move"><span ' + change_font_color + ' title="'+get_lang("Move")+'" class="message_options" onclick=wfolders.makeWindow(\"\",\"move_to\")>'+get_lang("Move")+'</span></span>'+
3592                ((expresso_offline)?" ":'<span class="message_options_print"><span ' + change_font_color + ' title="'+get_lang("Print")+'" class="message_options" onclick=print_all()>'+get_lang("Print")+'</span></span>')+
3593//              '<span class="message_options_print"><span ' + change_font_color + ' title="'+get_lang("Print")+'" class="message_options" onclick=print_all()>'+get_lang("Print")+'</span></span>'+
3594                ((expresso_offline)?" ":'<span class="message_options_export"><span ' + change_font_color + ' title="'+get_lang("Export")+'" class="message_options" onclick="proxy_mensagens.export_all_messages()">'+get_lang("Export")+'</span></span>') +
3595                ((expresso_offline)?" ":'<span class="message_options_import"><span ' + change_font_color + ' title="'+get_lang("Import")+'" class="message_options" onclick="import_window()">'+get_lang("Import")+'</span></span>');
3596        if(preferences.use_local_messages==1 && !expresso_offline)
3597                if(proxy_mensagens.is_local_folder(current_folder))
3598                        span_options.innerHTML += '&nbsp; <span title="'+get_lang("Unarchive")+'" class="message_options" onclick="expresso_local_messages.unarchive_msgs(\''+folder+'\',null)">'+get_lang("Unarchive")+'</span>';
3599                else
3600                        span_options.innerHTML += '&nbsp; <span title="'+get_lang("Archive")+'" class="message_options" onclick="archive_msgs(\''+folder+'\',null)">'+get_lang("Archive")+'</span>';
3601        if (use_spam_filter) {
3602                if ( current_folder == 'INBOX'+cyrus_delimiter+'Spam' ) {
3603                        span_options.innerHTML += ' | <span ' + change_font_color + ' title="'+get_lang("Not Spam")+'" class="message_options" onclick="nospam(\'selected\',\'null\',\'null\')">'+get_lang("Not Spam")+'</span>';
3604                }
3605                else {
3606                        span_options.innerHTML += ' | <span ' + change_font_color + ' title="'+get_lang("Mark as Spam")+'" class="message_options" onclick="spam(\'null\', \'selected\',\'null\')">'+get_lang("Mark as Spam")+'</span>';
3607                }
3608        }
3609        var span_D = Element("span_D");
3610        if(!span_D){
3611                span_D = document.createElement("TD");
3612                span_D.align = "right";
3613                span_D.style.fontSize = "12";
3614                span_D.id = "span_D";
3615                span_R.appendChild(span_D);
3616        }
3617        span_D.innerHTML =
3618                 get_lang("List")+': '+
3619        '<span ' + change_font_color + ' id="span_flag_SORTARRIVAL" class="'+(search_box_type == 'ALL' ? 'message_options_over' : 'message_options')+'" title="'+get_lang("All")+'" onclick="if(\'ALL\' == \''+search_box_type+'\') return false;sort_box(\'ALL\',\''+sort_box_type+'\')">'+get_lang("All")+'</span>, '+
3620        '<span ' + change_font_color + ' id="span_flag_UNSEEN" class="'+(search_box_type == 'UNSEEN' ? 'message_options_over' : 'message_options')+'" title="'+get_lang("l_unseen")+'" onclick="if(\'UNSEEN\' == \''+search_box_type+'\') return false;sort_box(\'UNSEEN\',\''+sort_box_type+'\')">'+get_lang("l_unseen")+'</span>, '+
3621        '<span ' + change_font_color + ' id="span_flag_SEEN" class="'+(search_box_type == 'SEEN' ? 'message_options_over' : 'message_options')+'" title="'+get_lang("l_seen")+'" onclick="if(\'SEEN\' == \''+search_box_type+'\') return false;sort_box(\'SEEN\',\''+sort_box_type+'\')">'+get_lang("l_seen")+'</span>, '+
3622        '<span ' + change_font_color + ' id="span_flag_ANSWERED" class="'+(search_box_type == 'ANSWERED' ? 'message_options_over' : 'message_options')+'" title="'+get_lang("title_answered")+'" onclick="if(\'ANSWERED\' == \''+search_box_type+'\') return false;sort_box(\'ANSWERED\',\''+sort_box_type+'\')">'+get_lang("l_answered")+'</span>, '+
3623        '<span ' + change_font_color + ' id="span_flag_FLAGGED" class="'+(search_box_type == 'FLAGGED' ? 'message_options_over' : 'message_options')+'" title="'+get_lang("l_important")+'" onclick="if(\'FLAGGED\' == \''+search_box_type+'\') return false;sort_box(\'FLAGGED\',\''+sort_box_type+'\')">'+get_lang("l_important")+'</span>&nbsp;&nbsp;';
3624        draw_paging(num_msgs);
3625        Element("tot_m").innerHTML = num_msgs;
3626}
Note: See TracBrowser for help on using the repository browser.