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

Revision 5083, 11.7 KB checked in by airton, 13 years ago (diff)

Ticket #2086 - Troca do atual editor de emails do expresso

  • 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;
4
5function setBorderAttributes(ID)
6{
7        this.border_id = "border_id_"+ID;
8        this.sequence = ID;
9}
10
11
12function alternate_border(ID)
13{
14        if( document.getElementById("div_menu_c3") != null )
15        {
16                var node = document.getElementById("div_menu_c3").firstChild;
17               
18                while ( node )
19                {
20                        node.style.display = "none";
21                        node = node.nextSibling;
22                }
23               
24                if( document.getElementById("span_paging"+ID) != null )
25                        document.getElementById("span_paging"+ID).style.display = "block";
26        }
27       
28        if ( typeof win == 'object' && win.close && win.close.constructor == Function ){
29            var search_win = document.getElementById( 'window_QuickCatalogSearch' );
30            if(search_win){
31                search_win.style.visibility = 'hidden';
32            }
33            win.close( );
34        }
35               
36        if (! Element('border_id_'+ID))
37                return false; // Not possible to alternate
38        show_hide_span_paging(ID);
39        spanD = Element("span_D");
40        if (spanD)
41                spanD.style.display = (openTab.type[ID] == 0 ? '' : 'none');
42
43        var footer_menu = Element("footer_menu");       
44        if (footer_menu) {
45                footer_menu.style.display = (openTab.type[ID] != 4 ? '' : 'none');
46        }
47
48        var len = BordersArray.length;
49        for (var i=0; i < len; i++)
50        {
51                m = document.getElementById(BordersArray[i].border_id);
52                if ((m)&&(m.className == 'menu-sel'))
53                {
54                        m.className = 'menu';
55                        c = document.getElementById("content_id_"+BordersArray[i].sequence);
56                        c.style.display = 'none';
57                        if(Element("font_border_id_"+BordersArray[i].sequence))
58                                Element("font_border_id_"+BordersArray[i].sequence).className = 'font-menu';   
59
60                }
61        }
62
63        m = Element("border_id_"+ID);
64        if (m)
65                m.className = 'menu-sel';
66        if(Element("font_border_id_" + ID))
67                Element("font_border_id_" + ID).className = 'font-menu-sel';
68        var c = Element("content_id_"+ID)
69        if (c)
70                c.style.display = '';
71
72
73        // hide the DropDrowContact, if necessary
74        window_DropDownContacts = Element('tipDiv');
75        if ((window_DropDownContacts)&&(window_DropDownContacts.style.visibility != 'hidden')){
76                window_DropDownContacts.style.visibility = 'hidden';
77        }
78
79        if (typeof(ID)=='number') {
80                 numBox = ID;
81         }
82         else {
83             if (ID.match("search_"))
84             {
85                 if (ID.match("search_local_msg"))
86                 {
87                         var p = ID.search(/[0-9]/);
88                         numBox =  ID.substr(p);
89                 }
90                 else
91                 {
92                         numBox = ID.substr(7);
93                 }
94             }
95         }
96
97        currentTab=ID;
98       
99        if( document.getElementById('to_'+ID) && document.getElementById('to_'+ID).type == "textarea"){
100                document.getElementById('to_'+ID).focus();
101        }
102       
103        RichTextEditor.setEditable(ID);
104        return ID;
105}
106
107function create_border(borderTitle, id_value)
108{
109        borderTitle = ( ( borderTitle && borderTitle.constructor == String && borderTitle.length > 0 ) ? borderTitle : '&nbsp;' );
110
111        var resize = false;
112        resize = resize_borders();
113        if (!resize){
114            var str_continue = '';
115            var bolContinue = true;
116            if (preferences.auto_close_first_tab == 1){
117                str_continue = '\n' + get_lang('You must manualy close one of your tabs before opening a new one');
118                var children = Element('border_tr').childNodes;
119                var bolDelete = true;
120                for (var i=0; i<children.length; i++) {
121                    if ((children[i].nodeName === 'TD') && (children[i].id!=='border_id_0') && (children[i].id!=='border_blank'))
122                    {
123                        bolDelete = true;
124                        var num_child = children[i].id.toString().substr(10);
125                        alternate_border(num_child);
126                        if (editTest(num_child)){
127                            bolDelete = false;
128                        }
129                        if (bolDelete){
130                            bolContinue = false;
131                            delete_border(num_child, 'false');
132                            break;
133                        }
134                    }
135                }
136            }
137            if (bolContinue){
138                alert(get_lang('Reached maximum tab limit') + str_continue );
139                return 0;
140            }
141        }
142       
143        if (! id_value) // Is new message?
144                var ID = parseInt(BordersArray[(BordersArray.length-1)].sequence) + 1;
145        else
146        {
147                if (Element("border_id_"+id_value)) // It's opened already!
148                        return alternate_border(id_value);
149               
150                var ID = id_value;
151                openTab.imapBox[ID] = current_folder;
152        }
153        td = document.createElement("TD");
154        td.id="border_id_" + ID;
155        if(resize)
156        {
157                td.setAttribute("width", parseInt(resize)+"px");
158                td.style.width = parseInt(resize)+"px";
159        }
160        else
161                td.setAttribute("width", "200px");
162
163        td.setAttribute("align", "right");
164        td.onclick = function(){alternate_border(ID);resizeWindow()};
165        td.setAttribute("noWrap","true");
166    td.alt = borderTitle.replace( '&nbsp;', ' ' );
167    td.title = borderTitle;
168        borderTitle = borderTitle ?  borderTitle : id_value ? get_lang("No Subject") : "&nbsp;" ;
169        td.value = borderTitle;
170        if (borderTitle.length > 21)
171                borderTitle = borderTitle.substring(0,21) + "...";
172
173        if ( resize )
174                borderTitle = borderTitle.substring(0, resize*0.08);
175
176        td.innerHTML = "<div style='width:100%;border:0;padding:0;'>\n\
177                            <div id='font_border_id_" + ID+"' class='font-menu' style='width:*;'>" +
178                                borderTitle +
179                            "</div>\n\
180                            <div style='width:1px;float:left;clear:right;'>\n\
181                                <img onmousedown='javascript:return false' style='cursor:pointer' onclick=delete_border('" + ID + "','false') src='templates/"+template+"/images/close_button.gif'/>\n\
182                            </div>\n\
183                        </div>";
184
185        bb = document.getElementById("border_blank");
186        parent_bb = bb.parentNode; //Pego o tbody
187        parent_bb.insertBefore(td, bb);
188
189        if(! Element("border_id_"+id_value+"_r") ||((typeof(id_value) == 'string') && id_value.match(/_r$/)))
190                _dragArea.makeDragged(td, id_value,td.value);
191
192        BordersArray[BordersArray.length] = new setBorderAttributes(ID);
193
194        var div = document.createElement("DIV");
195        div.id = "content_id_" + ID;
196        div.className = "conteudo";
197        div.style.display='';
198
199        div.style.overflow = "hidden";
200
201        Element("exmail_main_body").insertBefore(div,Element("footer_menu"));
202        alternate_border(ID);
203        return ID;
204}
205
206function resize_borders()
207{
208        var numBorders = count_borders();
209
210        if (numBorders > 8)
211                return false;
212
213        return redim_borders(numBorders+1);
214}
215
216function count_borders()
217{
218        var numBorders = 0;
219        var children = Element('border_tr').childNodes;
220        for (var i=0; i<children.length; i++) {
221            if ((children[i].nodeName === 'TD') && (children[i].id!=='border_id_0') && (children[i].id!=='border_blank'))
222                numBorders++;
223        }
224
225        return numBorders;
226}
227
228function redim_borders(numBorders)
229{
230        var children = Element('border_tr').childNodes;
231        var clientWidth = (window.document.body.clientWidth - findPosX(Element("exmail_main_body"))) - Element("border_id_0").clientWidth - 30;
232        var newWidthTD = (clientWidth/numBorders)-6;
233        newWidthTD = newWidthTD > 200 ? 200 : (newWidthTD < 50 ? 50 : newWidthTD);
234        children = Element('border_tr').childNodes;
235        for (var i=0; i<children.length; i++) {
236                if ((children[i].nodeName === 'TD') && (children[i].id!=='border_id_0') && (children[i].id!=='border_blank')){
237                        children[i].style.width = newWidthTD;
238                        set_border_caption(children[i].id, children[i].title, newWidthTD);
239                }
240        }
241        return newWidthTD;
242}
243
244function set_border_caption(border_id, title, border_width)
245{
246        var border = document.getElementById(border_id);
247        if (border_width == null)
248        {
249            border_width = border.clientWidth;
250        }
251        var caption = "";
252        Element("font_"+border.id).style.width = (border_width - 25)+'px';
253        Element("font_"+border.id).innerHTML = title;
254        return(title);
255}
256
257function draftTests(ID, msg_sent){
258    var cancel = new LertButton(get_lang('cancel'), function() {
259        Element("border_id_"+ID).onclick = function () {alternate_border(ID);};
260    });
261    var yes = new LertButton(get_lang('Save'), function() {
262        save_msg(ID);
263        openTab.toPreserve[ID] = false;
264        close_delete(ID, msg_sent);
265        delete(openTab.type[ID]);
266                write_msg(get_lang('Your message was save as draft in folder %1.', lang_folder('Drafts')));
267    });
268    var discard = new LertButton(get_lang('Discard'), function() {
269            if (openTab.imapBox[ID] && !openTab.toPreserve[ID])
270            {
271                //delete_msgs(openTab.imapBox[ID], openTab.imapUid[ID].toString(), 0)
272                //delete(openTab.imapBox[ID]);
273                openTab.toPreserve[ID] = false;
274            }
275                        delete(openTab.type[ID]);
276            close_delete(ID, msg_sent);
277    });
278    var titulo = '<b>' + get_lang('Warning') + '!</b>';
279    var message = get_lang("Your changes are not saved. What to do?");
280    var multConfirm = new Lert(
281            titulo,
282            message,
283            [cancel,discard,yes],
284            {
285                    defaultButton:yes,
286                    icon:'js/lert/images/dialog-help.gif'
287            });
288    multConfirm.display();
289}
290
291function editTest(ID){
292    var body = document.getElementById('body_'+ ID);
293    if (body)
294    {
295        var save_link = Element("save_message_options_"+ID);
296        if (openTab.toPreserve[ID] == undefined)
297                openTab.toPreserve[ID] = false;
298        if (((! openTab.toPreserve[ID] && ! ID.toString().match("_r")) || ((body.contentWindow) == 'object' && body.contentWindow.document.designMode.toLowerCase() == 'on')) && (save_link.onclick != ''))
299        {
300            return true;
301        }
302    }
303    return false;
304}
305
306function delete_border(ID, msg_sent)
307{
308        var bolExecuteClose = true;
309        var borderElem = Element("border_id_" + ID)
310        if (borderElem){
311            borderElem.onclick = null; // It's avoid a FF3 bug
312        }else{
313            return false;
314        }
315        if (msg_sent == 'false')
316        {
317            if (editTest(ID)){
318                bolExecuteClose = false;
319                return(draftTests(ID, msg_sent));
320            }
321        }
322        if (bolExecuteClose)
323        {
324            close_delete(ID, msg_sent);
325                }
326                delete(openTab.type[ID]);
327        return true;
328}
329
330function close_delete(ID, msg_sent)
331{
332        openTab.toPreserve[ID] = false;
333        openTab.imapUid[ID] = 0;
334
335        if (preferences.auto_save_draft == 1)
336        {
337                if (openTab.autosave_timer[ID])
338                        clearTimeout(openTab.autosave_timer[ID]);
339                openTab.autosave_timer[ID] = false;
340        }
341
342        hold_session = false;
343        if (exist_className(Element('border_id_'+ID),'menu-sel'))
344        {
345                if (BordersArray[BordersArray.length-2].sequence == ID)
346                        this.alternate_border(0);
347                else
348                        this.alternate_border(BordersArray[BordersArray.length-2].sequence);
349        }
350
351        // Remove TD, title
352        border = Element('border_id_' + ID);
353        border.parentNode.removeChild(border);
354        var j=0;
355        var new_BordersArray = new Array();
356        for (i=0;i<BordersArray.length;i++)
357                if (document.getElementById(BordersArray[i].border_id) != null){
358                        new_BordersArray[j] = BordersArray[i];
359                        j++;
360                }
361        if(j == 1)
362                Element("footer_menu").style.display = '';
363        BordersArray = new_BordersArray;
364
365        // Remove Div Content
366        content = Element('content_id_' + ID);
367        content.parentNode.removeChild(content);
368        resizeWindow();
369        RichTextEditor.destroy( 'body_'+ID );
370        return true;
371}
372
373function getMessageIdFromRowId(row_id) { // extrai o id da mensagem do id da linha
374        var p = row_id.search("_s");
375        if (p>0)
376                return row_id.substr(0,p);
377        else
378                return row_id;
379}
380
381function getNumBoxFromTabId(tab_id) { // extrai o numBox do id da tab
382        if (typeof(tab_id)=='number') {
383                return tab_id;
384        }
385        else {
386                var p = tab_id.search(/[0-9]/);
387                return tab_id.substr(p);
388        }
389}
390
391function getTabSufix() {
392        if (typeof(currentTab)=='number')
393                return '';
394        else
395                return '_s' + numBox.toString();
396}
Note: See TracBrowser for help on using the repository browser.