source: branches/2.0/expressoMail1_2/js/abas.js @ 2606

Revision 2606, 7.5 KB checked in by niltonneto, 14 years ago (diff)

Ticket #1040 - Corrige problemas ao redimensionar largura das divs principais.

  • Property svn:eol-style set to native
  • Property svn:executable set to *
RevLine 
[2]1var BordersArray = new Array();
2BordersArray[0] = new setBorderAttributes(0);
3
4function setBorderAttributes(ID)
5{
6        this.border_id = "border_id_"+ID;
7        this.sequence = ID;
8}
9
10
11function alternate_border(ID)
12{
[320]13        if (! Element('border_id_'+ID))
14                return false; // Not possible to alternate
[412]15        show_hide_span_paging(ID);
[790]16        spanD = Element("span_D");
17        if (spanD)
18                spanD.style.display = (openTab.type[ID] == 0 ? '' : 'none');
[1702]19
20        var footer_menu = Element("footer_menu");       
21        if (footer_menu) {
22                //console.log(openTab.type[ID]);
23                footer_menu.style.display = (openTab.type[ID] != 4 ? '' : 'none');
24        }
25
[2]26        var len = BordersArray.length;
27        for (var i=0; i < len; i++)
28        {
29                m = document.getElementById(BordersArray[i].border_id);
[320]30                if ((m)&&(m.className == 'menu-sel'))
[2]31                {
32                        m.className = 'menu';
33                        c = document.getElementById("content_id_"+BordersArray[i].sequence);
34                        c.style.display = 'none';
35                        if(Element("font_border_id_"+BordersArray[i].sequence))
36                                Element("font_border_id_"+BordersArray[i].sequence).className = 'font-menu';   
37                        var body = Element('body_'+BordersArray[i].sequence);
38                        if (body)
39                        {
40                                try
41                                {
42                                        if (Element('viewsource_rt_checkbox').checked)
43                                        { 
44                                                connector.loadScript("rich_text_editor");
45                                                RichTextEditor.viewsource(false);
46                                        }
47                                }
48                                catch(e)
49                                {
50                                        //alert(e.message)
51                                }
52                        }
53                }
54        }
55
56        m = Element("border_id_"+ID);
[320]57        if (m)
58                m.className = 'menu-sel';
[2]59        if(Element("font_border_id_" + ID))
60                Element("font_border_id_" + ID).className = 'font-menu-sel';
61        var c = Element("content_id_"+ID)
[320]62        if (c)
63                c.style.display = '';
[2]64
65        body = document.getElementById('body_'+ ID);
66        if (body){
67                try{
68                        if(ID){
69                                connector.loadScript("rich_text_editor");
70                                RichTextEditor.loadEditor(ID);
71                        }
72                        body.contentWindow.document.designMode="on";
73                }
74                catch(e){
75                        //alert(e.message);
76                }
77        }
78
79        // hide the DropDrowContact, if necessary
80        window_DropDownContacts = Element('tipDiv');
81        if ((window_DropDownContacts)&&(window_DropDownContacts.style.visibility != 'hidden')){
82                window_DropDownContacts.style.visibility = 'hidden';
83        }
[320]84
85        if (typeof(ID) == 'number')
86        {
[606]87                current_folder = openTab.imapBox[ID];
[1702]88                //openTab.type[ID] = 0;
[320]89                numBox=ID;
90        }
[790]91        else
92                if (ID.match("search_"))
93                        numBox=ID.substr(7);
[606]94        currentTab=ID;
[2]95        return ID;
96}
97
98function create_border(borderTitle, id_value)
99{
[790]100        var resize = false;
[2]101        var offWidth = Element('border_blank').offsetWidth ? Element('border_blank').offsetWidth : Element('border_blank').clientWidth;
102        if (offWidth < 200) {
103                resize = resize_borders();
104                if (!resize){
[197]105                        alert(get_lang('Reached maximum tab limit'));
[2]106                        return false;
107                }
108        }
109       
[271]110        if (! id_value) // Is new message?
111                var ID = parseInt(BordersArray[(BordersArray.length-1)].sequence) + 1;
[790]112        else
113        {
114                if (Element("border_id_"+id_value)) // It's opened already!
115                        return alternate_border(id_value);
[271]116                var ID = id_value;
[2202]117                openTab.imapBox[ID] = current_folder;
[271]118        }
[2]119        td = document.createElement("TD");
120        td.id="border_id_" + ID;
121        if(resize) {
122                td.setAttribute("width", parseInt(resize)+"px");
123                td.style.width = parseInt(resize)+"px";
124        }
125        else
126                td.setAttribute("width", "200px");
[790]127
[2]128        td.setAttribute("align", "right");
[2605]129        td.onclick = function(){alternate_border(ID);resizeWindow()};
[2]130        td.setAttribute("noWrap","true");
[1247]131        td.alt = borderTitle;
132        td.title = borderTitle;
[2]133        borderTitle = borderTitle ?  borderTitle : id_value ? get_lang("No Subject") : "&nbsp;" ;
134        td.value = borderTitle;
[790]135        if (borderTitle.length > 21)
[2]136                borderTitle = borderTitle.substring(0,21) + "...";
[790]137
[2]138        if (resize)
139                borderTitle = borderTitle.substring(0, resize*0.08);
140
[790]141        td.innerHTML = "<table width=100% border=0 cellspacing=0 cellpadding=0><tr><td id=font_border_id_" + ID+" class='font-menu' width=*>" + borderTitle + "</td><td width=1px><img onmousedown='javascript:return false' style='cursor:pointer' onclick=delete_border('" + ID + "','false') src='templates/"+template+"/images/close_button.gif'></td></tr></table>";
142
[2]143        bb = document.getElementById("border_blank");
144        parent_bb = bb.parentNode; //Pego o tbody
145        parent_bb.insertBefore(td, bb);
[790]146
147        if(! Element("border_id_"+id_value+"_r") ||((typeof(id_value) == 'string') && id_value.match(/_r$/)))
[2]148                _dragArea.makeDragged(td, id_value,td.value);
149
150        BordersArray[BordersArray.length] = new setBorderAttributes(ID);
[790]151
[2]152        var div = document.createElement("DIV");
153        div.id = "content_id_" + ID;
154        div.className = "conteudo";
155        div.style.display='';
156
[320]157        div.style.overflow = "hidden";
[790]158        Element("exmail_main_body").insertBefore(div,Element("footer_menu"));
[2]159        alternate_border(ID);
160        return ID;
161}
162
163function resize_borders()
164{
165        var children;
166        var     numBorders = 0;
167        var widthTD = 0;
168        var newWidthTD = 0;             
169        children = Element('border_tr').childNodes;     
170        for (var i=0; i<children.length; i++) {
171                if ((children[i].nodeName === 'TD') && (children[i].id!=='border_id_0') && (children[i].id!=='border_blank')) {
172                        numBorders++;
173                        if(!widthTD)
174                                widthTD = children[i].clientWidth;                             
175                }
176        }
177        if (numBorders > 8)
178                return false;
179       
180        newWidthTD = ((numBorders*widthTD)+(Element("border_blank").clientWidth-20))/(numBorders+1);
181        for (var i=0; i<children.length; i++) {
182                if ((children[i].nodeName === 'TD') && (children[i].id!=='border_id_0') && (children[i].id!=='border_blank')){
183                        children[i].style.width = newWidthTD;
184                        Element("font_"+children[i].id).innerHTML = Element("font_"+children[i].id).innerHTML.substring(0, newWidthTD*0.08);
185                }
186        }
187        return newWidthTD;
188}
189
190function delete_border(ID, msg_sent)
191{
[648]192        var borderElem = Element("border_id_" + ID)
193        if (borderElem)
194                borderElem.onclick = null; // It's avoid a FF3 bug
195        else
[125]196                return false;
[320]197
[2]198        if (msg_sent == 'false')
199        {
200                var body = document.getElementById('body_'+ ID);
201                if (body)
202                {
[606]203                                var save_link = Element("save_message_options_"+ID);
204                                if (openTab.toPreserve[ID] == undefined)
205                                        openTab.toPreserve[ID] = false;
[648]206                                if ((! openTab.toPreserve[ID] && ! ID.toString().match("_r")) || ((body.contentWindow) == 'object' && body.contentWindow.document.designMode.toLowerCase() == 'on') && (save_link.onclick != ''))
[2]207                                {
208                                        var discard_msg = confirm(get_lang("Your message has not been sent. Discard your message?"), "");
209                                        if (!discard_msg)
[245]210                                        {
[606]211                                                Element("border_id_"+ID).onclick = function () { alternate_border(ID);};
[2]212                                                return;
[245]213                                        }
214                                        else
215                                        {
[2202]216                                                if (openTab.imapBox[ID] && openTab.imapUid[ID] && !openTab.toPreserve[ID]){
[606]217                                                        delete_msgs(openTab.imapBox[ID], openTab.imapUid[ID].toString(), 0)
218                                                        openTab.toPreserve[ID] = false;
[2202]219                                                }
220                                                delete(openTab.imapBox[ID]);
221                                                // Element('to_'+ID).focus(); It crash on IE
[245]222                                        }
[2]223                                }
224                }
225        }
226
[606]227        openTab.toPreserve[ID] = false;
228        openTab.imapUid[ID] = 0;
[271]229
[801]230        if (preferences.auto_save_draft == 1)
231        {
232                if (openTab.autosave_timer[ID])
233                        clearTimeout(openTab.autosave_timer[ID]);
234                openTab.autosave_timer[ID] = false;
235        }
236
[2]237        hold_session = false;
[790]238        if (exist_className(Element('border_id_'+ID),'menu-sel'))
[2]239        {
[790]240                if (BordersArray[BordersArray.length-2].sequence == ID)
[2]241                        this.alternate_border(0);
242                else
[790]243                        this.alternate_border(BordersArray[BordersArray.length-2].sequence);
[2]244        }
245
246        // Remove TD, title
[320]247        border = Element('border_id_' + ID);
[2]248        border.parentNode.removeChild(border);
[790]249        var j=0;
[2]250        var new_BordersArray = new Array();
251        for (i=0;i<BordersArray.length;i++)
[790]252                if (document.getElementById(BordersArray[i].border_id) != null){
[2]253                        new_BordersArray[j] = BordersArray[i];
[790]254                        j++;
[2]255                }
[58]256        if(j == 1)
257                Element("footer_menu").style.display = '';
[2]258        BordersArray = new_BordersArray;
[790]259
260        // Remove Div Content
261        content = Element('content_id_' + ID);
262        content.parentNode.removeChild(content);
[2605]263        resizeWindow();
[320]264        return true;
265}
Note: See TracBrowser for help on using the repository browser.