source: trunk/expressoMail1_2/js/jscode/draw_messages.js @ 2814

Revision 2814, 35.0 KB checked in by niltonneto, 14 years ago (diff)

Ticket #1040 - Corrige problemas na largura de barra de funções e scroll vertical.

Line 
1draw_message.prototype.draw_message_header = function(header,border_id){
2        this.id = border_id;
3
4        var table_message = createAndSet("TABLE",['id','border','width'],['table_message_'+border_id,"0","100%"]);
5        table_message.id = 'table_message_'+border_id;
6        var tbody_message = document.createElement("TBODY");
7        if (!this.make_options_message(header,tbody_message))
8                return;
9
10        table_message.appendChild(tbody_message);
11        var content = document.getElementById('content_id_' + border_id);
12        content.appendChild(table_message);
13        loading_img = content.appendChild(loading_img);
14};
15
16
17draw_message.prototype.draw_message_body = function (info_msg){
18        var table_message = Element('table_message_'+this.id);
19        var tbody_message = table_message.childNodes[0];
20
21        var tbody_message_others_options = document.createElement("TBODY");
22        var tr1 = document.createElement("TR");
23        tr1.className = "tr_message_header";
24        var td1 = createAndSet('TD',['width'],['7%'],get_lang("From: "));
25        td1.appendChild(deny_email(info_msg.from.email));
26        var id=this.id;
27
28        if (info_msg.sender){
29                var tr111 = document.createElement("TR");
30                tr111.className = "tr_message_header";
31                var td111 = createAndSet('TD',['noWrap'],['true'],get_lang("Sent by")+": ");
32                td111.appendChild(deny_email(info_msg.sender.email));
33                var sender = document.createElement("TD");
34                sender.className = "header_message_field";
35                sender.id = "sender_"+id;
36                sender.innerHTML += this.draw_plugin_cc(info_msg.sender.full);
37                var sender_values = createAndSet("INPUT",['id','type','value'],["sender_values_"+id,"HIDDEN",info_msg.sender.full]);
38
39                tbody_message_others_options.appendChild(appendChilds(tr111, td111, sender, sender_values));
40        }
41
42        var from = createAndSet('TD',['id','class'],["from_"+this.id,"header_message_field"],info_msg.from.full);
43
44        if (info_msg.Draft != "X"){
45                from.innerHTML += this.draw_plugin_cc(info_msg.from);
46                tbody_message_others_options.appendChild(tr1);
47        }
48        var from_values = createAndSet('INPUT',['id','type','value'],["from_values_"+id,"HIDDEN",info_msg.from.full]);
49        var local_message = createAndSet("INPUT",['id','name','type','value'],["is_local_"+this.id,"is_local","HIDDEN",(info_msg.local_message)?"1":"0"]);
50        appendChilds(tr1,td1,from,from_values,local_message);
51
52        if (info_msg.reply_to){
53                var tr11 = document.createElement("TR");
54                tr11.className = "tr_message_header";
55                var _td11 = createAndSet('TD',['noWrap'],['true'],get_lang("Reply to")+": ");
56                var _reply_to = createAndSet('TD',['id', 'class'],["reply_to_"+id, "header_message_field"],this.draw_plugin_cc(info_msg.reply_to));
57                var _reply_to_values = createAndSet('INPUT',['id', 'type', 'value'],["reply_to_values_"+id,"HIDDEN",info_msg.reply_to]);
58                tbody_message_others_options.appendChild(appendChilds(tr11,_td11,_reply_to,_reply_to_values));
59        }
60        //////////////////////////////////////////////////////////////////////////////////////////////////////
61        var tr2 = document.createElement("TR");
62        tr2.className = "tr_message_header";
63        var td2 = document.createElement("TD");
64        td2.innerHTML = get_lang("To: ");
65        var to = document.createElement("TD");
66        to.id = "to_"+id;
67
68        var _to_values = createAndSet('INPUT',['id', 'type', 'value'],["to_values_"+id, "HIDDEN", info_msg.toaddress2]);
69        // Salva a pasta da mensagem
70        var _input_cfolder = createAndSet('INPUT',['id', 'name', 'type', 'value'],["input_folder_"+id, "input_folder", "hidden", info_msg.msg_folder]);
71        td2.appendChild(_input_cfolder);
72
73        toaddress_array[id] = info_msg.toaddress2.split(",");
74        if (toaddress_array[id].length > 1){
75                to.innerHTML += this.draw_plugin_cc(toaddress_array[id][0]);
76                var _div_toaddrs = createAndSet('SPAN',['id','style'],["div_toaddress_"+id,'display: inline']," (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+id+"','to');>"+get_lang('more')+"</a>)");
77                to.appendChild(_div_toaddrs);
78        }
79        else {
80                toAdd = toaddress_array[id].toString().replace("<","&lt;");
81                toAdd = toAdd.replace(">","&gt;");
82                to.innerHTML += this.draw_plugin_cc(toAdd);
83        }
84        to.className = "header_message_field";
85        tbody_message_others_options.appendChild(appendChilds(tr2,td2,to,_to_values));
86
87        if (info_msg.cc){
88                var tr3 = document.createElement("TR");
89                tr3.className = "tr_message_header";
90                var td3 = document.createElement("TD");
91                td3.innerHTML = "CC: ";
92                var cc = createAndSet("TD",['id', 'class'],["cc_"+this.id,"header_message_field"]);
93
94                var cc_values = createAndSet("INPUT",['id', 'type', 'value'],["cc_values_"+this.id, "HIDDEN", info_msg.cc]);
95                ccaddress_array[this.id] = info_msg.cc.split(",");             
96                if (ccaddress_array[this.id].length > 1){
97                        var div_ccaddress = document.createElement("SPAN");
98                        div_ccaddress.id = "div_ccaddress_"+this.id;
99                        var div_ccaddress_full = createAndSet("SPAN",['id', 'style'],["div_ccaddress_full_"+this.id, "display: inline"]);
100                        cc.innerHTML = this.draw_plugin_cc(ccaddress_array[this.id][0]);
101                        div_ccaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+this.id+"','cc');>"+get_lang('more')+"</a>)";
102                        cc.appendChild(div_ccaddress);
103                }
104                else{
105                        cc.innerHTML = this.draw_plugin_cc(info_msg.cc);
106                }
107                tbody_message_others_options.appendChild(appendChilds(tr3,td3,cc,cc_values));
108        }
109
110        if (info_msg.bcc)
111        {
112                tbody_message_others_options.appendChild(this.getBcc(info_msg.bcc));
113        }
114
115        var tr4 = document.createElement("TR");
116        tr4.className = "tr_message_header";
117        var td4 = document.createElement("TD");
118        td4.innerHTML = get_lang("Date: ");
119        var msgFull = info_msg.fulldate.split(' ');
120
121        var date = createAndSet('TD',['id','class'],["date_"+id,"header_message_field"],info_msg.fulldate);
122        var date_day = createAndSet('INPUT',['id', 'type', 'value'],["date_day_"+id, "HIDDEN", msgFull[0]]);
123        var date_hour = createAndSet('INPUT',['id', 'type', 'value'],["date_hour_"+id, "HIDDEN", msgFull[1]]);
124        tbody_message_others_options.appendChild(appendChilds(tr4,td4,date,date_day,date_hour));
125
126        var tr5 = document.createElement("TR");
127        tr5.className = "tr_message_header";
128        var td5 = document.createElement("TD");
129        td5.innerHTML = get_lang("Subject");
130        var subject = createAndSet('TD',['id', 'class'],["subject_"+this.id, "header_message_field"],info_msg.subject);
131        tbody_message_others_options.appendChild(appendChilds(tr5,td5,subject));
132        if (info_msg.attachments.length > 0){
133                var tr6 = document.createElement("TR");
134                tr6.className = "tr_message_header";
135                var td6 = document.createElement("TD");
136                td6.innerHTML = get_lang("Attachments: ");
137
138                var attachments = document.createElement("TD");
139                attachments.align='left';
140                td6.vAlign = "top";
141
142                var zipped_attachments = '';
143                if(info_msg.attachments.length >= 1) {
144                        var zipped_attachments  = createAndSet("TABLE",['style','cellPadding','cellSpacing'],['margin-bottom: 4px','0','0']);
145                        var td = document.createElement("TD");
146                        if(info_msg.attachments.length > 1) {
147                                var link_attachment     = document.createElement("A");
148                                if(proxy_mensagens.is_local_folder(current_folder))
149                                        link_attachment.setAttribute("href", "javascript:expresso_local_messages.download_all_local_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
150                                else
151                                        link_attachment.setAttribute("href", "javascript:download_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
152                                link_attachment.innerHTML = " "+info_msg.attachments.length+' '+get_lang('files')+' :: '+get_lang('Download all atachments');
153                                link_attachment.innerHTML += '<BR>';
154                                td.appendChild(link_attachment);
155                        }
156                        var tr = document.createElement("TR");
157                        if(parseInt(preferences.remove_attachments_function))
158                        {
159                                var del_attachments = document.createElement("A");
160                                del_attachments.setAttribute("href", "javascript:remove_all_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"')");
161                                del_attachments.innerHTML = get_lang('remove all attachments');
162                                del_attachments.appendChild(document.createElement('BR'));
163                                td.appendChild(del_attachments);
164                                tr.appendChild(td);
165                        }
166                        tr.appendChild(td);
167                        zipped_attachments.appendChild(tr);
168                        attachments.appendChild(zipped_attachments);
169                }
170
171                attachments.id = "attachments_" + this.id;
172                for (var i=0; i<info_msg.attachments.length; i++){
173                        var link_attachment = document.createElement("A");
174                        link_attachment.setAttribute("href", proxy_mensagens.link_anexo(info_msg,i));
175                        //link_attachment.setAttribute("href", "javascript:download_attachments('"+info_msg.msg_folder+"','"+info_msg.msg_number+"',"+i+",'"+info_msg.attachments[i].pid+"','"+info_msg.attachments[i].encoding+"')");
176                        link_attachment.innerHTML = url_decode(info_msg.attachments[i].name);
177                        link_attachment.innerHTML += "&nbsp;"+borkb(info_msg.attachments[i].fsize);
178
179                        if((url_decode(info_msg.attachments[i].name).indexOf(".ics")!=-1) || (url_decode(info_msg.attachments[i].name).indexOf(".vcard")!=-1)){
180                                //Link para importar calendário
181                                var link_import_attachment = createAndSet("IMG",['src','onclick','title','align','style'],["templates/"+template+"/images/new.png","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+"');",get_lang("Import to calendar"),"top","cursor: pointer"]);
182                                var space = document.createElement("span");
183                                space.innerHTML = "&nbsp;";
184                                appendChilds(attachments,link_attachment,space,link_import_attachment);
185                        }
186                        else {
187                                link_attachment.innerHTML += '<BR>';
188                                attachments.appendChild(link_attachment);
189                        }
190                }
191                tr6.appendChild(td6);
192                tr6.appendChild(attachments);
193                tbody_message_others_options.appendChild(tr6);
194        }
195
196        var div = document.createElement("DIV");
197        div.id = "div_message_scroll_"+this.id;
198        div.style.background = 'WHITE';
199        div.style.overflow = "auto";
200        div.style.width = "100%";
201
202        var table_msg_details = createAndSet("TABLE",['id','width','class'],['table_msg_details_' + this.id, '100%','table_message']);
203        table_msg_details.style.display = 'none';
204        table_msg_details.appendChild(tbody_message_others_options);
205        div.appendChild(table_msg_details);
206
207        var tr = document.createElement("TR");
208        var td = document.createElement("TD");
209        td.colSpan = '2';
210
211        var newBody = this.blockImage(info_msg,this.id,td);
212
213        td.appendChild(div);
214        tr.appendChild(td);
215        tbody_message.appendChild(tr);
216
217        ////////////////////////////////////////////////////////////////////////////////////////////////////// 
218        //Make the body message.
219        ///////////////////////////////////////////////////////////////////////////////////////////////////////
220        var tr = document.createElement("TR");
221        tr.className = "tr_message_body";
222        var td = document.createElement("TD");
223        //td.setAttribute("colSpan","2");
224        newBody = newBody.replace("<body","<span");
225        newBody = newBody.replace("<BODY","<span");
226        div.innerHTML+= "<span id='body_"+this.id+"' style='font-size:16px;'>"+newBody+"</span><br><br>";
227        function mailto( link )
228        {
229                var mail = link.href.substr( 7 );
230                link.onclick = function( )
231                {
232                        new_message_to( mail );
233                        return false;
234                };
235        }
236        var links = div.getElementsByTagName( 'a' );
237        for ( var i = 0; i < links.length; i++ )
238                if ( links.item( i ).href.indexOf( 'mailto:' ) === 0 )
239                        mailto( links.item( i ) );
240                else
241                {
242                        if ( links.item( i ).href.indexOf( 'javascript:' ) !== 0 )
243                                links.item( i ).setAttribute( 'target', '_blank' );
244                }
245
246        if ((info_msg.thumbs)&&(info_msg.thumbs.length > 0)){
247                ////////////////////////////////////////////////////////////////////////////////////////////////////// 
248                //Make the thumbs of the message.
249                //////////////////////////////////////////////////////////////////////////////////////////////////////
250                div.appendChild(this.getThumbs(info_msg.attachments, info_msg.thumbs, info_msg.msg_number, info_msg.msg_folder));
251        }
252
253
254        var msg_number = createAndSet("INPUT",['id','type','value'],["msg_number_" + this.id, "hidden", info_msg.msg_number]);
255        var content = document.getElementById('content_id_' + this.id);
256        try{
257                loading_img = content.removeChild( loading_img );
258        }catch(e){};
259        content.appendChild(msg_number);
260        //////////////////////////////////////////////////////////////////////////////////////////////////////
261
262        //Exibe o cabecalho da mensagem totalmente aberto caso esteja setado nas preferencias do usuario
263        if (preferences.show_head_msg_full == 1)
264        {
265                option_hide_more.onclick();
266
267                if (Element('div_toaddress_'+this.id) != null)
268                {
269                        show_div_address_full(this.id,'to');
270                }       
271                if (Element('div_ccaddress_'+this.id) != null)
272                {
273                        show_div_address_full(this.id,'cc');
274                }
275        }
276
277};
278
279draw_message.prototype.make_options_message = function(info_msg, tbody_message){
280        var tr0 = document.createElement("TR");
281        tr0.className = "tr_message_header";
282        var td0 = document.createElement("TD");
283        var table_message_options = createAndSet("TABLE",['border','width','class'],["0","100%",'table_message']);
284        var tbody_message_options = document.createElement("TBODY");
285        var tr = document.createElement("TR");
286        var td = document.createElement("TD");
287        td.setAttribute("noWrap","true");
288        var _name = '';
289        var menuHidden = Element("folderscol").style.display == 'none' ? true : false;
290
291        var folder_id = info_msg.msg_number;
292        var folder = document.getElementById(folder_id);
293        if (!folder){
294                delete_border(this.id);
295                return false;
296        }
297
298        var next_previous_msg_td = this.createNxtPrevButtons(info_msg.msg_folder,folder_id);
299        if (typeof(next_previous_msg_td) == 'undefined')
300                return false;
301
302
303        var _maxChar = menuHidden ? 40 : 15;
304
305        if (info_msg.from.name)
306        {
307                var spanName = document.createElement("SPAN");
308                spanName.innerHTML = info_msg.from.name;
309                _name = spanName.innerHTML.length > _maxChar ? spanName.innerHTML.substring(0,_maxChar) + "..." : spanName.innerHTML;
310        }
311        else
312                _name = info_msg.from.email.length > _maxChar ? info_msg.from.email.substring(0,_maxChar) + "..." : info_msg.from.email;
313        var id = this.id;
314        td.innerHTML = _name.bold() + ', ' + info_msg.udate;
315        if (info_msg.attachment.names.length > 0)
316                td.innerHTML += "&nbsp<img style='cursor:pointer' onclick='javascript:Element(\"option_hide_more_"+id+"\").onclick()' src ='" + URL_SERVER + "expressoMail1_2/templates/"+template+"/images/clip.gif' title='"+info_msg.attachment.names+"'>";
317
318        if (typeof(info_msg.signature) == 'string')
319        {
320                if (info_msg.signature != "void")
321                        td.innerHTML += '&nbsp;<img style="cursor:pointer" onclick="alert(\''+ get_lang("This message is signed, and you can trust.") + info_msg.signature +'\');" src="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/signed.gif">';
322                else
323                        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='" + URL_SERVER + "expressoMail1_2/templates/"+template+"/images/invalid.gif'>";
324        }
325
326        if (info_msg.DispositionNotificationTo)
327        {
328                td.innerHTML += '&nbsp;<img style="cursor:pointer" alt="'+ get_lang('Message with read notification') + '" title="'+ get_lang('Message with read notification') + '" src="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/notification.gif">';
329        }
330
331        // NORMAL MSG
332        if(info_msg.Draft != 'X')
333        {
334                var options = createAndSet("TD",['noWrap','width','align'],['true','30%','right']);
335                var option_hide_more = createAndSet("SPAN",['class','value','id'],['message_options','more_options','option_hide_more_'+id],get_lang('show details'));
336                option_hide_more.onclick = function(){
337                        if (this.value != 'hide_options'){
338                                this.innerHTML = "<b><u>"+get_lang('hide details')+"</u></b>";
339                                this.value = 'hide_options';
340                                Element('table_msg_details_'+id).style.display = '';
341
342                        }
343                        else{
344                                this.innerHTML = get_lang('show details');
345                                this.value = 'more_options';
346                                Element('table_msg_details_'+id).style.display = 'none';
347                        }
348                        resizeWindow();
349                };
350                var option_mark = createAndSet("TD",['width','align'],['50%','left']);
351
352                var option_mark_as_unseen = '<span class="message_options" onclick="changeLinkState(this,\'seen\');set_messages_flag(\'unseen\','+
353                                                folder_id+');write_msg(\''+get_lang('Message marked as ')+get_lang("Unseen")+
354                                                '.\');">'+get_lang("Unseen")+'</span>, ';
355
356                if (info_msg.Flagged == "F")
357                        var option_mark_important = '<span class="message_options" onclick="changeLinkState(this,\'important\');set_messages_flag(\'unflagged\','+
358                                                        folder_id+');write_msg(\''+get_lang('Message marked as ')+get_lang("Normal")+
359                                                        '.\');">'+get_lang("Normal")+'</span>';
360                else
361                        var option_mark_important = '<span class="message_options" onclick="changeLinkState(this,\'normal\');set_messages_flag(\'flagged\','+folder_id+');write_msg(\''+get_lang('Message marked as ')+get_lang("Important")+
362                                                                    '.\');">'+get_lang("Important")+'</span>';
363                option_mark.innerHTML = option_mark_as_unseen+option_mark_important;
364
365                var option_forward = createAndSet("SPAN",['id','class'],['msg_opt_forward_'+this.id, 'message_options'],get_lang('Forward'));
366                option_forward.onclick = function(){new_message('forward', this.id);};
367                appendChilds(options,option_hide_more,createAndSet('SPAN',false,false,'&nbsp;|&nbsp;'),option_forward);
368
369                var option_reply_options = createAndSet("IMG",['id', 'src', 'value'],['msg_opt_reply_options_'+id,URL_SERVER+'expressoMail1_2/templates/default/images/down.png','show']);
370                option_reply_options.onmouseover = function(){
371                                option_reply_options.src= URL_SERVER+'expressoMail1_2/templates/default/images/over.png';
372                };
373                option_reply_options.onmouseout = function(){
374                        if (this.value == 'show')
375                        {
376                                option_reply_options.src= URL_SERVER+'expressoMail1_2/templates/default/images/down.png';
377                        }
378                        else
379                        {
380                                option_reply_options.src= URL_SERVER+'expressoMail1_2/templates/default/images/pressed.png';
381                        }
382                };
383                option_reply_options.onclick = function(){
384                        if (this.value != 'hide'){
385                                this.value = 'hide';
386                                option_reply_options.src= URL_SERVER+'expressoMail1_2/templates/default/images/pressed.png';
387                                Element('tr_other_options_'+id).style.display = '';
388
389                        }
390                        else{
391                                this.value = 'show';
392                                option_reply_options.src= URL_SERVER+'expressoMail1_2/templates/default/images/down.png';
393                                Element('tr_other_options_'+id).style.display = 'none';
394                        }
395                };
396
397                var _option_reply = createAndSet("SPAN",['id','class'],['msg_opt_reply_'+id,'message_options'],get_lang('Reply'));
398                _option_reply.onclick = function(){new_message('reply_with_history', id);};
399
400                appendChilds(options,createAndSet('SPAN',false,false,'&nbsp;|&nbsp;'),option_reply_options,_option_reply);
401                appendChilds(tr,td,option_mark,options,next_previous_msg_td);
402                tbody_message_options.appendChild(tr);
403
404                ////////// OTHER OPTIONS ////////////////////
405                var _tr_other_options = createAndSet("TR",['id'],['tr_other_options_' + id]);
406                _tr_other_options.style.display = 'none';
407
408                var div_other_options = document.createElement("DIV");
409
410                var option_mark_as      = '<span>'+get_lang("Mark as")+'</span>: ';
411                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>, ';
412                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>, ';
413                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> | ';
414
415                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>';
416                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> | ';
417
418                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> | </div>';
419
420                div_other_options.innerHTML = option_reply_to_all + option_reply_to_all_without_history + option_reply_without_history;
421                if (use_spam_filter) {
422                        if(info_msg.msg_folder == 'INBOX'+cyrus_delimiter+'Spam')
423                                div_other_options.innerHTML += ' | <span class="reply_options" onclick="nospam('+info_msg.msg_number+',\'null\', \''+info_msg.msg_folder+'\')";>'+get_lang("Not Spam")+'</span>';
424                        else
425                                div_other_options.innerHTML += ' | <span class="reply_options" onclick="spam(\''+info_msg.msg_folder+'\', '+info_msg.msg_number+',\'null\')";>'+get_lang("Mark as Spam")+'</span>';
426                }
427
428                var td_other_options = createAndSet("TD",['colSpan','align','noWrap'],['3','right','true']);
429                td_other_options.appendChild(div_other_options);
430
431                _tr_other_options.appendChild(td_other_options);
432                tbody_message_options.appendChild(_tr_other_options);
433                ////////// END OTHER OPTIONS ////////////////
434                table_message_options.appendChild(tbody_message_options);
435                td0.appendChild(table_message_options);
436                tr0.appendChild(td0);
437                tbody_message.appendChild(tr0);
438                if (info_msg.signature && info_msg.signature.length > 0)
439                {
440                        tbody_message.appendChild(putSignature(this.id,info_msg,td));
441                }
442        }
443        else    // IF DRAFT
444        {
445                var options = createAndSet('TD',['width','noWrap','align'],['1%','true','right']);
446                var option_hide_more = createAndSet("SPAN",['class','value','id'],['message_options','more_options','option_hide_more_'+this.id],get_lang('Show details'));
447                option_hide_more.onclick = function(){
448                        var _height = Element("div_message_scroll_"+id).style.height;
449                        _height = parseInt(_height.replace("px",""));
450                        var _offset = 35;
451                        if (this.value != 'hide_options'){
452                                this.innerHTML = "<b><u>"+get_lang('Hide details')+"</u></b>";
453                                this.value = 'hide_options';
454                                Element("div_message_scroll_"+id).style.height = (_height - _offset)+"px";
455                                Element('table_msg_details_'+id).style.display = '';
456                        }
457                        else{
458                                this.innerHTML = get_lang('show details');
459                                this.value = 'more_options';
460                                Element("div_message_scroll_"+id).style.height = (_height + _offset)+"px";
461                                Element('table_msg_details_'+id).style.display = 'none';
462                        }
463                };
464                var option_edit = createAndSet('SPAN',['class'],['message_options'], get_lang('Edit'));
465                option_edit.onclick= function () { new_message('edit',this.id); };
466                appendChilds(options, option_hide_more, createAndSet('SPAN',false,false,"&nbsp;|&nbsp;"), option_edit);
467
468                tbody_message_options.appendChild(appendChilds(tr, td, options, next_previous_msg_td));
469                table_message_options.appendChild(tbody_message_options);
470                td0.appendChild(table_message_options);
471                tr0.appendChild(td0);
472                tbody_message.appendChild(tr0);
473        }
474        return true;
475};
476
477
478/* Class draw_message */
479function draw_message(){
480        this.id=0;
481}
482draw_message.prototype.createNxtPrevButtons = function(msg_folder,folder_id){
483        var next_previous_msg_td = createAndSet("TD",[ "noWrap", "align", "width" ], [ "true", "right", "40px"]);
484        var img_next_msg = createAndSet("IMG", [ 'id', 'src', 'title' ], [
485                        'msg_opt_next_' + this.id,
486                        URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/down.button.png',
487                        get_lang('Next') ]);
488        img_next_msg.style.cursor = 'pointer';
489
490        var folder = document.getElementById(folder_id);
491        if (folder){ // mensagem local criptografada nao tem ID da pasta local
492                if (folder.nextSibling){
493                        var nextMsgBox = folder.nextSibling.name?folder.nextSibling.name:msg_folder;
494
495                        if (nextMsgBox == "INBOX/decifradas")// teste para ver se a mensagem vem da pasta oculta decifradas
496                                nextMsgBox = get_current_folder();
497
498                        img_next_msg.onclick = function()
499                        {
500                                openTab.type[currentTab] = 2;
501                                if ( nextMsgBox == undefined )
502                                       nextMsgBox = current_folder;
503                                for (var i=0; i < draw_box.headers_msgs.length; i++)
504                                        if (draw_box.headers_msgs[i].msg_number == folder.nextSibling.id){
505                                                var nextHeader = draw_box.headers_msgs[i];
506                                                break;
507                                        }
508                                proxy_mensagens.get_msg(nextHeader,nextMsgBox,true,show_msg,currentTab);
509                        };
510                }
511                else
512                {
513                        img_next_msg.src = URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/down.gray.button.png';
514                        img_next_msg.style.cursor = 'default';
515                }
516        }
517        else
518        {
519                img_next_msg.src = URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/down.gray.button.png';
520                img_next_msg.style.cursor = 'default';
521                if (!proxy_mensagens.is_local_folder(get_current_folder()) && !(msg_folder == "INBOX/decifradas")) // testa se a mensagem e local
522                {
523                        img_next_msg.onclick = function()
524                        {
525                                delete_border(this.id);
526                        };
527                }
528        }
529        var img_space = document.createElement("SPAN");
530        img_space.innerHTML = "&nbsp;";
531        var img_previous_msg = createAndSet("IMG",['id','src','title'],['msg_opt_previous_' + this.id,
532                        URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/up.button.png',
533                        get_lang('Previous')]);
534        img_previous_msg.style.cursor = 'pointer';
535
536        if (!folder){
537                delete_border(this.id);
538                return;
539        }
540        if (folder){ // mensagem local criptografada nao tem this.id da pasta local
541                if (folder.previousSibling)
542                {
543                        var previousMsgBox = folder.previousSibling.name?folder.previousSibling.name:msg_folder;
544
545                        if (previousMsgBox == "INBOX/decifradas") // teste para ver se a mensagem vem da pasta oculta decifradas
546                                previousMsgBox = get_current_folder();
547
548                        img_previous_msg.onclick = function()
549                        {
550                                openTab.type[currentTab] = 2;
551                                if ( previousMsgBox == undefined )
552                                       previousMsgBox = current_folder;
553                                 for (var i=0; i < draw_box.headers_msgs.length; i++)
554                                        if (draw_box.headers_msgs[i].msg_number == folder.previousSibling.id){
555                                                var previousHeader = draw_box.headers_msgs[i];
556                                                break;
557                                        }
558                                proxy_mensagens.get_msg(previousHeader,previousMsgBox,true,show_msg,currentTab);
559                        };
560                }
561                else
562                {
563                        img_previous_msg.src = URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/up.gray.button.png';
564                        img_previous_msg.style.cursor = 'default';
565                }
566        }
567        else
568        {
569                img_previous_msg.src = URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/up.gray.button.png';
570                img_previous_msg.style.cursor = 'default';
571                if (!proxy_mensagens.is_local_folder(get_current_folder()) && !(msg_folder == "INBOX/decifradas")) // testa se a mensagem e local
572                {
573                        img_previous_msg.onclick = function()
574                        {
575                                delete_border(this.id);
576                        };
577                }
578        }
579        next_previous_msg_td.appendChild(img_previous_msg);
580        next_previous_msg_td.appendChild(img_space);
581        next_previous_msg_td.appendChild(img_next_msg);
582        return next_previous_msg_td;
583
584};
585var idx_cc = 0;
586draw_message.prototype.draw_plugin_cc = function(addrs)
587{
588    expresso.connector.loadScript("jscode/ccQuickAdd");
589    var id=this.id;
590
591    var array_addrs = '';
592    var array_name      = '';
593    var cc_data = new Array();
594    if(typeof(addrs.name) != 'undefined') {
595        array_name      = LTrim(addrs.name).split(" ");
596        array_addrs = new Array(addrs.email);
597    }
598    else {
599        array_addrs = (typeof addrs == 'object' ? addrs.toString().split("\" ") : addrs.split("\" "));
600        array_name      = LTrim(array_addrs[0]).replace('"','').split(" ");
601    }
602
603    var _split = array_name[0].split('@');
604    cc_data[0] = _split[0];
605    cc_data[1] = _split[0];
606    cc_data[2] = '';
607
608    for (i=1; i < array_name.length; i++)
609        cc_data[2] += array_name[i] + " ";
610
611
612    if(array_addrs.length > 1)
613        cc_data[3] = array_addrs[1] ? array_addrs[1].replace("&lt;",'').replace("&gt;",'') : '';
614    else
615        cc_data[3] = array_addrs[0];
616
617    var sm_envelope_img1 = '<img style="cursor:'+ (is_ie ? 'hand' : 'pointer') +'" title="' + get_lang("Add Contact") +
618    '" onclick="ccQuickAddOne.showList(\''+cc_data+'\')" src="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/user_card.png">';
619    var to_addybook_add = "<SPAN id='insert_plugin_"+idx_cc+"_"+id+"'>";
620    to_addybook_add += addrs;
621    to_addybook_add +=  sm_envelope_img1;
622    idx_cc++;
623    to_addybook_add += "</SPAN>";
624    return to_addybook_add;
625};
626
627
628draw_message.prototype.show_signature_certificate_data = function(){
629        var _height = Element("div_message_scroll_"+this.id).style.height;
630        _height = parseInt(_height.replace("px",""));
631        var _offset = 130;
632        if (this.value == 'more_cert'){
633                //this.innerHTML += "<b><u>Mais Informaᅵᅵes</u></b>";
634                this.value = 'hide_cert';
635                Element("div_message_scroll_"+this.id).style.height = (_height + _offset)+"px";
636                Element('tr_signature_'+this.id).style.display = 'none';
637                Element('td_signature_'+this.id).style.display = 'none';
638
639        }
640        else{
641                //this.innerHTML += "Mais Informaᅵᅵes";
642                this.value = 'more_cert';
643                Element("div_message_scroll_"+this.id).style.height = (_height - _offset)+"px";
644                Element('tr_signature_'+this.id).style.display = '';
645                Element('td_signature_'+this.id).style.display = '';
646        }
647};
648
649draw_message.prototype.putSignature = function(info_msg,tdx){
650        var tr_signature = document.createElement("TR");
651        var td_signature = document.createElement("TD");
652        td_signature.className = 'tr_message_header';
653        tr_signature.id = 'tr_signature_'+this.id;
654        td_signature.colSpan = "5";
655        tr_signature.style.display = 'none';
656
657        for (i=0; i < info_msg.signature.length; i++)
658                td_signature.innerHTML += '<span>'+info_msg.signature[i]+'</span> <br /> ';
659        td_signature.innerHTML += '<hr></hr>';
660        var signature_status_pos = info_msg.signature[0].indexOf('Message untouched');
661        td_signature.id = "td_signature_"+this.id;
662        if(signature_status_pos < 0 )
663        {
664                tdx.innerHTML += '&nbsp;<img style="cursor:pointer" src="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/signed_error.gif" title="'+get_lang("Details")+'" onclick="show_signature_certificate_data(\'' + this.id + '\')">';
665                tr_signature.style.display = '';
666        }
667        else
668        {
669                tdx.innerHTML += '&nbsp;<img style="cursor:pointer" src="' + URL_SERVER + 'expressoMail1_2/templates/'+template+'/images/signed_table.gif" title="'+get_lang("Details")+'" onclick="show_signature_certificate_data(\'' + this.id + '\')">';
670        }
671        tr_signature.appendChild(td_signature);
672        return tr_signature;
673    };
674
675
676draw_message.prototype.getThumbs = function(attachments, thumbs, msg_number, msg_folder){
677                var table_message_thumbs = document.createElement("TABLE");
678                table_message_thumbs.width = "80%";
679                table_message_thumbs.style.borderTop = "2px solid rgb(170, 170, 170)";
680                var tbody_message_thumbs = document.createElement("TBODY");
681                var tr = document.createElement("TR");
682                tr.className = "tr_message_body";
683                var td = document.createElement("TD");
684                td.setAttribute("colSpan","2");
685                td.id = "body_thumbs_"+msg_number;
686                td.innerHTML += "&nbsp;<font color='DARKBLUE' size='2'><b>"+attachments.length+" "+get_lang("attachment")+(attachments.length > 1 ? "s" : "")+" "+get_lang("in this message")+"</font></b>";
687                var _link_attachments = '';
688                if(thumbs.length > 1){
689                        _link_attachments       = document.createElement("A");
690                        _link_attachments.className = "message_options";
691                        if(proxy_mensagens.is_local_folder(current_folder))
692                                _link_attachments.setAttribute("href", "javascript:expresso_local_messages.download_all_local_attachments('"+msg_folder+"','"+msg_number+"')");
693                        else
694                                _link_attachments.setAttribute("href", "javascript:download_all_attachments('"+msg_folder+"','"+msg_number+"')");
695                        _link_attachments.innerHTML = get_lang('Download all atachments');
696                }
697
698                if(_link_attachments){
699                        td.innerHTML += " :: ";
700                        td.appendChild(_link_attachments);
701                }
702
703                td.innerHTML += "<BR><img src='" + URL_SERVER + "expressoMail1_2/templates/"+template+"/images/menu/ktip.png'>"+get_lang("<b>Tip:</b> For faster save, click over the image with <u>right button</u>.");
704                td.innerHTML += "<BR>";
705
706                for (var i=0; i<thumbs.length; i++){
707                        if ((i % 4) == 0)
708                                td.innerHTML += "<BR>";
709                        td.innerHTML += thumbs[i];
710                        td.innerHTML += "&nbsp;&nbsp;";
711                }
712                tr.appendChild(td);
713                tbody_message_thumbs.appendChild(tr);
714                table_message_thumbs.appendChild(tbody_message_thumbs);
715                return table_message_thumbs;
716};
717
718draw_message.prototype.getBcc = function(bccField){
719        /*
720         * @AUTHOR Rodrigo Souza dos Santos
721         * @MODIFY-DATE 2008/09/11
722         * @BRIEF Adding routine to create bcc (blind carbon copy) field if there is one.
723         */
724        var tr3 = document.createElement("tr");
725        tr3.className = "tr_message_header";
726        var td3 = document.createElement("td");
727        td3.innerHTML = get_lang("BCC") + " : ";
728        var cco = document.createElement("td");
729        cco.id = "cco_"+this.id;
730
731        var cco_values = createAndSet("INPUT",['id', 'type', 'value'],["cco_values_"+this.id,"hidden",bccField]);
732        ccoaddress_array[this.id] = bccField.split(",");               
733        if (ccoaddress_array[this.id].length > 1){
734                var div_ccoaddress = document.createElement("SPAN");
735                div_ccoaddress.id = "div_ccoaddress_"+this.id;
736                var div_ccoaddress_full = createAndSet("SPAN",['id', 'style'],["div_ccoaddress_full_"+this.id, "display:inline"]);
737                /*
738                 * The function below is ugly, doesn't possible use this.
739                 * The problem is that the code's function was written
740                 * on a hardcode concept.
741                 */
742                //cco.innerHTML = this.draw_plugin_cc(ccoaddress_array[this.id][0]);
743                cco.innerHTML = ccoaddress_array[this.id][0];
744                div_ccoaddress.innerHTML += " (<a STYLE='color: RED;' onclick=javascript:show_div_address_full('"+this.id+"','cco');>"+get_lang('more')+"</a>)";
745                cco.appendChild(div_ccoaddress);
746        }
747        else{
748                /*
749                 * The function below is ugly, it is not possible to use this.
750                 * The problem is that the code's function was written
751                 * on a hardcode concept.
752                 */
753                //cco.innerHTML = this.draw_plugin_cc(info_msg.cco);
754                cco.innerHTML = bccField;
755        }
756        cco.className = "header_message_field";
757        return appendChilds(tr3,td3,cco,cco_values);
758};
759
760draw_message.prototype.blockImage = function(info_msg,ID,td){
761        var imgTag = info_msg.body.match(/(<img[^>]*src[^>=]*=['"]?[^'">]*["']?[^>]*>)|(<[^>]*(style[^=>]*=['"][^>]*background(-image)?:[^:;>]*url\()[^>]*>)/gi);
762
763        var newBody = info_msg.body;
764        if(!info_msg.showImg && imgTag)
765        {
766                var domains = '';
767                var blocked = false;
768                var forbidden = true;
769
770                if (preferences.notification_domains != null && typeof(preferences.notification_domains) != 'undefined')
771                {
772                        domains = preferences.notification_domains.split(',');
773                        for(var j = 0; j < imgTag.length; j++)
774                        {
775                                for (var i = 0; i < domains.length; i++)
776                                {
777                                        if (imgTag[j].match(/cid:([\w\d]){5,}/) || imgTag[j].match(/src=\"\.\/inc\/show_embedded_attach\.php/g))
778                                        {
779                                                forbidden = false;
780                                                continue;
781                                        }
782                                        imgSource = imgTag[j].match(/=['"](http:\/\/)+[^'"\/]*/);
783                                        if (imgSource && imgSource.toString().substr(5).match(domains[i]))
784                                                forbidden = false;
785                                }
786                                if (forbidden)
787                                {
788                                        newBody = newBody.replace(imgTag[j],"<img src='" + URL_SERVER + "expressoMail1_2/templates/"+template+"/images/forbidden.jpg'>");
789                                        blocked=true;
790                                }
791                        }
792                        if (blocked)
793                        {
794                                var showImgLink = document.createElement('DIV');
795                                showImgLink.id="show_img_link_"+ID;
796                                showImgLink.onclick = function(){show_msg_img(info_msg.msg_number,info_msg.msg_folder)};
797                                showImgLink.className="show_img_link";
798                                showImgLink.innerHTML = get_lang("Show images from")+": "+info_msg.from.email;
799                                td.appendChild(showImgLink);
800                        }
801                }
802        }
803        return newBody;
804
805};
806
807draw_msg = new draw_message();
808
Note: See TracBrowser for help on using the repository browser.