source: trunk/expressoMail1_2/js/abas.js @ 5498

Revision 5498, 16.5 KB checked in by angelo, 12 years ago (diff)

Ticket #2485 - Otimizar acao de criar nova mensagem ou encaminhar

  • Property svn:eol-style set to native
  • Property svn:executable set to *
Line 
1var BordersArray = new Array();
2BordersArray[0] = new setBorderAttributes(0);
3var countBorders = 0;
4var partMsgs = new Array();
5
6
7function setBorderAttributes(ID)
8{
9        this.border_id = "border_id_"+ID;
10        this.sequence = ID;
11}
12
13
14function alternate_border(ID)
15{
16        msg_selected = false;//Controle da seleção de mensagens
17        if(isNaN(ID))
18                if(preferences.use_shortcuts == "1")
19                        select_msg((ID.split("_"))[0]);
20        if( document.getElementById("div_menu_c3") != null )
21        {
22                var node = document.getElementById("div_menu_c3").firstChild;
23               
24                while ( node )
25                {
26                        node.style.display = "none";
27                        node = node.nextSibling;
28                }
29               
30                if( document.getElementById("span_paging"+ID) != null )
31                        document.getElementById("span_paging"+ID).style.display = "block";
32        }
33       
34        if ( typeof win == 'object' && win.close && win.close.constructor == Function ){
35            var search_win = document.getElementById( 'window_QuickCatalogSearch' );
36            if(search_win){
37                search_win.style.visibility = 'hidden';
38            }
39            win.close( );
40        }
41               
42        if (! Element('border_id_'+ID))
43                return false; // Not possible to alternate
44        show_hide_span_paging(ID);
45        spanD = Element("span_D");
46        if (spanD)
47                spanD.style.display = (openTab.type[ID] == 0 ? '' : 'none');
48
49        var footer_menu = Element("footer_menu");       
50        var aba = Element('border_id_'+ID);
51        if (footer_menu != null) {
52                footer_menu.style.display = (openTab.type[ID] != 4 ? '' : 'none');
53                var alternate_menu = document.getElementById('localOption');
54               
55                if(alternate_menu != null && alternate_menu != 'undefined'){ //Quando Carregado o expresso mail
56                        if(openTab.imapBox[ID]!= null && openTab.imapBox[ID]!= 'undefined' ){ //Quando abrir uma Nova Mensagem
57                                if((openTab.imapBox[ID].indexOf("local_") >= 0)){                                               
58                                                alternate_menu.title = get_lang("Unarchive");
59                                                alternate_menu.removeAttribute("onclick");
60                                                if(!is_ie)
61                                                        alternate_menu.setAttribute("onclick",  'expresso_local_messages.unarchive_msgs(\''+openTab.imapBox[ID]+'\', null)');
62                                                else{
63                                                        alternate_menu.onclick = function(){
64                                                                expresso_local_messages.unarchive_msgs(openTab.imapBox[ID], null);
65                                                        }
66                                                }
67                                                alternate_menu.innerHTML = get_lang("Unarchive");
68                                               
69                                        }else{
70                                                alternate_menu.title = get_lang("Archive");
71                                                alternate_menu.removeAttribute("onclick");
72                                                if(!is_ie)
73                                                        alternate_menu.setAttribute("onclick", 'archive_msgs(\''+openTab.imapBox[ID]+'\', null)');             
74                                                else{
75                                                        alternate_menu.onclick = function(){
76                                                                archive_msgs(openTab.imapBox[ID], null);
77                                                        }       
78                                                }
79                                                alternate_menu.innerHTML = get_lang("Archive");
80                                        }
81                                       
82                        }
83                }
84               
85                if((aba.id.indexOf("_r") < 0) && (aba.id.indexOf("_0") < 0) && (aba.id.indexOf("id_search_") < 0) && (aba.id.indexOf("_s") < 0)){
86                        spanD.style.display = 'none';
87                        footer_menu.style.display = 'none';                     
88                }
89        }
90
91
92        var len = BordersArray.length;
93        for (var i=0; i < len; i++)
94        {
95                m = document.getElementById(BordersArray[i].border_id);
96                if ((m)&&(m.className == 'menu-sel'))
97                {
98                        m.className = 'menu';
99                        c = document.getElementById("content_id_"+BordersArray[i].sequence);
100                        c.style.display = 'none';
101                        if(Element("font_border_id_"+BordersArray[i].sequence))
102                                Element("font_border_id_"+BordersArray[i].sequence).className = 'font-menu';   
103
104                }
105        }
106
107        m = Element("border_id_"+ID);
108        if (m)
109                m.className = 'menu-sel';
110        if(Element("font_border_id_" + ID))
111                Element("font_border_id_" + ID).className = 'font-menu-sel';
112        var c = Element("content_id_"+ID)
113        if (c)
114                c.style.display = '';
115
116
117        // hide the DropDrowContact, if necessary
118        window_DropDownContacts = Element('tipDiv');
119        if ((window_DropDownContacts)&&(window_DropDownContacts.style.visibility != 'hidden')){
120                window_DropDownContacts.style.visibility = 'hidden';
121        }
122
123        numBox = getNumBoxFromTabId(ID);
124        if (typeof(ID)=='number') {
125                 numBox = ID;
126         }
127         else {
128             if (ID.match("search_"))
129             {
130                 if (ID.match("search_local_msg"))
131                 {
132                         var p = ID.search(/[0-9]/);
133                         numBox =  ID.substr(p);
134                 }
135                 else
136                 {
137                         numBox = ID.substr(7);
138                 }
139             }
140         }
141        currentTab=ID;
142        if( document.getElementById('to_'+ID) && document.getElementById('to_'+ID).type == "textarea"){
143            document.getElementById('to_'+ID).focus();
144        }
145        RichTextEditor.setEditable(ID);
146        return ID;
147}
148
149function create_border(borderTitle, id_value, search)
150{
151                       
152        borderTitle = ( ( borderTitle && borderTitle.constructor == String && borderTitle.length > 0 ) ? borderTitle : '&nbsp;' );
153
154        var resize = false;
155        resize = resize_borders();
156        if (!resize){
157            var str_continue = '';
158            var bolContinue = true;
159                        str_continue = '\n' + get_lang('You must manually close one of your tabs before opening a new one');
160            if (preferences.auto_close_first_tab == 1){
161                var children = Element('border_tr').childNodes;
162                var bolDelete = true;
163                for (var i=0; i<children.length; i++) {
164                    if ((children[i].nodeName === 'TD') && (children[i].id!=='border_id_0') && (children[i].id!=='border_blank'))
165                    {
166                        bolDelete = true;
167                        var num_child = children[i].id.toString().substr(10);
168                        alternate_border(num_child);
169                        if (editTest(num_child)){
170                            bolDelete = false;
171                        }
172                        if (bolDelete || bolContinue){
173                                                        str_fechar = '\n' + get_lang('Reached maximum tab limit. Want to close this tab');
174                                                        var confirmacao = confirm(str_fechar);
175                            if(confirmacao){
176                            bolContinue = false;
177                            delete_border(num_child, 'false');
178                            break;
179                                                        }else{
180                                                                return 'maximo';
181                        }
182                    }
183                }
184            }
185            }else{                     
186                alert(get_lang('Reached maximum tab limit') + str_continue );
187                return 'maximo';
188            }
189        }
190       
191        if (! id_value){ // Is new message?
192                var ID = parseInt(BordersArray[(BordersArray.length-1)].sequence) + 1;
193                        if(isNaN(ID)){
194                                var aux = BordersArray[(BordersArray.length-1)].sequence.split("_");
195                                ID = parseInt(aux[1]) + 1;
196                        }
197        }else
198        {
199                if (Element("border_id_"+id_value)) // It's opened already!
200                        return alternate_border(id_value);
201               
202                var ID = id_value;
203                if(isNaN(ID) && ID.indexOf("search_local") >= 0){
204                        if(current_folder.indexOf("local") >= 0)
205                                openTab.imapBox[ID] = current_folder;
206                        else
207                                openTab.imapBox[ID] = 'local_search';
208                }else if(isNaN(ID) && ID.indexOf("search_") >= 0){
209                        if(current_folder.indexOf("local") < 0)
210                                openTab.imapBox[ID] = current_folder;
211                        else
212                                openTab.imapBox[ID] = 'search';
213                }else if( (currentTab != 0) && isNaN(currentTab) && (currentTab.indexOf("search") >= 0) && (ID.indexOf("msg") < 0) ) {
214                        var id_border = currentTab.replace(/[a-zA-Z_]+/, "");
215                        ID_TR = ID.toString().substr(0,ID.toString().indexOf("_r"));
216                        var tr = Element(ID_TR);
217                        openTab.imapBox[ID] = (tr.getAttribute('name') == null?get_current_folder():tr.getAttribute('name'));
218                }else
219                        openTab.imapBox[ID] = current_folder;
220        }
221        td = document.createElement("TD");
222        td.id="border_id_" + ID;
223        if(resize)
224        {
225                td.setAttribute("width", parseInt(resize)+"px");
226                td.style.width = parseInt(resize)+"px";
227        }
228        else
229                td.setAttribute("width", "200px");
230
231        td.setAttribute("align", "right");
232        td.onclick = function(){alternate_border(ID);resizeWindow()};
233        td.setAttribute("noWrap","true");
234    td.alt = borderTitle.replace( '&nbsp;', ' ' );
235    td.title = borderTitle;
236        borderTitle = borderTitle ?  borderTitle : id_value ? get_lang("No Subject") : "&nbsp;" ;
237        td.value = borderTitle;
238        if (borderTitle.length > 21)
239                borderTitle = borderTitle.substring(0,21) + "...";
240
241        if ( resize )
242                borderTitle = borderTitle.substring(0, resize*0.08);
243       
244        var cc = search;
245        if(!cc){
246                if(isNaN(ID)){
247                        var is_local = ID.match('.*_local_.*');
248                        if(!is_local)
249                                cc = document.getElementById("em_message_search").value;
250                        else{
251                                cc = document.getElementsByName(currentTab)[0].value;
252                        }
253                }else{
254                        cc ="";
255                }
256        }
257
258        td.innerHTML = "<div style='width:100%;border:0;padding:0;'>\n\
259                            <div id='font_border_id_" + ID+"' class='font-menu' style='width:*;'>" +
260                                borderTitle +
261                            "</div>\n\
262                            <div style='width:1px;float:left;clear:right;'>\n\
263                                <img onmousedown='javascript:return false' style='cursor:pointer' onclick=delete_border('" + ID + "','false') src='templates/"+template+"/images/close_button.gif'/>\n\ " +
264                            "</div>\n\ " +
265                                                        "<input type=\"hidden\" name=\""+ ID+"\" value=\""+cc+"\">" +
266                        "</div>";
267       
268        bb = document.getElementById("border_blank");
269        parent_bb = bb.parentNode; //Pego o tbody
270        parent_bb.insertBefore(td, bb);
271
272        if(! Element("border_id_"+id_value+"_r") ||((typeof(id_value) == 'string') && id_value.match(/_r$/))){
273                $(td).draggable({
274                        helper: function(event){
275                                if(     borderTitle.length > 18 )
276                                        return $(DataLayer.render('../prototype/modules/mail/templates/draggin_box.ejs', {texto : borderTitle.substring(0,18) + "...", type: "messages"}));
277                                else
278                                        return $(DataLayer.render('../prototype/modules/mail/templates/draggin_box.ejs', {texto : borderTitle, type: "messages"}));
279                        },
280                        cursorAt: { cursor: "move", top: 5, left: 56 },
281                        refreshPositions: true ,
282                        scroll: true,
283                        scrollSensitivity: 100,
284                        scrollSpeed: 100,
285                        containment: "#divAppbox"
286                });
287        }
288                //_dragArea.makeDragged(td, id_value,td.value);
289
290        BordersArray[BordersArray.length] = new setBorderAttributes(ID);
291
292        var div = document.createElement("DIV");
293        div.id = "content_id_" + ID;
294        div.className = "conteudo";
295        div.style.display='';
296
297        div.style.overflow = "hidden";
298
299        Element("exmail_main_body").insertBefore(div,Element("footer_menu"));       
300        alternate_border(ID);
301        return ID;
302}
303
304function resize_borders()
305{
306        var numBorders = count_borders();
307
308        if (numBorders > 8)
309                return false;
310
311        return redim_borders(numBorders+1);
312}
313
314function count_borders()
315{
316        var numBorders = 0;
317        var children = Element('border_tr').childNodes;
318        for (var i=0; i<children.length; i++) {
319            if ((children[i].nodeName === 'TD') && (children[i].id!=='border_id_0') && (children[i].id!=='border_blank'))
320                numBorders++;
321        }
322
323        return numBorders;
324}
325
326function redim_borders(numBorders)
327{
328        var children = Element('border_tr').childNodes;
329        var clientWidth = (window.document.body.clientWidth - findPosX(Element("exmail_main_body"))) - Element("border_id_0").clientWidth - 30;
330        var newWidthTD = (clientWidth/numBorders)-6;
331        newWidthTD = newWidthTD > 200 ? 200 : (newWidthTD < 50 ? 50 : newWidthTD);
332        children = Element('border_tr').childNodes;
333        for (var i=0; i<children.length; i++) {
334                if ((children[i].nodeName === 'TD') && (children[i].id!=='border_id_0') && (children[i].id!=='border_blank')){
335                        children[i].style.width = newWidthTD;
336                        set_border_caption(children[i].id, children[i].title, newWidthTD);
337                }
338        }
339        return newWidthTD;
340}
341
342
343
344
345function set_border_caption(border_id, title, border_width)
346{
347        var border = document.getElementById(border_id);
348        if (border_width == null)
349        {
350            border_width = border.clientWidth;
351        }
352        var caption = "";
353        Element("font_"+border.id).style.width = (border_width - 30)+'px';
354        Element("font_"+border.id).innerHTML = title;
355        return(title);
356}
357
358opened_alert = false;
359
360function draftTests(ID, msg_sent){
361        var cancel = new LertButton(get_lang('cancel'), function() {
362        Element("border_id_"+ID).onclick = function () { alternate_border(ID);};
363        $("#to_"+ID).focus();
364        opened_alert = false;
365    });
366       
367    var yes = new LertButton(get_lang('Save'), function() {
368        save_msg(ID, 'undefined', true);
369        openTab.toPreserve[ID] = false;
370        close_delete(ID, msg_sent);
371        delete(openTab.type[ID]);
372                //write_msg(get_lang('Your message was save as draft in folder %1.', lang_folder('Drafts')));
373               
374    });
375    var discard = new LertButton(get_lang('Discard'), function() {
376                        if (openTab.imapBox[ID] && !openTab.toPreserve[ID])
377            {
378                //delete_msgs(openTab.imapBox[ID], openTab.imapUid[ID].toString(), 0)
379                //delete(openTab.imapBox[ID]);
380                openTab.toPreserve[ID] = false;
381            }
382                        delete(openTab.type[ID]);
383            close_delete(ID, msg_sent);
384    });
385        if( $("#save_message_options_"+ID).attr("disabled") == "disabled") {
386                openTab.toPreserve[ID] = false;
387        close_delete(ID, msg_sent);
388        delete(openTab.type[ID]);
389        }else{
390                var titulo = '<b>' + get_lang('Warning') + '!</b>';
391                var message = get_lang("Your changes are not saved. What to do?");
392                var multConfirm = new Lert(
393                        titulo,
394                        message,
395                        [cancel,discard,yes],
396                        {
397                                        defaultButton:yes,
398                                        icon:'js/lert/images/dialog-help.gif'
399                        });
400                multConfirm.display();
401                opened_alert = true;
402        }
403}
404
405function editTest(ID){
406    var body = document.getElementById('body_'+ ID);
407    if (body)
408    {
409        var save_link = Element("save_message_options_"+ID);
410        if (openTab.toPreserve[ID] == undefined)
411                openTab.toPreserve[ID] = false;
412        if (((! openTab.toPreserve[ID] && ! ID.toString().match("_r")) || ((body.contentWindow) == 'object' && body.contentWindow.document.designMode.toLowerCase() == 'on')) && (save_link.onclick != ''))
413        {
414            return true;
415        }
416    }
417    return false;
418}
419
420function delete_border(ID, msg_sent)
421{
422   
423        var bolExecuteClose = true;
424        var borderElem = Element("border_id_" + ID);
425        if (borderElem){
426            borderElem.onclick = null; // It's avoid a FF3 bug
427        }else{
428            return false;
429        }
430        if (msg_sent == 'false')
431        {
432            if (editTest(ID)){
433                bolExecuteClose = false;
434                return(draftTests(ID, msg_sent));
435            }
436        }
437        if (bolExecuteClose)
438        {
439            close_delete(ID, msg_sent);
440                }
441                delete(openTab.type[ID]);
442        return true;
443}
444
445function close_delete(ID, msg_sent)
446{
447        openTab.toPreserve[ID] = false;
448        openTab.imapUid[ID] = 0;
449
450        // Limpa o autosave
451            if (preferences.auto_save_draft == 1 && autoSaveControl.timer[ID] !== null )
452            {
453                autoSaveControl.status[ID] = null;
454                clearInterval(autoSaveControl.timer[ID]);
455            }
456        ////////////////////////////////
457       
458        hold_session = false;
459        if (exist_className(Element('border_id_'+ID),'menu-sel'))
460        {
461                if (BordersArray[BordersArray.length-2].sequence == ID)
462                        this.alternate_border(0);
463                else
464                        this.alternate_border(BordersArray[BordersArray.length-2].sequence);
465        }
466
467        // Remove TD, title
468        border = Element('border_id_' + ID);
469        border.parentNode.removeChild(border);
470        var j=0;
471        var new_BordersArray = new Array();
472        for (i=0;i<BordersArray.length;i++)
473                if (document.getElementById(BordersArray[i].border_id) != null){
474                        new_BordersArray[j] = BordersArray[i];
475                        j++;
476                }
477        if(j == 1)
478                Element("footer_menu").style.display = '';
479        BordersArray = new_BordersArray;
480
481        // Remove Div Content
482        content = Element('content_id_' + ID);
483        content.parentNode.removeChild(content);
484        resizeWindow();
485        RichTextEditor.destroy( 'body_'+ID );
486       
487        //Caso for uma mensagem anexada tem que deletar ela da lixeira apos fechar a aba
488            var isPartMsg = false;
489            var id2 = ID.replace('_r','');
490            for(var ii = 0; ii < partMsgs.length; ii++)
491               if(partMsgs[ii] == id2){           
492                  isPartMsg = true;
493                  partMsgs[ii] = null;
494               }     
495
496            if(isPartMsg === true){
497                var handler_delete_msg = function(){};
498                cExecute ("$this.imap_functions.delete_msgs&folder=INBOX"+cyrus_delimiter+trashfolder+"&msgs_number="+id2,handler_delete_msg);
499            }
500        ///////////////////////////////////////////////////////////////////////////////////
501       
502        return true;
503}
504
505function getTabPrefix() { // define o prefixo para os checkboxes das mensagens
506        if (typeof(currentTab)!='number')
507                return currentTab+"_";
508        else
509                return "";
510}
511
512function getMessageIdFromRowId(row_id) { // extrai o id da mensagem do id da linha
513        var p = row_id.search("_s");
514        if (p>0)
515                return row_id.substr(0,p);
516        else
517                return row_id;
518}
519
520function getNumBoxFromTabId(tab_id) { // extrai o numBox do id da tab
521        if (typeof(tab_id)=='number') {
522                return tab_id;
523        }
524        else {
525                var p = tab_id.search(/[0-9]/);
526                return tab_id.substr(p);
527        }
528}
Note: See TracBrowser for help on using the repository browser.