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

Revision 5499, 17.9 KB checked in by gustavo, 12 years ago (diff)

Ticket #2484 - Melhorias na estrutura de diretórios do ExpressoMail?

  • 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                        start : function(){
275                                if($(".shared-folders").length){
276                                        $(".shared-folders").parent().find('.folder:not(".shared-folders")').droppable({
277                                                over : function(a, b){                                         
278                                                        //SETA BORDA EM VOLTA DA PASTA
279                                                        $(this).css("border", "1px solid black");
280                                                },
281                                                out : function(){
282                                                        //RETIRA BORDA EM VOLTA DA PASTA
283                                                        $(this).css("border", "");
284                                                },
285                                                //accept: ".draggin_mail",
286                                                drop : function(event, ui){
287                                                        $(this).css("border", "");
288                                                        if($(this).parent().attr('id') == undefined){
289                                                                var folder_to = 'INBOX';
290                                                                var to_folder_title = get_lang("Inbox");
291                                                        }else{
292                                                                var folder_to = $(this).parent().attr('id');
293                                                                var to_folder_title = $(this).attr('title');
294                                                        }               
295                                                        var folder_to_move = ui.draggable.parent().attr('id');
296                                                        var border_id = ui.draggable.find("input[type=hidden]").attr("name");
297                                                        if(folder_to_move == "border_tr"){
298                                                                var id_msg = border_id.substring("_");
299                                                                folder = $("#input_folder_"+border_id+"_r")[0] ? $("#input_folder_"+border_id+"_r").val() : (openTab.imapBox[border_id] ? openTab.imapBox[border_id]:get_current_folder());
300                                                                move_msgs2(folder, id_msg, border_id, folder_to, to_folder_title,true);
301                                                                return refresh();
302                                                        }
303                                                }
304                                        });
305                                }
306                        },
307                        stop :function(){
308                                $(".shared-folders").parent().find(".folder").droppable("destroy");
309                        },
310                        helper: function(event){
311                                if(     borderTitle.length > 18 )
312                                        return $(DataLayer.render('../prototype/modules/mail/templates/draggin_box.ejs', {texto : borderTitle.substring(0,18) + "...", type: "messages"}));
313                                else
314                                        return $(DataLayer.render('../prototype/modules/mail/templates/draggin_box.ejs', {texto : borderTitle, type: "messages"}));
315                        },
316                        cursorAt: { cursor: "move", top: 5, left: 56 },
317                        refreshPositions: true ,
318                        scroll: true,
319                        scrollSensitivity: 100,
320                        scrollSpeed: 100,
321                        containment: "#divAppbox"
322                });
323        }
324                //_dragArea.makeDragged(td, id_value,td.value);
325
326        BordersArray[BordersArray.length] = new setBorderAttributes(ID);
327
328        var div = document.createElement("DIV");
329        div.id = "content_id_" + ID;
330        div.className = "conteudo";
331        div.style.display='';
332
333        div.style.overflow = "hidden";
334
335        Element("exmail_main_body").insertBefore(div,Element("footer_menu"));       
336        alternate_border(ID);
337        return ID;
338}
339
340function resize_borders()
341{
342        var numBorders = count_borders();
343
344        if (numBorders > 8)
345                return false;
346
347        return redim_borders(numBorders+1);
348}
349
350function count_borders()
351{
352        var numBorders = 0;
353        var children = Element('border_tr').childNodes;
354        for (var i=0; i<children.length; i++) {
355            if ((children[i].nodeName === 'TD') && (children[i].id!=='border_id_0') && (children[i].id!=='border_blank'))
356                numBorders++;
357        }
358
359        return numBorders;
360}
361
362function redim_borders(numBorders)
363{
364        var children = Element('border_tr').childNodes;
365        var clientWidth = (window.document.body.clientWidth - findPosX(Element("exmail_main_body"))) - Element("border_id_0").clientWidth - 30;
366        var newWidthTD = (clientWidth/numBorders)-6;
367        newWidthTD = newWidthTD > 200 ? 200 : (newWidthTD < 50 ? 50 : newWidthTD);
368        children = Element('border_tr').childNodes;
369        for (var i=0; i<children.length; i++) {
370                if ((children[i].nodeName === 'TD') && (children[i].id!=='border_id_0') && (children[i].id!=='border_blank')){
371                        children[i].style.width = newWidthTD;
372                        set_border_caption(children[i].id, children[i].title, newWidthTD);
373                }
374        }
375        return newWidthTD;
376}
377
378
379
380
381function set_border_caption(border_id, title, border_width)
382{
383        var border = document.getElementById(border_id);
384        if (border_width == null)
385        {
386            border_width = border.clientWidth;
387        }
388        var caption = "";
389        Element("font_"+border.id).style.width = (border_width - 30)+'px';
390        Element("font_"+border.id).innerHTML = title;
391        return(title);
392}
393
394opened_alert = false;
395
396function draftTests(ID, msg_sent){
397        var cancel = new LertButton(get_lang('cancel'), function() {
398        Element("border_id_"+ID).onclick = function () { alternate_border(ID);};
399        $("#to_"+ID).focus();
400        opened_alert = false;
401    });
402       
403    var yes = new LertButton(get_lang('Save'), function() {
404        save_msg(ID, 'undefined', true);
405        openTab.toPreserve[ID] = false;
406        close_delete(ID, msg_sent);
407        delete(openTab.type[ID]);
408                //write_msg(get_lang('Your message was save as draft in folder %1.', lang_folder('Drafts')));
409               
410    });
411    var discard = new LertButton(get_lang('Discard'), function() {
412                        if (openTab.imapBox[ID] && !openTab.toPreserve[ID])
413            {
414                //delete_msgs(openTab.imapBox[ID], openTab.imapUid[ID].toString(), 0)
415                //delete(openTab.imapBox[ID]);
416                openTab.toPreserve[ID] = false;
417            }
418                        delete(openTab.type[ID]);
419            close_delete(ID, msg_sent);
420    });
421        if( $("#save_message_options_"+ID).attr("disabled") == "disabled") {
422                openTab.toPreserve[ID] = false;
423        close_delete(ID, msg_sent);
424        delete(openTab.type[ID]);
425        }else{
426                var titulo = '<b>' + get_lang('Warning') + '!</b>';
427                var message = get_lang("Your changes are not saved. What to do?");
428                var multConfirm = new Lert(
429                        titulo,
430                        message,
431                        [cancel,discard,yes],
432                        {
433                                        defaultButton:yes,
434                                        icon:'js/lert/images/dialog-help.gif'
435                        });
436                multConfirm.display();
437                opened_alert = true;
438        }
439}
440
441function editTest(ID){
442    var body = document.getElementById('body_'+ ID);
443    if (body)
444    {
445        var save_link = Element("save_message_options_"+ID);
446        if (openTab.toPreserve[ID] == undefined)
447                openTab.toPreserve[ID] = false;
448        if (((! openTab.toPreserve[ID] && ! ID.toString().match("_r")) || ((body.contentWindow) == 'object' && body.contentWindow.document.designMode.toLowerCase() == 'on')) && (save_link.onclick != ''))
449        {
450            return true;
451        }
452    }
453    return false;
454}
455
456function delete_border(ID, msg_sent)
457{
458   
459        var bolExecuteClose = true;
460        var borderElem = Element("border_id_" + ID);
461        if (borderElem){
462            borderElem.onclick = null; // It's avoid a FF3 bug
463        }else{
464            return false;
465        }
466        if (msg_sent == 'false')
467        {
468            if (editTest(ID)){
469                bolExecuteClose = false;
470                return(draftTests(ID, msg_sent));
471            }
472        }
473        if (bolExecuteClose)
474        {
475            close_delete(ID, msg_sent);
476                }
477                delete(openTab.type[ID]);
478        return true;
479}
480
481function close_delete(ID, msg_sent)
482{
483        openTab.toPreserve[ID] = false;
484        openTab.imapUid[ID] = 0;
485
486        // Limpa o autosave
487            if (preferences.auto_save_draft == 1 && autoSaveControl.timer[ID] !== null )
488            {
489                autoSaveControl.status[ID] = null;
490                clearInterval(autoSaveControl.timer[ID]);
491            }
492        ////////////////////////////////
493       
494        hold_session = false;
495        if (exist_className(Element('border_id_'+ID),'menu-sel'))
496        {
497                if (BordersArray[BordersArray.length-2].sequence == ID)
498                        this.alternate_border(0);
499                else
500                        this.alternate_border(BordersArray[BordersArray.length-2].sequence);
501        }
502
503        // Remove TD, title
504        border = Element('border_id_' + ID);
505        border.parentNode.removeChild(border);
506        var j=0;
507        var new_BordersArray = new Array();
508        for (i=0;i<BordersArray.length;i++)
509                if (document.getElementById(BordersArray[i].border_id) != null){
510                        new_BordersArray[j] = BordersArray[i];
511                        j++;
512                }
513        if(j == 1)
514                Element("footer_menu").style.display = '';
515        BordersArray = new_BordersArray;
516
517        // Remove Div Content
518        content = Element('content_id_' + ID);
519        content.parentNode.removeChild(content);
520        resizeWindow();
521        RichTextEditor.destroy( 'body_'+ID );
522       
523        //Caso for uma mensagem anexada tem que deletar ela da lixeira apos fechar a aba
524            var isPartMsg = false;
525            var id2 = ID.replace('_r','');
526            for(var ii = 0; ii < partMsgs.length; ii++)
527               if(partMsgs[ii] == id2){           
528                  isPartMsg = true;
529                  partMsgs[ii] = null;
530               }     
531
532            if(isPartMsg === true){
533                var handler_delete_msg = function(){};
534                cExecute ("$this.imap_functions.delete_msgs&folder=INBOX"+cyrus_delimiter+trashfolder+"&msgs_number="+id2,handler_delete_msg);
535            }
536        ///////////////////////////////////////////////////////////////////////////////////
537       
538        return true;
539}
540
541function getTabPrefix() { // define o prefixo para os checkboxes das mensagens
542        if (typeof(currentTab)!='number')
543                return currentTab+"_";
544        else
545                return "";
546}
547
548function getMessageIdFromRowId(row_id) { // extrai o id da mensagem do id da linha
549        var p = row_id.search("_s");
550        if (p>0)
551                return row_id.substr(0,p);
552        else
553                return row_id;
554}
555
556function getNumBoxFromTabId(tab_id) { // extrai o numBox do id da tab
557        if (typeof(tab_id)=='number') {
558                return tab_id;
559        }
560        else {
561                var p = tab_id.search(/[0-9]/);
562                return tab_id.substr(p);
563        }
564}
Note: See TracBrowser for help on using the repository browser.