source: trunk/expressoMail1_2/js/search.js @ 128

Revision 128, 16.7 KB checked in by niltonneto, 16 years ago (diff)

Nova funcionalidade: Teclas de Atalho
Correção de frases lang

  • Property svn:eol-style set to native
  • Property svn:executable set to *
Line 
1/**************************************************************************\
2 Início
3\**************************************************************************/
4        function searchE(){
5                this.searchW   = new Array;
6                this.name_box_search = "";
7                this.all_boxes = new Array;
8                this.type = "";
9                this.fields = new Array("_ass","_de","_body","_para","_cc","_cco");
10        }
11        var search_tabs = 0; // Count the number of seach tabs
12       
13        //Monta os forms dentro da janela;
14        searchE.prototype.showForms = function(value){
15                // Principal
16                if(!Element("window_search")) {
17                        var form_search = document.createElement("DIV");
18                        form_search.style.visibility = 'hidden';
19                        form_search.style.top = '0px';
20                        form_search.style.left = '0px';
21                        form_search.id = "window_search";
22                        document.body.appendChild(form_search);                 
23                }
24               
25                // Pesquisa
26                if(!Element("div_form_search")){
27                        var div_form_search = document.createElement("DIV");
28                        div_form_search.id = "div_form_search";
29                        div_form_search.style.position = "absolute";
30                        div_form_search.style.left = "10px";
31                        div_form_search.style.top  = "10px";
32                        div_form_search.style.width = "635px";
33                        div_form_search.style.height = "200px";
34                        div_form_search.style.borderStyle = "outset";
35                        div_form_search.style.borderColor = "black";
36                        div_form_search.style.borderWidth = "1px";
37                        div_form_search.style.overflow = "hidden";
38                        div_form_search.innerHTML = "";
39                        var call_form_search = EsearchE.mount_form();
40                        div_form_search.appendChild(call_form_search);
41                        form_search.appendChild(div_form_search);       
42
43                }       
44               
45                if(!Element("div_button_search")){
46                        var div_button_search    = document.createElement("DIV");
47                                div_button_search.id = "div_button_search";
48                                div_button_search.style.position = "absolute";
49                                div_button_search.style.left = "10px";
50                                div_button_search.style.top = "223px";
51                                div_button_search.style.width = "600px";
52                                div_button_search.style.height = "25px";
53                                div_button_search.innerHTML = "<table border='0' width='50%' cellpadding='0' cellspacing='0' align='right'>"+
54                                                                                          "<tr>"+
55                                                                                          "<td><input type='button' value=" + get_lang('Search') + " onclick='EsearchE.func_search()'></td>"+
56                                                                                          "<td><input type='button' value=" + get_lang('Clean') + " onclick='EsearchE.func_clean()'></td>"+
57                                                                                          "<td><input type='button' value=" + get_lang('Close') + " onclick='EsearchE.func_close(\"hidden\")'></td>"+
58                                                                                          "</tr>"+
59                                                                                          "</table>";
60                                form_search.appendChild(div_button_search);
61                }
62               
63                if(!Element("table_layer")){
64                        var table_layer    = "";
65                }
66               
67                if(value == "")
68                        EsearchE.showWindow(Element("window_search"));
69       
70                // Cria as caixas postais;
71                EsearchE.mount_folders();
72
73                if(value){
74                        Element("check_all_msg").checked = true;
75                        EsearchE.all_mailboxes();
76                        EsearchE.func_search(value);
77                }
78
79        }
80       
81        //Form
82        searchE.prototype.mount_form = function(value){
83                var form_sch = document.createElement("FORM");
84                form_sch.id  = "form_sch";
85                form_sch.innerHTML = "<table id='table_princ' border='0' cellpading='0' cellspacing='0' align='center'>"+
86                                                     "<tr>"+
87                                                     "<td colspan='2'><b>" + get_lang('Inform your search in the text fields') + " :</b></td>"+
88                                                     "<td rowspan='7'>&nbsp"+
89                                                     "</td>"+
90                                                     "<td rowspan='8'>"+
91                                                     "<table border='0' cellpading='0' cellspacing='0'>"+
92                                                     "<tr>"+
93                                                     "<td colspan='3' valign='top'>&nbsp;<b>" + get_lang('Search the messages in these folders') + " :</b></td>"+
94                                                     "</tr>"+
95                                                     "<tr>"+
96                                                     "<td valign='top'><div id='folders' style='width:160px; height:150px'></div></td>"+
97                                                     "<td>"+
98                                                     "<input type='button' id='incluir' name='incluir' value='>>' onclick='EsearchE.add_mailboxes()'><br>"+
99                                                     "<input type='button' id='excluir' name='excluir' value='<<' onclick='EsearchE.del_mailboxes()'></td>"+
100                                                     "</td>"+
101                                                     "<td><select multiple id='sel_search_nm_box1' name='sel_search_nm_box1' size='10' style='width:160px'></select></td>"+
102                                                     "</tr>"+
103                                                     "<tr>"+
104                                                     "<td valign='top'><input type='checkBox' id='check_all_msg' name='check_all_msg' onclick='EsearchE.all_mailboxes()'><b>" + get_lang('In all the folders') + "</b></td>"+
105                                                     "</tr>"+
106                                                     "</table>"+
107                                                     "</td>"+
108                                                     "</tr>"+
109                                                     "<tr>"+
110                                                     "<td align='right'>" + get_lang('From') + " .: </td>"+
111                                                     "<td><input type='text' id='txt_de' size='20'></td>"+
112                                                     "</tr>"+
113                                                     "<tr>"+
114                                                     "<td align='right'>" + get_lang('To') + ".: </td>"+
115                                                     "<td><input type='text' id='txt_para' size='20'></td>"+
116                                                     "</tr>"+                                               
117                                                     "<tr>"+
118                                                     "<td align='right'>" + get_lang('Cc') + " .: </td>"+
119                                                     "<td><input type='text' id='txt_cc' size='20'></td>"+
120                                                     "</tr>"+
121                                                     "<tr>"+
122                                                     "<td align='right'>" + get_lang('Subject') + " .: </td>"+
123                                                     "<td><input type='text' id='txt_ass' size='20'></td>"+
124                                                     "</tr>"+
125                                                     "<tr>"+
126                                                         "<td align='right'>" + get_lang('Message body') + " .:</td>"+
127                                                     "<td><input type='text' id='txt_body' size='20'></td>"+
128                                                     "</tr>"+
129                                                     "</table>";
130                return form_sch;
131        }
132
133        // Pastas;
134        searchE.prototype.mount_folders = function(){
135                connector.loadScript("TreeS");
136
137                if( Element("div_folders_search") == null){
138                        var div_folders = document.createElement("DIV");
139                                div_folders.id = "div_folders_search";
140                                div_folders.style.width = "155px";
141                                div_folders.style.height = "152px";
142                                div_folders.style.borderStyle = "outset";
143                                div_folders.style.borderColor = "black";
144                                div_folders.style.borderWidth = "1px";
145                                div_folders.style.background  = "#F7F7F7";
146                                div_folders.style.overflow = "auto";
147                                div_folders.innerHTML = "";
148                                var dest_div = Element("folders");
149                                dest_div.appendChild(div_folders);
150                }               
151                ttree.make_tree(folders,"div_folders_search","_folders_tree_search","","","","");
152        }
153       
154        // Monta Resultado no Box
155        searchE.prototype.mount_result_box = function(data){
156                draw_box(new Array(), "_search");
157                draw_paging(0);
158//              alternate_border(0);
159
160        }
161        // Form resultado;
162        searchE.prototype.mount_result = function(data){
163                //This func returns the most recent date
164                function date_comp(a,b)
165                {
166                        var data1 = a.match(/\d{2}\/\d{2}\/\d{4}--\d+? \w*b--\d*$/g);
167                        data1 = data1[0].substr(0, data1[0].indexOf('--'))
168                        with ( data1 )
169                                data1 = Date.UTC(substr(6), substr(3, 2), substr(0, 2));
170                        var data2 = b.match(/\d{2}\/\d{2}\/\d{4}--\d+? \w*b--\d*$/g);
171                        data2 = data2[0].substr(0, data2[0].indexOf('--'))
172                        with ( data2 )
173                                data2 = Date.UTC(substr(6), substr(3, 2), substr(0, 2));
174                        return data2 - data1;
175                }
176
177                var nw_array = new Array;
178                data = data.substr(2, data.length - 4);
179                var var_tmp  = data.split("####");
180                var cont = parseInt(0);
181                var_tmp.sort(date_comp);
182                for(var i=0; i < var_tmp.length; i++){
183                        if(var_tmp[i] != ""){
184                                nw_array[cont] = var_tmp[i];
185                                cont++;
186                        }
187                }
188                var table = document.createElement("TABLE");
189                        table.id    = "table_result";
190                        table.width = "100%";
191
192/*              if(is_ie){
193                        table.cellPadding  = '0';
194                        table.cellSpacing = '0';
195                        table.setAttribute("border","1");
196                }else{
197                        table.setAttribute( "cellspacing", "0");
198                        table.setAttribute( "cellpadding", "0");
199                        table.setAttribute( "border", "1");
200                }*/
201                var tbody = document.createElement("TBODY");
202                if(nw_array.length > 0){
203                        write_msg(nw_array.length + get_lang(' search results'));                       
204                }
205
206                for( var i=0; i < nw_array.length; i++){
207                        var tr = document.createElement("TR");
208                //var color = "#F0F0F0";
209                        //tr.style.background  =  color;
210                        tr.className = 'tr_msg_read';
211
212                        if (nw_array[i].match(/.*--.*--\w*--\d{2}\/\d{2}\/\d{4}--\d+? \w*b--\d*$/g) == null) //subject with "--"
213                        {
214                                var aux1 = nw_array[i].match(/\d{2}\/\d{2}\/\d{4}--\d+? \w*b--\d*$/g);
215                                aux1 = aux1[0].split("--");
216                                nw_array[i] = nw_array[i].substr(0, nw_array[i].indexOf(aux1[0])-2);
217                                var aux = [];
218                                aux[0] = nw_array[i].substr(0, nw_array[i].indexOf('--'));
219                                nw_array[i] = nw_array[i].substr(nw_array[i].indexOf('--')+2);
220                                aux[1] = nw_array[i].substr(0, nw_array[i].indexOf('--'));
221                                aux[2] = nw_array[i].substr(nw_array[i].indexOf('--')+2);
222                                aux = aux.concat(aux1);
223                        }
224                        else
225                        {
226                        var aux = nw_array[i].split("--");
227                        }
228                       
229                        for(var j=0 ; j < aux.length ; j++){
230                                        var mailbox = aux[0];
231                                        var uid_msg = aux[5];
232                                        var td = document.createElement("TD");                                 
233                                       
234                                if( j <= 4){
235                                        if( j == 0){
236                                                td.style.width = "20%";                                 
237                                                var nm_box = aux[0].split(cyrus_delimiter);
238                                                var td1 = nm_box.pop();
239                                                td.setAttribute("NoWrap","true");
240                                                td.style.overflow = "hidden";
241                                                if(td1 == "INBOX"){
242                                                        var td1  = get_lang("Inbox");
243                                                }
244                                        }
245                                        if( j == 1){
246                                                var subject_encode = url_encode(aux[2]);
247                                                td.width = "20%";                                       
248                                                var td1  =  '<div style="width:100%;overflow:hidden">'+aux[1]+"</div>";
249                                        }
250                                        if( j == 2){
251                                                var subject_encode = url_encode(aux[2]);
252                                                td.width = "40%";                                       
253                                                var td1  = '<div style="width:100%;overflow:hidden"><a href=javascript:void(0) onclick=EsearchE.open_msg(\"' + url_encode(mailbox) + '\",\"' + uid_msg + '\",\"' + subject_encode + '\")>' + aux[2] +'</a></div>';
254
255                                        }
256                                        if( j == 3){
257                                                td.width = "10%";                                       
258                                                td.align = "center";
259                                                var td1  = aux[3];
260                                        }
261                                        if( j == 4){
262                                                td.width = "10%";
263                                                td.align = "center";
264                                                var td1  = aux[4];
265                                        }
266
267                                        td.innerHTML = td1;
268                                        tr.appendChild(td);
269                                }
270                        }
271                        aux.splice(0,(aux.length));
272                        tbody.appendChild(tr);
273                }
274                table.appendChild(tbody);
275               
276                search_tabs += 1;
277                var border_id = create_border(get_lang("Search Results"), "search_" + search_tabs);
278                var content = document.getElementById('content_id_' + "search_" + search_tabs);
279                if(is_ie)
280                        Element("border_table").width = "99.5%";
281               
282                /* Put header */
283                var table_element = document.createElement("TABLE");
284                var tbody_element = document.createElement("TBODY");
285                table_element.border = 1;
286                table_element.setAttribute("id", "table_message_header_box");
287                table_element.className = "table_message_header_box";
288                tr_element = document.createElement("TR");
289                tr_element.className = "message_header";
290                td_element1 = document.createElement("TD");
291                td_element1.setAttribute("width", "20%");
292                td_element1.align = "left";
293                td_element1.innerHTML = get_lang("Folder");
294                td_element2 = document.createElement("TD");
295                td_element2.setAttribute("width", "20%");
296                td_element2.align = "left";
297                td_element2.innerHTML = get_lang("Who");
298                td_element3 = document.createElement("TD");
299                td_element3.setAttribute("width", "40%");
300                td_element3.align = "left";
301                td_element3.innerHTML = get_lang("Subject");
302                td_element4 = document.createElement("TD");
303                td_element4.setAttribute("width", "10%");
304                td_element4.align = "center";
305                td_element4.innerHTML = get_lang("Date");
306                td_element5 = document.createElement("TD");
307                td_element5.setAttribute("width", "10%");
308                td_element5.align = "center";
309                td_element5.innerHTML = get_lang("Size");
310       
311                tr_element.appendChild(td_element1);
312                tr_element.appendChild(td_element2);
313                tr_element.appendChild(td_element3);
314                tr_element.appendChild(td_element4);
315                tr_element.appendChild(td_element5);
316                tbody_element.appendChild(tr_element);
317                table_element.appendChild(tbody_element);
318                content.appendChild(table_element);
319                /*end of "put header"*/
320               
321                content.appendChild(table);
322        }
323
324        searchE.prototype.open_msg = function(mailbox, uid_msg, subject){
325                var handler_get_msg = function(data){
326                        if(Element("border_id_" + uid_msg + "_r")){alert(get_lang("This message is already opened!"));}
327                        else{draw_message(data,create_border(url_decode(subject), uid_msg + "_r"));}
328                }
329                var args   = "$this.imap_functions.get_info_msg";
330                var params = "msg_number=" + uid_msg + "&msg_folder=" + mailbox;
331                cExecute(args,handler_get_msg,params);
332
333        }
334
335        // Adiciona caixas postais na busca;
336        searchE.prototype.add_mailboxes = function(){
337                var sel = Element("sel_search_nm_box1");
338                var name_box     = this.name_box_search.split(cyrus_delimiter);
339                if(this.name_box_search == "")
340                        return false;
341                var name_box_def = "";
342                if(name_box.length != 1){
343                        name_box_def = name_box[(name_box.length-1)];
344                }else{
345                        name_box_def = get_lang("Inbox");               
346                }
347                if( sel.length > 0){
348                        for(var i=0; i < sel.options.length; i++){
349                                if(sel.options[i].value == this.name_box_search){
350                                        alert(get_lang('This message is already selected!'));
351                                        return false;
352                                }
353                        }
354                }
355                var opt = new Option(lang_folder(name_box_def),this.name_box_search,false,true);
356                sel[sel.length] = opt;
357        }
358        // Remove as caixas postais na busca;
359        searchE.prototype.del_mailboxes = function(){
360                var sel = Element("sel_search_nm_box1");
361                if(sel.length > 0){
362                        for(var i=0; i < sel.options.length; i++){
363                                if(sel.options[i].selected == true){
364                                        sel.options[i] = null;
365                                        i--;
366                                }
367                        }
368                }
369       
370        }
371        // todas as caixas
372        searchE.prototype.all_mailboxes = function(){
373                var value = Element("check_all_msg").checked;
374                var cont = parseInt(0);
375                if(value){
376                        if(EsearchE.all_boxes.length > 0){
377                                EsearchE.all_boxes.splice(0,(EsearchE.all_boxes.length));                       
378                        }
379                        for(var i=0; i < folders.length; i++){
380                                EsearchE.all_boxes[cont] = folders[i].folder_id;
381                                cont++;
382                        }
383                }else{
384                        EsearchE.all_boxes.splice(0,(EsearchE.all_boxes.length));
385                }
386        }
387
388        // Search;
389        searchE.prototype.func_search = function(value){
390                var fields = "##";
391                        // Verifica se os campos estão preenchidos;
392                        if(trim(Element("txt_ass").value) != ""){
393                                fields += "SUBJECT " +  "<=>" +url_encode(Element("txt_ass").value) + " ";
394                        }
395                        if(trim(Element("txt_body").value) != ""){
396                                fields += "BODY " + "<=>" + url_encode(Element("txt_body").value) + " ";
397                        }
398                        if(trim(Element("txt_de").value) != ""){
399                                fields += "FROM " + "<=>" + url_encode(Element("txt_de").value) + " ";
400                        }
401                        if(trim(Element("txt_para").value) != ""){
402                                fields += "TO " + "<=>" + url_encode(Element("txt_para").value) + " ";
403                        }
404                        if(trim(Element("txt_cc").value) != ""){
405                                fields += "CC " + "<=>" + url_encode(Element("txt_cc").value) + " ";
406                        }
407                        if(value) {
408                                fields = "##ALL " +  "<=>" +url_encode(value) + " ";
409                        }
410
411                fields += "##";
412                if(fields == "####"){
413                        alert(get_lang("Define some search parameters!"));
414                        return false;
415                }
416               
417                if(Element("check_all_msg").checked){
418                        var nm_box = new Array;
419                        for(var i=0; i < EsearchE.all_boxes.length; i++){
420                                nm_box[i] = EsearchE.all_boxes[i] + fields;
421                        }
422                }else{
423                        var nm_box = new Array;
424                        var sel_combo = Element("sel_search_nm_box1");
425                        if( sel_combo.options.length <= 0){
426                                alert(get_lang("Define the boxes to search!"));
427                                return false;
428                        }
429                       
430                        for(var i=0; i < sel_combo.options.length; i++){
431                                sel_combo.options[i].selected = true;
432                        }
433                        for(var i=0; i < sel_combo.options.length; i++){
434                                if(sel_combo.options[i].selected == true){
435                                        nm_box[nm_box.length] = sel_combo.options[i].value + fields;
436                                }
437                        }
438                }
439                var handler = function(data){
440                        if(data == "none"){alert(get_lang("None result was found."));}
441                        else if(data == "many results"){alert(get_lang("More than %1 results. Please, try to refine your search.",50));}
442                        else{EsearchE.mount_result(data);}
443                }
444                var args   = "$this.imap_functions.search_msg";
445                var params = "condition=" + nm_box;
446                cExecute(args,handler,params);
447        }
448        // clean;
449        searchE.prototype.func_clean = function(){
450                // Limpa os campos;
451                for(var i=0; i < this.fields.length; i++){
452                        if(Element("txt" + this.fields[i]) != null){Element("txt" + this.fields[i]).value = "";}
453                }                       
454            if(Element("check_all_msg") != null){Element("check_all_msg").checked = false;}
455
456            EsearchE.all_boxes.splice(0,(EsearchE.all_boxes.length));
457                EsearchE.del_mailboxes();
458        }
459
460        // close
461        searchE.prototype.func_close = function(type){
462                var _this = this;
463                _this.name_box_search = "";
464                EsearchE.all_boxes.splice(0,(EsearchE.all_boxes.length));
465                _this.type = type;
466                _this.searchW['window_search'].close();
467        }
468        // Monta a janela em tela;
469        searchE.prototype.showWindow = function(div){
470                if(!this.searchW[div.id]) {
471                        div.style.width = "660px";
472                        div.style.height = "255px";
473                        div.style.visibility = "hidden";
474                        div.style.position = "absolute";
475                        div.style.zIndex = "10003";                     
476                        var title = ":: "+ get_lang("Search")+" ::";
477                        var wHeight = div.offsetHeight + "px";
478                        var wWidth =  div.offsetWidth   + "px";
479                       
480                        win = new dJSWin({                     
481                                id: 'ccList'+div.id,
482                                content_id: div.id,
483                                width: wWidth,
484                                height: wHeight,
485                                title_color: '#3978d6',
486                                bg_color: '#eee',
487                                title: title,                                           
488                                title_text_color: 'white',
489                                button_y_img: '../phpgwapi/images/win_min.gif',
490                                button_x_img: '../phpgwapi/images/winclose.gif',
491                                border: true });
492                        this.searchW[div.id] = win;
493                        win.draw();
494                }else{
495                        var _this = this;
496                        win = this.searchW[div.id];
497                        if((_this.type == "close" && win.state == 0) || win.state == 2){EsearchE.func_clean();}
498                        win.draw();
499                }
500                win.open();     
501        }
502// Cria o objeto
503        var EsearchE;
504        EsearchE = new searchE();
Note: See TracBrowser for help on using the repository browser.