source: branches/2.2/expressoMail1_2/js/abas.js @ 3606

Revision 3606, 8.5 KB checked in by rafaelraymundo, 13 years ago (diff)

Ticket #1342 - Alterada a funcao alternate_border para recolocar o foco na transicao entre abas

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