source: trunk/expressoMail1_2/js/common_functions.js @ 271

Revision 271, 18.2 KB checked in by niltonneto, 16 years ago (diff)

Fechamento de versão: 1.2211
Tickets:

#50 Criar uma funcionalidade para inserir imagens embutidas no corpo da mensagem.
#174 Implementar rascunho com anexos
#182 Criar funcionalidade de salvar automaticamente os emails em rascunhos
#183 Funcionalidade de drag and drop na busca
#185 Adicionar tabela na edição de email
#186 Correção do problema com nomes de anexos com caracteres especiais
#188 Definir aspectos de QA do ExpressoMail?
#190 Problema ao salvar informações de filtros no IE

  • Property svn:eol-style set to native
  • Property svn:executable set to *
Line 
1// BEGIN: FUNCTION RESIZE WINDOW
2var _showBar = showBar;
3var _hideBar = hideBar;
4
5function __showBar(){
6        _showBar();
7        resizeWindow();
8}
9
10function __hideBar(){
11        _hideBar();
12        resizeWindow();
13}
14showBar = __showBar;
15hideBar = __hideBar;
16
17window.onresize = resizeWindow;
18
19function resizeWindow(){
20
21        var bar = Element("toolbar");
22        var offset = 0;
23        if(bar.style.visibility != 'hidden')
24                offset = (bar.offsetHeight ? bar.offsetHeight :  bar.clientHeight);     
25
26        var screenHeight = document.body.clientHeight ? document.body.clientHeight : document.body.offsetHeight;
27        var defaultHeight = screenHeight - offset;
28
29        if(BordersArray) {
30                for(var i = 1; BordersArray.length > 1 && i < BordersArray.length;i++) {
31                        var div_scroll = Element("div_message_scroll_"+BordersArray[i].sequence);
32                        if(div_scroll)
33                                div_scroll.style.height = defaultHeight - 122;
34                        var div = Element("content_id_"+BordersArray[i].sequence);
35                        if(div)
36                                div.style.height = defaultHeight - 73;
37                }
38        }
39        Element('content_folders').style.height = defaultHeight - (is_ie ? 165 : 150);
40        if(Element("divScrollMain"))
41                Element("divScrollMain").style.height   = defaultHeight - (is_ie ? 111 : 110); 
42}
43// END: FUNCTION RESIZE WINDOW
44
45// onUnload edit message
46if(!is_ie)
47{
48        var beforeunload = window.onbeforeunload;
49        window.onbeforeunload = function()
50        {
51                if ( typeof beforeunload == 'function' )
52                        beforeunload();
53
54                return unloadMess();
55        };
56}
57function unloadMess(){
58        var mess = get_lang("Your message has not been sent and will be discarted.");
59        for(var i = 0; i < BordersArray.length;i++) {
60                var body = Element('body_'+BordersArray[i].sequence);
61                if (body && body.contentWindow && body.contentWindow.document.designMode.toLowerCase() == 'on') {
62                        return mess;
63                }
64        }
65}
66// Translate words and phrases using user language from eGroupware.
67function get_lang(_key,_arg1,_arg2,_arg3,_arg4) {
68
69        if(!array_lang[0]){             
70                return _key+"*";
71        }
72        _value = "";   
73        for(i = 0; i < array_lang[0].length;i++){
74                if(array_lang[0][i] == _key.toLowerCase()) {
75                        _value = array_lang[1][i];                                     
76                        break;
77                }
78        }       
79       
80        if(!_value)
81                return _key+"*";
82                       
83        if(_arg1 || _arg2 ||_arg3 || _arg4) {
84                for(j = 1; j <= 4; j++){
85                        if(eval("_arg"+j)) {
86                                var regExp = new RegExp("%"+j+"");             
87                                _value = _value.replace(regExp,eval("_arg"+j));
88                        }
89                }
90        }
91       
92        return _value;
93}
94
95// Make decimal round, using in size message
96function round(value, decimal){
97        var return_value = Math.round( value * Math.pow( 10 , decimal ) ) / Math.pow( 10 , decimal );
98        return( return_value );
99}
100
101// Change the class of message.
102// In refresh, the flags UnRead and UnSeen don't exist anymore.
103function set_msg_as_read(msg_number, selected){
104        tr_message = Element(msg_number);
105        if (exist_className(tr_message, 'tr_msg_unread'))
106                decrement_folder_unseen();
107        remove_className(tr_message, 'tr_msg_unread');
108        remove_className(tr_message, 'selected_msg');
109        add_className(tr_message, 'tr_msg_read');
110        return true;
111}
112
113function set_msg_as_unread(msg_number){
114        tr_message = Element(msg_number);
115        if (exist_className(tr_message, 'tr_msg_read'))
116                increment_folder_unseen();
117        remove_className(tr_message, 'tr_msg_read');
118        remove_className(tr_message, 'selected_msg');
119        add_className(tr_message, 'tr_msg_unread');
120}
121
122function set_msg_as_flagged(msg_number){
123        var msg = Element(msg_number);
124        remove_className(msg, 'selected_msg');
125        add_className(msg, 'flagged_msg');
126        Element("td_message_important_"+msg_number).innerHTML = '<img src=templates/default/images/important.gif title=Importante!>';
127}
128
129function set_msg_as_unflagged(msg_number){
130        var msg = Element(msg_number);
131        remove_className(msg, 'selected_msg');
132        remove_className(msg, 'flagged_msg');
133        Element("td_message_important_"+msg_number).innerHTML = '';
134}
135
136function get_current_folder(){
137        return current_folder;
138}
139
140// Kill current box (folder or page).
141function kill_current_box(){
142        var box = document.getElementById("table_box");
143        if (box != null)
144                box.parentNode.removeChild(box);
145}
146
147// Kill current paging.
148function kill_current_paging(){
149        var paging = Element("span_paging");
150        if (paging != null)
151                paging.parentNode.removeChild(paging);
152}
153
154//Get the current number of messages in a page.
155function get_messages_number_in_page(){
156        //Get element tBody.
157        main = document.getElementById("tbody_box");
158               
159        // Get all TR (messages) in tBody.
160        main_list = main.childNodes;
161       
162        return main_list.length;
163}
164
165function download_attachments(msg_folder, msg_number, idx_file, msg_part, encoding, new_file_name, show_iframe){
166        div_attachment = document.getElementById("id_div_attachment");
167        var params = '';
168       
169        if (div_attachment == null){
170                var div_attachment = document.createElement("DIV");
171                div_attachment.id="id_div_attachment";
172                document.body.appendChild(div_attachment);
173        }
174        if(new_file_name)
175                params = "&newfilename="+new_file_name;
176        if(encoding)
177                params += "&encoding="+encoding;
178
179        div_attachment.innerHTML="<iframe style='display:none;width:0;height:0' name='attachment' src='inc/gotodownload.php?msg_folder="+msg_folder+"&msg_number="+msg_number+"&idx_file="+idx_file+"&msg_part="+msg_part+params+"'></iframe>";
180}
181
182function download_all_attachments(msg_folder, msg_number){
183        var handler_source = function(data){           
184                download_attachments(null, null, data, null,null,'anexos.zip');
185        }
186        cExecute("$this.exporteml.download_all_attachments",handler_source,"folder="+msg_folder+"&num_msg="+msg_number);
187}
188// Add Input File Dynamically.
189function addFile(id_border){
190        divFiles = document.getElementById("divFiles_"+id_border);
191       
192        if (divFiles.lastChild)
193                var countDivFiles = parseInt(divFiles.lastChild.id.split('_')[2]) + 1;
194
195        if (! countDivFiles)
196                var countDivFiles = 1;
197       
198        divFile = document.createElement('DIV');
199       
200        var inputFile = document.createElement("INPUT");
201       
202        var tmp_id_border = document.createAttribute('id_border');
203        tmp_id_border.value = id_border;
204       
205        inputFile.setAttributeNode(tmp_id_border);
206        inputFile.id = "inputFile_"+id_border+"_"+countDivFiles;
207        inputFile.onchange = function () {validateFileExtension(this.value, this.id.replace("input","div"), this.getAttribute('id_border'));};
208        inputFile.type = 'file';
209        inputFile.size = 50;
210        inputFile.maxLength = 255;
211        inputFile.name='file_'+countDivFiles;
212       
213        divFile.appendChild(inputFile);
214       
215        var linkFile = document.createElement("A");
216        linkFile.id = "linkFile_"+id_border+"_"+countDivFiles;
217        linkFile.href='javascript:void(0)';
218        linkFile.onclick=function () {removeFile(this.id.replace("link","div"));};
219        linkFile.innerHTML=get_lang("Remove"); 
220        //divFile.innerHTML += "&nbsp;&nbsp;";
221        divFile.appendChild(linkFile);
222        divFile.id = "divFile_"+id_border+"_"+countDivFiles;   
223        divFiles.appendChild(divFile);
224}
225//      Remove Input File Dynamically.
226function removeFile(id){
227        var border_id = id.substr(8,1);
228        var el = Element(id);
229        el.parentNode.removeChild(el);
230}
231
232function validateFileExtension(fileName, id, id_border){
233        var error_flag  = false;
234        if (fileName[0] != '/'){ // file name is windows format?
235                var file = fileName.substr(fileName.lastIndexOf('\\') + 1, fileName.length);
236                if ((fileName.indexOf(':\\') != 1) && (fileName.indexOf('\\\\') != 0)) // Is stored in partition or a network file?
237                        error_flag = true;     
238        }
239        else // is nix
240                var file = fileName.substr(fileName.lastIndexOf('/') + 1, fileName.length);                                             
241
242        var fileExtension = file.split(".");
243        fileExtension = fileExtension[(fileExtension.length-1)];
244        for(var i=0; i<denyFileExtensions.length; i++)
245        {
246                if(denyFileExtensions[i] == fileExtension)
247                {
248                        error_flag = true;
249                        break;
250                }
251                       
252        }
253
254        if (error_flag == true){
255                alert(get_lang('File extension forbidden or invalid file') + '.');
256                removeFile(id);
257                addFile(id_border);
258                return false;
259        }
260        return true;
261       
262}
263
264var setTimeout_write_msg = 0;
265var old_msg = false;
266// Funcao usada para escrever mensagem
267// notimeout = True : mensagem nao apaga
268function write_msg(msg, notimeout){     
269       
270        if (setTimeout_write_msg)
271                clearTimeout(setTimeout_write_msg);
272       
273        var msg_div = Element('em_div_write_msg');
274        var old_divStatusBar = Element("divStatusBar");
275
276        if(!msg_div) {
277                msg_div = document.createElement('DIV');
278                msg_div.id = 'em_div_write_msg';
279                msg_div.style.height = is_ie ? '17px' : '15px';
280                msg_div.style.background = '#f7f8fa';
281                msg_div.style.display = 'none';
282                old_divStatusBar.parentNode.insertBefore(msg_div,old_divStatusBar);
283        }       
284        msg_div.innerHTML = '<table bgcolor="#f7f8fa" width=100% cellspacing="0" cellpadding="0" border="0"><tbody><tr><th width="40%"></th><th noWrap class="action_info_th">'+msg+'</th><th width="40%"></th></tr></tbody></table>';
285        old_divStatusBar.style.display = 'none';
286        msg_div.style.display = '';     
287        // Nao ponha var na frente!! jakjr
288        handle_write_msg = function(){
289                try{
290                        if(!old_msg)
291                                clean_msg();
292                        else
293                                write_msg(old_msg, true);                       
294                }
295                catch(e){}
296        }
297        if(notimeout)
298                old_msg = msg;
299        else
300                setTimeout_write_msg = setTimeout("handle_write_msg();", 5000);
301}
302// Funcao usada para apagar mensagem sem timeout
303function clean_msg(){
304        old_msg = false;
305        var msg_div = Element('em_div_write_msg');
306        var old_divStatusBar = Element("divStatusBar");
307        if(msg_div)
308                msg_div.style.display = 'none';
309        old_divStatusBar.style.display = '';   
310}
311
312function make_body_reply(body, to, date_day, date_hour){
313        to = to.replace("<","&lt;");
314        to = to.replace(">","&gt;");
315        block_quoted_body ="<br><br>";
316        block_quoted_body += get_lang('At %1, %2 hours, %3 wrote:', date_day, date_hour, to);
317        block_quoted_body += "<blockquote style=\"border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;\">";
318        block_quoted_body += body;
319        block_quoted_body += "</blockquote>";
320        return block_quoted_body;
321}
322
323function make_forward_body(body, from, date, subject, to, cc){
324        from = from.replace(/</g,"&lt;");
325        from = from.replace(/>/g,"&gt;");
326        to = to.replace(/</g,"&lt;");
327        to = to.replace(/>/g,"&gt;");
328        var forward_body = '<BR><BR>---------- ' + get_lang('Forwarded message') + ' ----------<BR>';
329        forward_body += get_lang('From') + ': ' + from + '<BR>';
330        forward_body += get_lang('Date') + ': ' + date + '<BR>';
331        forward_body += get_lang('Subject') + ': ' + subject + '<BR>';
332        forward_body += get_lang('To') + ': ' + to+ '<BR>';
333        if(cc != undefined){
334                cc = cc.replace(/</g,"&lt;");
335                cc = cc.replace(/>/g,"&gt;");
336                forward_body += get_lang('CC') + ': ' + cc+ '<BR><BR>';
337        }
338        forward_body += body;
339        return forward_body;
340}
341
342function emMessageSearch(e,value){
343        var     e  = is_ie ? window.event : e;
344        if(e.keyCode == 13) {
345                search_emails(value);
346        }
347}
348
349function emQuickSearch(emailList, field, ID){
350        var quickSearchKeyBegin;
351        var quickSearchKeyEnd;
352       
353        var handler_emQuickSearch = function(data)
354        {
355                window_DropDownContacts = Element('tipDiv');
356                if (window_DropDownContacts.style.visibility != 'hidden'){
357                        window_DropDownContacts.style.visibility = 'hidden';
358                }
359               
360                if ((!data.status) && (data.error == "many results")){
361                        alert(get_lang('More than %1 results. Please, try to refine your search.',200));
362                        return false;
363                }
364                       
365                if (data.length > 0){
366                        if ((field != 'null') && (ID != 'null'))
367                        {
368                                connector.loadScript("QuickCatalogSearch");
369                                QuickCatalogSearch.showList(data, quickSearchKeyBegin, quickSearchKeyEnd);
370                        }
371                        else
372                        {
373                                connector.loadScript("QuickSearchUser");
374                                QuickSearchUser.showList(data);
375                        }
376                }
377                else
378                        alert(get_lang('None result was found.'));
379                return true;
380        }
381       
382        if ((field != 'null') && (ID != 'null'))
383        {
384                Element(field +'_'+ ID).focus(); //necessário para o IE.
385                var i = getPosition(Element(field +'_'+ ID)); //inputBox.selectionStart;
386                var j = --i;
387
388                // Acha o inicio
389        while ((j >= 0) && (emailList.charAt(j) != ',')){j--};
390            quickSearchKeyBegin = ++j;
391
392            // Acha o final
393        while ((i <= emailList.length) && (emailList.charAt(i) != ',')){i++};
394            quickSearchKeyEnd = i;
395
396            // A Chave da Pesquisa
397        var search_for = trim(emailList.substring(quickSearchKeyBegin, quickSearchKeyEnd));
398        }
399        else
400                var search_for = emailList;
401       
402        if (search_for.length < 4){
403                alert(get_lang('Your search argument must be longer than 4 characters.'));
404                return false;
405        }
406       
407        cExecute ("$this.ldap_functions.quicksearch&search_for="+search_for+"&field="+field+"&ID="+ID, handler_emQuickSearch);
408}
409
410function folderbox(){
411        connector.loadScript("TreeS");
412        ttree.make_Window();
413}
414
415function filterbox(){
416        connector.loadScript("filter");
417        connector.loadScript("filters");
418        filters.Forms();
419}
420
421function sharebox(){
422        var handler_imap_getacl = function(data)
423        {
424                var options = '';
425                for (var x in data)
426                {
427                        options += "<option value='"+data[x].uid+"'>"+data[x].cn+"</option>";
428                }
429                connector.loadScript("sharemailbox");
430                sharemailbox.makeWindow(options);
431        }
432        cExecute ("$this.imap_functions.getacl", handler_imap_getacl);
433}
434
435function preferences_mail(){
436        connector.loadScript("preferences");
437        prefe.showList();
438}
439
440function search_emails(value){
441        connector.loadScript("search");
442        EsearchE.showForms(value);
443}
444
445function source_msg(id_msg,folder){
446        var num_msg = id_msg.substr(0,(id_msg.length - 2));
447        var handler_source = function(data){
448                download_attachments(null, null, data, null,null,'fonte_da_mensagem.txt');
449        }
450        cExecute("$this.exporteml.export_msg",handler_source,"folder="+url_decode(folder)+"&msgs_to_export="+num_msg);
451}
452
453function url_encode(str){
454    var hex_chars = "0123456789ABCDEF";
455    var noEncode = /^([a-zA-Z0-9\_\-\.])$/;
456    var n, strCode, hex1, hex2, strEncode = "";
457
458    for(n = 0; n < str.length; n++) {
459        if (noEncode.test(str.charAt(n))) {
460            strEncode += str.charAt(n);
461        } else {
462            strCode = str.charCodeAt(n);
463            hex1 = hex_chars.charAt(Math.floor(strCode / 16));
464            hex2 = hex_chars.charAt(strCode % 16);
465            strEncode += "%" + (hex1 + hex2);
466        }
467    }
468    return strEncode;
469
470
471function url_decode(str) {
472
473        var n, strCode, strDecode = "";
474        for (n = 0; n < str.length; n++) {
475            if (str.charAt(n) == "%") {
476                strCode = str.charAt(n + 1) + str.charAt(n + 2);
477                strDecode += String.fromCharCode(parseInt(strCode, 16));
478                n += 2;
479            } else {
480                strDecode += str.charAt(n);
481            }
482        }
483        return strDecode;
484
485
486
487function Element(element){
488        return document.getElementById(element);
489}
490
491function getPosition(obj)
492{
493        if(typeof obj.selectionStart != "undefined")
494        {
495        return obj.selectionStart;
496        }
497        else if(document.selection && document.selection.createRange)
498        {
499                var M = document.selection.createRange();
500                try
501                {
502                        var Lp = M.duplicate();
503                        Lp.moveToElementText(obj);
504                }
505                catch(e)
506                {
507                        var Lp=obj.createTextRange();
508                }
509               
510                Lp.setEndPoint("EndToStart",M);
511                var rb=Lp.text.length;
512               
513                if(rb > obj.value.length)
514                {
515                        return -1;
516                }
517                return rb;
518        }
519}
520
521function trim(inputString) {
522   if (typeof inputString != "string")
523        return inputString;
524     
525   var retValue = inputString;
526   var ch = retValue.substring(0, 1);
527   while (ch == " ") {
528          retValue = retValue.substring(1, retValue.length);
529          ch = retValue.substring(0, 1);
530   }
531   ch = retValue.substring(retValue.length-1, retValue.length);
532   while (ch == " ") {
533          retValue = retValue.substring(0, retValue.length-1);
534          ch = retValue.substring(retValue.length-1, retValue.length);
535   }
536   while (retValue.indexOf("  ") != -1) {
537          retValue = retValue.substring(0, retValue.indexOf("  ")) + retValue.substring(retValue.indexOf("  ")+1, retValue.length);
538   }
539   return retValue;
540}
541
542function increment_folder_unseen(){
543        var folder_id = get_current_folder();
544       
545        var folder_unseen = Element('dftree_'+folder_id+'_unseen');
546        if (folder_unseen)
547        {
548                folder_unseen.innerHTML = (parseInt(folder_unseen.innerHTML) + 1);
549                Element('new_m').innerHTML = '<font face="Verdana" size="1" color="RED">'+folder_unseen.innerHTML+'</font>';
550        }
551        else
552        {
553                tree_folders.getNodeById(folder_id).alter({caption: tree_folders.getNodeById(folder_id).caption + '<font style=color:red>&nbsp(</font><span id="dftree_'+folder_id+'_unseen" style=color:red>1</span><font style=color:red>)</font>'});
554                tree_folders.getNodeById(folder_id)._refresh();
555                Element('new_m').innerHTML = '<font face="Verdana" size="1" color="RED">1</font>';
556        }
557}
558function decrement_folder_unseen(){
559        var folder_id = get_current_folder();
560       
561        var folder_unseen = Element('dftree_'+folder_id+'_unseen');
562        if(!folder_unseen)
563                return;
564
565        if ((folder_unseen) && (parseInt(folder_unseen.innerHTML) > 1))
566        {
567                folder_unseen.innerHTML = (parseInt(folder_unseen.innerHTML) - 1);
568                Element('new_m').innerHTML = '<font face="Verdana" size="1" color="RED">'+folder_unseen.innerHTML+'</font>';
569        }
570        else if (parseInt(folder_unseen.innerHTML) <= 1)
571        {
572                var tmp_folder_name = tree_folders.getNodeById(folder_id).caption.split('<');
573                var folder_name = tmp_folder_name[0];
574                tree_folders.getNodeById(folder_id).alter({caption: folder_name});
575                tree_folders.getNodeById(folder_id)._refresh();
576                Element('new_m').innerHTML = 0;
577        }
578}
579
580function LTrim(value){
581        var w_space = String.fromCharCode(32);
582        var strTemp = "";
583        var iTemp = 0;
584       
585        if(v_length < 1)
586                return "";
587
588        var v_length = value ? value.length : 0;
589       
590        while(iTemp < v_length){
591                if(value && value.charAt(iTemp) != w_space){
592                        strTemp = value.substring(iTemp,v_length);
593                        break;
594                }
595                iTemp++;
596        }       
597        return strTemp;
598}
599
600//changes MENU background color.
601function set_menu_bg(menu)
602{
603        menu.style.backgroundColor = 'white';
604        menu.style.border = '1px solid black';
605}
606//changes MENU background color.
607function unset_menu_bg(menu)
608{
609        menu.style.backgroundColor = '';
610        menu.style.border = '1px solid #f7f7f7';
611}
612
613function array_search(needle, haystack) {
614        var n = haystack.length;
615        for (var i=0; i<n; i++) {
616                if (haystack[i]==needle) {
617                        return true;
618                }
619        }
620        return false;
621}
622
623 function lang_folder(fn) {
624        if (fn == "Inbox") return get_lang("Inbox");
625        if (special_folders[fn])
626                return get_lang(special_folders[fn]);
627        return fn;
628 }
629
630function add_className(obj, className){
631        if (!exist_className(obj, className))
632                obj.className = obj.className + ' ' + className;
633}
634
635function remove_className(obj, className){
636        var re = new RegExp("\\s*"+className);
637        obj.className = obj.className.replace(re, '');
638}
639
640function exist_className(obj, className){
641        if ( obj.className.indexOf(className) != -1 )
642                return true;
643        return false;
644}
645
646function select_all_messages(select)
647{
648        var main = Element("tbody_box");
649        var main_list = main.childNodes;
650        var len_main_list = main_list.length;
651       
652        if (select)
653        {
654                for (i=0; i<len_main_list; i++)
655                {
656                        Element("check_box_message_"+main_list[i].id).checked = true;
657                        add_className(Element(main_list[i].id), 'selected_msg');
658                }
659        }
660        else
661        {
662                for (i=0; i<len_main_list; i++)
663                {
664                        Element("check_box_message_"+main_list[i].id).checked = false;
665                        remove_className(Element(main_list[i].id), 'selected_msg');
666                }
667        }
668}
Note: See TracBrowser for help on using the repository browser.