source: branches/2.4/prototype/modules/mail/js/followupflag.js @ 7244

Revision 7244, 30.6 KB checked in by eduardow, 12 years ago (diff)

Ticket #3106 - Inconsistencia na tela de acompanhamento de mensagens

  • Property svn:executable set to *
Line 
1MsgsCallbackFollowupflag = {
2
3    '#FollowupflagMessageIdError': function(){
4        alert('Não foi possível sinalizar esta mensagem. \nDetalhes do erro: mensagem não contém o atributo message-id.');
5    },
6    '#FollowupflagLimitError': function(){
7        alert('Não foi possível sinalizar esta mensagem. \nDetalhes do erro: limite de flags atingido para esta pasta.');
8    },
9    '#FollowupflagParamsError': function(){
10        alert('Não foi possível sinalizar esta mensagem. \nDetalhes do erro: mensagem não contém todos os atributos necessários.');
11    }
12   
13}
14
15function updateCacheFollowupflag(msgNumber, msgFolder, op){
16        if(op){
17                if(typeof msgNumber == 'object'){
18                        var extend = DataLayer.get('followupflagged', {
19                                filter: ['AND', ['IN', 'messageNumber', msgNumber], ['IN', 'folderName', msgFolder]],
20                                criteria: {deepness: 1}
21                        }, true);
22                } else{
23                        var extend = DataLayer.get('followupflagged', {
24                                filter: ['AND', ['=', 'messageNumber', msgNumber], ['=', 'folderName', msgFolder]],
25                                criteria: {deepness: 1}
26                        }, true);
27                }
28
29               
30                if(extend != "" || extend != 'undefined' || extend != []){
31                        for(var i = 0; i < extend.length; i++){
32                                if(!(onceOpenedHeadersMessages[extend[i].folderName])){
33                                        onceOpenedHeadersMessages[extend[i].folderName] = {};
34                                }
35                                if(!(onceOpenedHeadersMessages[extend[i].folderName][extend[i].messageNumber])){
36                                        onceOpenedHeadersMessages[extend[i].folderName][extend[i].messageNumber] = []; 
37                                }
38                                onceOpenedHeadersMessages[extend[i].folderName][extend[i].messageNumber]['followupflagged'] = {};
39                                DataLayer.merge(onceOpenedHeadersMessages[extend[i].folderName][extend[i].messageNumber]['followupflagged'], extend[i]);
40                               
41                                /*
42                                if(onceOpenedHeadersMessages[extend[i].folderName]){
43                                        if(onceOpenedHeadersMessages[extend[i].folderName][extend[i].messageNumber]){
44                                                onceOpenedHeadersMessages[extend[i].folderName][extend[i].messageNumber]['followupflagged'] = {};
45                                                DataLayer.merge(onceOpenedHeadersMessages[extend[i].folderName][extend[i].messageNumber]['followupflagged'], extend[i]);
46                                        }
47                                }*/
48
49                        }
50                }
51        }else{
52                onceOpenedHeadersMessages[msgFolder][msgNumber]['followupflagged'] = undefined;
53        }
54}
55
56function init_followup(data){
57
58        winElement = data.window;
59        selectedMessageIds = data.selectedMessages;
60        folder = current_folder;
61
62        /**
63         * Implementação do widget de input-combobox
64         */
65 
66        (function( $ ) {
67                $.widget( "ui.combobox", {
68                        _create: function() {
69                                var self = this,
70                                        select = this.element.hide(),
71                                        selected = select.children( ":selected" ),
72                                        value = selected.val() ? selected.text() : "";
73                                var input = this.input = $( "<input>" )
74                                        .insertAfter( select )
75                                        .val( value )
76                                        .autocomplete({
77                                                delay: 0,
78                                                minLength: 0,
79                                                source: function( request, response ) {
80                                                        var matcher = new RegExp( $.ui.autocomplete.escapeRegex(request.term), "i" );
81                                                        response( select.children( "option" ).map(function() {
82                                                                var text = $( this ).text();
83                                                                if ( this.value && ( !request.term || matcher.test(text) ) )
84                                                                        return {
85                                                                                label: text.replace(
86                                                                                        new RegExp(
87                                                                                                "(?![^&;]+;)(?!<[^<>]*)(" +
88                                                                                                $.ui.autocomplete.escapeRegex(request.term) +
89                                                                                                ")(?![^<>]*>)(?![^&;]+;)", "gi"
90                                                                                        ), "<strong>$1</strong>" ),
91                                                                                value: text,
92                                                                                option: this
93                                                                        };
94                                                        }) );
95                                                },
96                                                select: function( event, ui ) {
97                                                        ui.item.option.selected = true;
98                                                        self._trigger( "selected", event, {
99                                                                item: ui.item.option
100                                                        });
101                                                },
102                                                change: function( event, ui ) {
103                                                        if ( !ui.item ) {
104                                                                var matcher = new RegExp( "^" + $.ui.autocomplete.escapeRegex( $(this).val() ) + "$", "i" ),
105                                                                        valid = false;
106                                                                select.children( "option" ).each(function() {
107                                                                        if ( $( this ).text().match( matcher ) ) {
108                                                                                this.selected = valid = true;
109                                                                                return false;
110                                                                        }
111                                                                });
112                                                                /*
113                                                                if ( !valid ) {
114                                                                        // remove invalid value, as it didn't match anything
115                                                                        $( this ).val( "" );
116                                                                        select.val( "" );
117                                                                        input.data( "autocomplete" ).term = "";
118                                                                        return false;
119                                                                }
120                                                                */
121                                                                if ( !valid ) {
122                                                                        if(select.has('option[value="custom"]').length > 0) {
123                                                                                select.find('option:last').val('custom').html($(this).val()).attr('selected', 'selected');
124                                                                        } else {
125                                                                                select.append(select.find('option:last').clone().val('custom').html($(this).val()));
126                                                                                select.find('option[value="custom"]').attr('selected', 'selected');
127                                                                        }
128                                                                }
129                                                        }
130                                                }
131                                        })
132                                        .addClass( "ui-widget ui-widget-content ui-corner-left" );
133
134                                input.data( "autocomplete" )._renderItem = function( ul, item ) {
135                                        return $( "<li></li>" )
136                                                .data( "item.autocomplete", item )
137                                                .append( "<a>" + item.label + "</a>" )
138                                                .appendTo( ul );
139                                };
140
141                                this.button = $( "<button type='button'>&nbsp;</button>" )
142                                        .attr( "tabIndex", -1 )
143                                        .attr( "title", "Show All Items" )
144                                        .insertAfter( input )
145                                        .button({
146                                                icons: {
147                                                        primary: "ui-icon-triangle-1-s"
148                                                },
149                                                text: false
150                                        })
151                                        .removeClass( "ui-corner-all" )
152                                        .addClass( "ui-corner-right ui-button-icon" )
153                                        .click(function() {
154                                                // close if already visible
155                                                if ( input.autocomplete( "widget" ).is( ":visible" ) ) {
156                                                        input.autocomplete( "close" );
157                                                        return;
158                                                }
159
160                                                // work around a bug (likely same cause as #5265)
161                                                $( this ).blur();
162
163                                                // pass empty string as value to search for, displaying all results
164                                                input.autocomplete( "search", "" );
165                                                input.focus();
166                                        });
167                        },
168
169                        destroy: function() {
170                                this.input.remove();
171                                this.button.remove();
172                                this.element.show();
173                                $.Widget.prototype.destroy.call( this );
174                        }
175                });
176        })( jQuery );
177        /**
178         * #END: Implementação do widget de input-combobox
179         */
180         winElement.find('input[name="alarmDate"]').change(function(event){
181                winElement.find('input[name="alarmTime"]').attr('disabled', ( $(this).val() == "" ? 'disabled' : false));
182         });
183
184         winElement.find('input[name="alarmDate"]').keyup(function(event){
185                winElement.find('input[name="alarmTime"]').attr('disabled', ( $(this).val() == "" ? 'disabled' : false)).val('');
186         });
187
188        winElement.find('.button').button()
189        .filter('.menu-configure-followupflag .cancel').click(function(){
190                winElement.dialog("close");
191        }).end()
192       
193        .filter('.menu-configure-followupflag .save').click(function(){
194        var saveFollowupflagged = function(){
195                var idFollowupflagged = winElement.find('[name="followupflagId"]').val();
196                        idFollowupflagged = idFollowupflagged.split(',');
197                        for(x=0; x<idFollowupflagged.length; x++){
198                                (idFollowupflagged[x] == "false") ? idFollowupflagged[x] = false : idFollowupflagged;
199                        }
200                for(i=0; i<selectedMessageIds.length; i++){
201                                var isDone = winElement.find('[name="done"]').is(':checked') ? 1 : 0;
202                                var alarmDate = false;
203                                var doneDate  = false;
204                                var folder_name;
205                                var folders = [];
206                                var messages = [];
207                                var roles = get_selected_messages_search_role().split(',');
208                                for (var i=0; i < selectedMessageIds.length; i++ ){
209                                        if (currentTab == 0) {
210                                                folder_name = current_folder;
211                                                var messageNumber = selectedMessageIds[i];
212                                        }else{
213                                                var tr = $('[role="'+roles[i]+'"]');
214                                                folder_name = $(tr).attr('name');
215                                                var id = $(tr).attr('id');
216                                                var messageNumber = id.replace(/_[a-zA-Z0-9]+/,"");
217                                        }
218                                        folders.push(folder_name);
219                                       
220                                                var followupflagged = DataLayer.merge({
221                                                        uid : User.me.id,
222                                                        followupflagId : followupflagId,
223                                                        folderName : folder_name,
224                                                        messageNumber : messageNumber,
225                                                        isDone: isDone,
226                                                        isSent: 0,
227                                                        backgroundColor : backgroundColor
228                                                }, !!idFollowupflagged[i] ? {id: idFollowupflagged[i]} : {});
229                                       
230                                        if (alarmDate = winElement.find('[name="alarmDate"]').datepicker("getDate")) {
231                                                if (alarmTime = winElement.find('[name="alarmTime"]').datepicker("getDate")) {
232                                                        alarmDate.set({hour:alarmTime.getHours(), minute:alarmTime.getMinutes()});
233                                                }
234                                                followupflagged.alarmDeadline = alarmDate.toString('yyyy-MM-dd HH:mm:ss');
235                                        }
236
237                                        if (doneDate = winElement.find('[name="doneDate"]').datepicker("getDate")) {
238                                                if (doneTime = winElement.find('[name="doneTime"]').datepicker("getDate")) {
239                                                        doneDate.set({hour:doneTime.getHours(), minute:doneTime.getMinutes()});
240                                                }
241                                                followupflagged.doneDeadline = doneDate.toString('yyyy-MM-dd HH:mm:ss');
242                                        }
243                                       
244                                        /**
245                                         * Aplica o ícone correspondente na lista de mensagens do expressoMail
246                                         */
247                                        if(current_folder == folder_name){
248                                                var flagged = $('#td_message_followup_' + messageNumber + ', tr[role="'+messageNumber+'_'+folder_name+'"] #td_message_followup_search_' + messageNumber).find(".flag-edited");
249                                        } else{
250                                                var flagged = $('tr[role="'+messageNumber+'_'+folder_name+'"] #td_message_followup_search_' + messageNumber).find(".flag-edited");
251                                        }
252                                        if(isDone){
253                                                flagged.find("img").attr("src", "../prototype/modules/mail/img/flagChecked.png").css("margin-left","-3px");
254                                        }else{
255                                                flagged.find("img").attr("src", "../prototype/modules/mail/img/flagEditor.png").css("margin-left","0");                 
256                                        }
257                                       
258                                        var followupflagName = winElement.find('[name="name"] option:selected').text();
259                                        if(current_folder == folder_name){
260                                                $('#td_message_followup_' + messageNumber + ', ' +
261                                                'tr[role="'+messageNumber+'_'+folder_name+'"] #td_message_followup_search_' + messageNumber).attr('title', followupflagName).find(".flag-edited").css("background", backgroundColor);
262                                        }else{
263                                                $('tr[role="'+messageNumber+'_'+folder_name+'"] #td_message_followup_search_' + messageNumber).attr('title', followupflagName).find(".flag-edited").css("background", backgroundColor);
264                                        } 
265                                        /**
266                                         * Salva ou, caso já exista, atualiza
267                                         */
268                                        DataLayer.put('followupflagged', followupflagged);
269                                }
270                               
271                                DataLayer.commit(false, false, function(data){
272                                        winElement.find('.menu-configure-followupflag .delete').button("option", "disabled", false);
273                                        updateCacheFollowupflag(selectedMessageIds, folders, true);
274                                        winElement.dialog("close");
275                                        alarmFollowupflagged('followupflagAlarms');
276                                });
277                                winElement.find('.menu-configure-followupflag .save').button("option", "disabled", true);
278                               
279               
280                }
281                selectAllFolderMsgs(false);
282    }
283                var backgroundColor = winElement.find('[name="backgroundColor"]').val();
284                var followupflagId  = winElement.find('[name="name"] option:selected').val();
285                if (followupflagId == 'custom') {
286                        DataLayer.put('followupflag', {name:winElement.find('[name="name"] option:selected').text(), uid:User.me.id});
287                        DataLayer.commit(false, false, function(data){
288                                $.each(data, function(index, value) {
289                                        if(typeof value == 'object'){
290                                                followupflagId = value.id;
291                                        }
292                                });
293                                winElement.find('[name="name"] option[value="custom"]').val(followupflagId);
294                                saveFollowupflagged();
295                        });
296                }else{
297                        saveFollowupflagged();
298                }       
299
300        }).end()
301       
302        .filter('.menu-configure-followupflag .delete').click(function(){
303                if (selectedMessageIds.length == 0) $(this).button("option", "disabled", true);
304                /** TODO Mudar quando melhorias forem implementadas na API de atualização do cache */
305                DataLayer.remove('followupflagged', false);
306                DataLayer.get('followupflagged');
307                var roles = get_selected_messages_search_role().split(',');
308                for (var i=0; i < selectedMessageIds.length; i++ ){
309                                if (currentTab == 0) {
310                                        folder_name = current_folder;
311                                        var messageNumber = selectedMessageIds[i];
312                                }else{
313                                        var tr = $('[role="'+roles[i]+'"]');
314                                        folder_name = $(tr).attr('name');
315                                        var id = $(tr).attr('id');
316                                        var messageNumber = id.replace(/_[a-zA-Z0-9]+/,"");
317                                }                               
318                               
319                        if(onceOpenedHeadersMessages[folder_name][messageNumber]['followupflagged']){
320                                if(onceOpenedHeadersMessages[folder_name][messageNumber]['followupflagged'].id){
321                                        var flag_id = onceOpenedHeadersMessages[folder_name][messageNumber]['followupflagged'].id;
322                                        DataLayer.remove('followupflagged', flag_id );
323                                        /**
324                                         * TODO - corrigir o formato do ID no DataLayer, para que seja utilizado o ID composto
325                                         * ao invés do ID do PostgreSQL atualmente em uso.
326                                         */
327                                         
328                                        /**
329                                         * # hack necessário enquanto o DataLayer não reconhece o ID composto. Trocar o
330                                         * código abaixo pela chamada trivial de DataLayer.remove('followupflagged', idCompost)
331                                         */
332                                        // var data = {};
333                                        // data[ 'followupflagged://' + folder_name + '/' + messageNumber + '#' + flag_id ] = false;
334                                        // DataLayer.dispatch('Sync', data, false, true);
335                                       
336                                        if(current_folder == folder_name){
337                                                $('#td_message_followup_' + messageNumber + ', ' +
338                                                  'tr[role="'+messageNumber+'_'+folder_name+'"] #td_message_followup_search_' + messageNumber).attr('title', '').find(".flag-edited").css("background", '#CCC');
339                                                $('#td_message_followup_' + messageNumber + ', ' +
340                                                        'tr[role="'+messageNumber+'_'+folder_name+'"] #td_message_followup_search_' + messageNumber).find(".flag-edited")
341                                                        .find("img").attr("src", "../prototype/modules/mail/img/flagEditor.png").css("margin-left","0");
342                                        }else{
343                                                $('tr[role="'+messageNumber+'_'+folder_name+'"] #td_message_followup_search_' + messageNumber).attr('title', '').find(".flag-edited").css("background", '#CCC');
344                                                $('tr[role="'+messageNumber+'_'+folder_name+'"] #td_message_followup_search_' + messageNumber).find(".flag-edited")
345                                                        .find("img").attr("src", "../prototype/modules/mail/img/flagEditor.png").css("margin-left","0");
346                                        }
347                                        updateCacheFollowupflag(messageNumber, folder_name, false);
348                                }
349                        }
350                }
351                DataLayer.commit(false, false, function(){
352                        winElement.dialog("close");
353                        alarmFollowupflagged('followupflagAlarms');
354                });
355                selectAllFolderMsgs(false);
356        });
357       
358        /**
359         * Se houver mudança, habilita o botão "Save"
360         */
361        winElement.find(':input').change(function(event){
362                if (event.keyCode != '27' && event.keyCode != '13')
363                        winElement.find('.menu-configure-followupflag .save').button("option", "disabled", false);
364        }).keydown(function(event){
365                if (event.keyCode != '27' && event.keyCode != '13')
366                        winElement.find('.menu-configure-followupflag .save').button("option", "disabled", false);
367        });
368       
369        winElement.find('.date').datepicker();
370        winElement.find('.time').timepicker({});
371        winElement.find('[name="name"]').combobox()
372        //pega o botão criado
373        .next().next().click(function (event, ui){     
374                $(".ui-autocomplete.ui-menu li").css("position","relative");
375                $(".ui-autocomplete.ui-menu li a:gt(5)").append("<span class='ui-icon ui-icon-only ui-icon-close delete_followupflag'></span>").find("span").click(function(event){
376                        var id = $('.followupflag-configure').find('option')[$(this).parents('li').index()].value;
377                        var nameFollowupflag = $('.followupflag-configure').find('option')[$(this).parents('li').index()].text;
378                        var removeLi = $(this).parents("li");           
379                       
380                        $.Zebra_Dialog(get_lang('All messages flagged with the flag type ') + '<strong>'+ nameFollowupflag + '</strong>' + get_lang(' will be removed. This action cannot be undone. Want to continue?'), {
381                                'type':     'question',
382                                'custom_class': (is_ie ? 'configure-zebra-dialog' : ''),
383                                'title':    'Atenção',
384                                'buttons': ['Sim','Não'],               
385                                'overlay_opacity': '0.5',
386                                'onClose':  function(caption) {
387                                        if(caption == 'Sim'){
388                                                var listFollowupflag = DataLayer.get('followupflagged', ['=', 'followupflagId', id]);
389                                                for (var i=0; i < listFollowupflag.length; i++)
390                                                        DataLayer.remove('followupflagged', listFollowupflag[i].id);
391
392                                                DataLayer.remove('followupflag',false);                                 
393                                                DataLayer.get('followupflag');
394
395                                                DataLayer.remove('followupflag', ''+id);                                               
396                                                DataLayer.commit(false, false, function(data){
397                                                        $('[title="'+nameFollowupflag+'"]').attr('title', '').find('div').css({backgroundColor:'#CCC'});
398                                                        $(removeLi).remove();
399                                                        $('option[value="'+ id +'"]').remove();
400                                                        $('.ui-autocomplete.ui-menu li:first');
401                                                        $('.followupflag-configure').find('option:first').attr("selected","selected");                                                 
402                                                        $('.ui-autocomplete-input').val($('.followupflag-configure').find('option:selected').text());
403                                                       
404                                                        for(var i=0; i<listFollowupflag.length; i++){
405                                                                if(listFollowupflag[i].id == winElement.find('[name="followupflagId"]').val()){
406                                                                        winElement.find('[name="followupflagId"]').val("");
407                                                                }
408                                                        }                                               
409                                                });                     
410                                                event.stopImmediatePropagation();
411                                        }
412                                }
413                        });     
414                        if(is_ie)
415                                $(".ZebraDialogOverlay").css("z-index","1006");
416                });
417
418        });
419        winElement.find('.ui-corner-right.ui-button-icon').attr('title', get_lang('Show All Items'));
420
421        winElement.find('[name="alarmDate"],[name="alarmTime"]').attr("disabled","disabled");
422       
423        winElement.find('.menu-configure-followupflag .delete').button("option", "disabled", true);     
424    var idFollowupflag = winElement.find('[name="followupflagId"]').val();
425            idFollowupflag = idFollowupflag.split(',');
426     
427    $.each(idFollowupflag, function(index,value){
428            if (value != "false" ){
429                    winElement.find('.menu-configure-followupflag .delete').button("option", "disabled", false);
430            }
431    });
432
433        winElement.find('[name="alarm"]').click(function(){
434                if($(this).is(":checked")){
435                        winElement.find('[name="alarmDate"]').removeAttr("disabled");                   
436                }else{
437                        winElement.find('[name="alarmDate"],[name="alarmTime"]').attr("disabled","disabled").val('');
438                }
439        });
440
441        if(winElement.find('[name="alarm"]').is(":checked")){
442                winElement.find('[name="alarmDate"],[name="alarmTime"]').removeAttr("disabled");
443        }
444       
445        winElement.find('[name="done"]').click(function(){
446                if($(this).is(":checked")){
447                        winElement.find(".input-done input").attr("disabled","disabled");
448                }else{
449                        winElement.find(".input-done input").removeAttr("disabled");
450                }
451        });
452
453
454        winElement.find(".followupflag-color-fields").hide();
455        winElement.find(".followupflag-color.sample-list .sample-item").click(function(){
456                winElement.find('.menu-configure-followupflag .save').button("enable");
457                winElement.find(".followupflag-color.sample-list .sample-item").removeClass("selected");
458                $(this).addClass("selected");
459                var color = $(this).attr('alt');
460                winElement.find('[name="backgroundColor"]').css('background-color', color).val(color)
461        });
462       
463        winElement.find(".followupflag-color.sample-list .sample-item.selected").trigger('click');
464                               
465        winElement.find('[name="setColor"]').change(function(){
466                if(winElement.find('[name="setColor"]').val() == "default"){
467                        winElement.find(".followupflag-color.sample-list").show("fast");
468                        winElement.find(".followupflag-color-fields").hide();
469                        winElement.find(".followupflag-color.sample-list .sample-item.selected").trigger('click');
470                } else if(winElement.find('[name="setColor"]').val() == "custom"){     
471                        winElement.find(".followupflag-color-fields").show("fast");
472                        winElement.find(".followupflag-color.sample-list").hide();
473                        winElement.find(".colorwell").focus();
474                }               
475        });
476       
477        if(winElement.find('[name="setColor"] option:selected').val() == "custom"){
478                winElement.find('[name="setColor"]').trigger("change");
479        }
480
481        var colorpickerPreviewChange = function(color) {
482                winElement.find('.menu-configure-followupflag .save').button("enable");
483                winElement.find('.colorwell-selected').val(color).css('background-color', color);
484                winElement.find('.flag-color-preview').css('background',color);
485        }
486
487        var f = $.farbtastic(winElement.find('.colorpicker'), colorpickerPreviewChange);
488        var selected;                                   
489        winElement.find('.colorwell').each(function () {
490                f.linkTo(this);
491        }).focus(function() {
492                if (selected) {
493                        $(selected).removeClass('colorwell-selected');
494                }
495                $(selected = this).addClass('colorwell-selected');
496                f.linkTo(this, colorpickerPreviewChange);
497                f.linkTo(colorpickerPreviewChange);
498               
499        });
500        if(winElement.find('[name="setColor"] option:selected').val() == "custom"){
501                winElement.find(".colorwell").focus();
502        }
503
504}
505
506
507/**
508 * constrói as três possíveis janelas de alerta, utilizando o mesmo template
509 * para o parametro alert_type, espera-se vazio, followupflagAlarms ou filtersAlarms
510 * vazio: quando serão carregadas todas as modais de alarmes
511 * followupflagAlarms: quando serão carregadas as modais referentes à sinalizações
512 * filtersAlarms: quando será carregada a modal de filtros (nesse caso o parametro filter_list deve conter a lista de mensagens a ser exibida na modal)
513 */
514function alarmFollowupflagged(alert_type, filter_list){
515        var currentDate = new Date().toString("dd/MM/yyyy");
516        var data = {alarmDeadline: false, doneDeadline: false, filtersAlarms: false};
517
518        switch(alert_type){
519                case 'followupflagAlarms':
520                        $('.doneDeadline').remove();
521                        $('.alarmDeadline').remove();
522                        data.alarmDeadline = $.cookie("fadeAlarm") != currentDate ? true : false;
523                        data.doneDeadline = $.cookie("fadeCompleted") != currentDate ? true : false;
524                break;
525                case 'filtersAlarms':
526                        $('.filtersDeadline').remove();
527                        data.filtersAlarms = $.cookie("fadeFilterAlarm") != currentDate ? true : false;
528                break;
529                default:
530                        $('.gray').remove();
531                        data.alarmDeadline = $.cookie("fadeAlarm") != currentDate ? true : false;
532                        data.doneDeadline = $.cookie("fadeCompleted") != currentDate ? true : false;
533                        data.filtersAlarms = $.cookie("fadeFilterAlarm") != currentDate ? true : false;
534                break;
535        };
536
537        var startDate = (new Date()).set({hour:0, minute:0, second:0}).toString('yyyy-MM-dd 00:00:00');
538        var endDate = (new Date()).set({hour:0, minute:0, second:0}).addHours(24).toString('yyyy-MM-dd 00:00:00');
539
540        if(data.alarmDeadline){
541                var decodeAlarms = {'sent': [], 'task':[]};     
542                alarms = DataLayer.get('followupflagged',
543                        {
544                                filter: ['AND', ['<', 'alarmDeadline', endDate], ['=','isSent','0'], ['=','isDone','0']],
545                                criteria: {deepness: 1}
546                        });
547
548                if(alarms.length > 0){
549                        var itens = [];
550                        for(var i = 0; i < alarms.length; i++){
551
552                                var date = Date.parseExact(alarms[i]['alarmDeadline'], 'yyyy-MM-dd HH:mm:ss');
553                        alarms[i]['alarmDeadline'] = date.toString('dd/MM HH:mm');
554
555                                var nameFollowupflag = alarms[i]['followupflag']['id'] < 7 ? get_lang(alarms[i]['followupflag']['name']) : alarms[i]['followupflag']['name'];
556                                var li_alarm = alarms[i]['alarmDeadline'] + ' - ' + nameFollowupflag + ' - ' + alarms[i]['message']['headers']['subject'];
557
558                                if(alarms[i]['doneDeadline'] != ''){
559                                        var dateDone = Date.parseExact(alarms[i]['doneDeadline'], 'yyyy-MM-dd HH:mm:ss');
560                                        if(dateDone.getTime() < $.now())
561                                                continue;
562                                }
563
564                                if(date.getTime() <= $.now())
565                                        decodeAlarms.sent.push({
566                                                "msg_number" : alarms[i]['messageNumber'],
567                                                "msg_folder" : alarms[i]['folderName'],
568                                                "a"                      : truncate(li_alarm, 34),
569                                                'id' : alarms[i].id
570                                        });
571                        else
572                                decodeAlarms.task.push({
573                                                a: truncate(li_alarm, 34),
574                                                sentTime:  date.getTime() / 1000,
575                                                id: alarms[i].id,
576                                                'msg_folder': alarms[i].folderName,
577                                                'msg_number': alarms[i].messageNumber
578                                        });
579                        }
580
581                        if(decodeAlarms.task.length)
582                                alarmDeadline.load(decodeAlarms.task);
583
584                        if(decodeAlarms.sent.length)
585                                data.alarmDeadline = {
586                                                alarms: decodeAlarms.sent,
587                                                title: get_lang('Follow ups'),
588                                                caption: (itens.length == 1) ? get_lang('You have one undone message today:') : get_lang('You have %1 follow ups due for today:', decodeAlarms.sent.length),
589                                                type: 'alarmDeadline'
590                                        };
591                        else
592                                data.alarmDeadline = false;
593                }else
594                        data.alarmDeadline = false;
595        }
596
597        if(data.doneDeadline){
598                alarms = DataLayer.get('followupflagged', {filter: ['AND', ['>', 'doneDeadline', startDate], ['<', 'doneDeadline', endDate]], criteria: {deepness: 1}});
599
600                if(alarms.length > 0){
601                        var itens = [];
602                        for(var i = 0; i < alarms.length; i++){
603
604                            var date = Date.parseExact(alarms[i]['doneDeadline'], 'yyyy-MM-dd HH:mm:ss');
605                            alarms[i]['doneDeadline'] = date.toString('dd/MM HH:mm');
606
607                            var nameFollowupflag = alarms[i]['followupflag']['id'] < 7 ? get_lang(alarms[i]['followupflag']['name']) : alarms[i]['followupflag']['name'];
608                            var li_alarm = alarms[i]['doneDeadline'] + ' - ' + nameFollowupflag + ' - ' + truncate(alarms[i]['message']['headers']['subject'], 15);
609
610                            itens.push({
611                                    a: truncate(li_alarm, 34),
612                                    id: alarms[i].id,
613                                    'msg_folder': alarms[i].folderName,
614                                    'msg_number': alarms[i].messageNumber
615                            });
616                        }
617                    data.doneDeadline = {
618                        alarms: itens,
619                        title: get_lang('Done'),
620                        caption: (itens.length == 1) ? get_lang('You have one undone message today:') : get_lang('You have %1 follow ups due for today:', itens.length),
621                        type: 'doneDeadline'
622                    };
623                }else
624                    data.doneDeadline = false;
625        }
626
627        if(data.filtersAlarms){
628
629                alarms = filter_list;
630
631                if(alarms.length > 0){
632                    var itens = [];
633
634                    for(var i=0; i<alarms.length; i++){
635                        alarms[i]['udate'] =  new Date(alarms[i]['udate']*1000).toString('dd/MM HH:mm');
636                        var li_alarm = alarms[i]['udate'] + ' - ' + alarms[i]['from'] + ' - ' + alarms[i]['subject'];
637
638                        itens.push({
639                                'msg_number' : alarms[i]['msg_number'],
640                                'msg_folder' : alarms[i]['msg_folder'],
641                                a            : truncate(html_entities(li_alarm), 34),
642                                id : alarms[i].id
643                        });                             
644                }
645
646                data.filtersAlarms = {
647                                alarms: itens,
648                                title: get_lang('Filter by sender'),
649                                caption: (itens.length == 1) ? get_lang('You have an archived message:') : get_lang('You have %1 messages archived:', itens.length),
650                                type: 'filtersDeadline',
651                                captions: {
652                                    singular:'You have one undone message today:',
653                                    plural:"You have %1 undone messages today:"
654                                }
655                        };
656
657                }else
658                    data.filtersAlarms = false;
659        }
660
661        for (var i in data)
662                if(data[i] != false)
663                        showAlarmsModal(data[i]);
664
665        // controle de qual janela de alarme estará maximizada
666        $('.gray').find('.content-alarm').hide();
667        $('.gray').find('.header-alarm [name="header-icon"]').removeClass('minimize-alarm').addClass('maximize-alarm');
668       
669        if($('.gray').length > 0){
670                if($('.gray').hasClass('filtersDeadline')){
671                        $('.filtersDeadline').find('.content-alarm').show();
672                        $('.filtersDeadline .header-alarm [name="header-icon"]').removeClass('maximize-alarm').addClass('minimize-alarm');
673                }else if($('.gray').hasClass('alarmDeadline')){
674                        $('.alarmDeadline').find('.content-alarm').show();
675                        $('.alarmDeadline .header-alarm [name="header-icon"]').removeClass('maximize-alarm').addClass('minimize-alarm');       
676                }else if($('.gray').hasClass('doneDeadline')){
677                        $('.doneDeadline').find('.content-alarm').show();
678                        $('.doneDeadline .header-alarm [name="header-icon"]').removeClass('maximize-alarm').addClass('minimize-alarm');
679                }
680        }
681}
682
683function showAlarmsModal(alarm){
684       
685        var ok_function = function(event, type, type_cookie){
686                if($(event.target).parents('.'+type).find('[name="stopAlert"]').is(':checked')){
687                        $.cookie(type_cookie, (new Date).toString("dd/MM/yyyy"), {
688                                expires: 1
689                        });
690                }
691        }
692
693        // carrega o template dos alarmes e cria a modal utilizando o plugin freeow
694        var dialogText = DataLayer.render("../prototype/modules/mail/templates/followupflag_alarm_list.ejs", alarm);
695        var titulo = '<div class="header-alarm"><span class="img_title"></span><span class="title-alarm"><strong>'+alarm.title+'</strong></span><span name="header-icon" class="maximize-alarm"></span></div>';
696       
697        $("#freeow").freeow(titulo, dialogText, {
698                classes: ["gray", alarm.type],
699                autoHide: false,
700                startStyle: null,
701                onClick: function(event){
702                        var type = '';
703                        var type_cookie = '';
704                        if($(this).hasClass('alarmDeadline')){
705                                type = 'alarmDeadline';
706                                type_cookie = 'fadeAlarm';
707                        }else if($(this).hasClass('doneDeadline')){
708                                type = 'doneDeadline';
709                                type_cookie = 'fadeCompleted';
710                        }else if($(this).hasClass('filtersDeadline')){
711                                type = 'filtersDeadline';
712                                type_cookie = 'fadeFilterAlarm';
713                        }
714                        if($(event.target).hasClass('stop-alert-alarm')){
715                                return;
716                        }
717                        if($(event.target).hasClass('minimize-alarm')){
718                                $('.'+type).find('.content-alarm').hide();
719                                $(event.target).removeClass('minimize-alarm').addClass('maximize-alarm');
720                                return;
721                        }
722                        if($(event.target).hasClass('maximize-alarm')){
723                                $('.'+type).find('.content-alarm').show();
724                                $(event.target).removeClass('maximize-alarm').addClass('minimize-alarm');
725                                return;
726                        }
727                        if($(( !!$.browser.safari ) ? event.target.parentElement : event.target).hasClass('confirm-alarm')){
728                                ok_function(event, type, type_cookie);
729                                $('.'+type).remove();
730                                return;
731                        }
732                        return false;
733                }
734        });
735        // elementos do freeow desnecessários
736        $('.gray .background .content p').remove();
737        $('.gray .icon').remove();
738        $('.gray .close').remove();
739
740        $('div.gray.alarmDeadline .button.delete').button({
741                text: false,
742                icons:{
743                        primary: 'ui-icon-close'
744                }
745        })
746       
747        // botão ok da modal com jquery button
748        $('.content-alarm button').button();
749}
750
751function cancelAlarm(element, idAlarm, messageNumber, folderName){
752
753        $(element).parents('li').remove();
754
755        var view = 'div.gray.alarmDeadline';
756        var length = $(view).find('ul.message-list li').length;
757
758        if(length > 0){
759                var msg = '';
760                if(length == 1)
761                        msg = get_lang( 'You have a follow up due for today:');
762                else
763                        msg = get_lang('You have %1 follow ups due for today:', length);
764
765                $(view).find('span.subtitle-alarm strong').html(msg);
766        }else
767                $(view).remove();
768
769        DataLayer.put('followupflagged',
770                {
771                        id: idAlarm ,
772                        isSent: '1',
773                        folderName: folderName,
774                        messageNumber: messageNumber,
775                        uid: User.me.uid
776                });
777
778        DataLayer.commit();
779
780}
781
782alarmDeadline = {
783
784
785        load: function(alarm){
786                var currentDate = new Date().toString("dd/MM/yyyy")
787                if($.cookie("fadeAlarm") != currentDate)
788                        for(var i = 0; i < alarm.length; i++)
789                                this.addAlarm( alarm[i] );
790        },
791
792        addAlarm: function(alarm){
793
794                    DataLayer.task( parseInt(alarm['sentTime']) , function( timestamp ){
795                        var view = 'div.gray.alarmDeadline';
796
797                        if(!$(view+' li.message-item.'+alarm.id).length){
798
799                                var currentDate = new Date().toString("dd/MM/yyyy")
800                                        if($.cookie("fadeAlarm") != currentDate)
801                                       
802                                        if($('div.gray.alarmDeadline').length){
803                                               
804                                                $(view).find('ul.message-list').append(DataLayer.render("../prototype/modules/mail/templates/followupflag_alarmDeadline_add_item_list.ejs", alarm))
805
806                                                var length = $(view).find('ul.message-list li').length;
807                                                var msg = '';
808                                                if(length == 1)
809                                                        msg = get_lang( 'You have a follow up due for today:');
810                                                else
811                                                        msg = get_lang('You have %1 follow ups due for today:', length);
812
813                                                $(view).find('span.subtitle-alarm strong').html(msg);
814
815                                                $(view+' .button.delete').button({
816                                                                text: false,
817                                                                icons:{
818                                                                        primary: 'ui-icon-close'
819                                                                }
820                                                        });
821
822                                        }else{
823                                                var item = {
824                                                                alarms: [alarm],
825                                                                title: get_lang('Follow ups'),
826                                                                caption: get_lang('You have one undone message today:'),
827                                                                type: 'alarmDeadline'
828                                                        };
829                                                        showAlarmsModal(item);
830                                        }
831                                    }
832                               
833                    });
834        }
835
836}
837               
838$('#main_table').ready(function(){
839        handlerMessageFilter = function (data) {
840                alarmFollowupflagged(null, data);
841        }
842        /* Busca  nas pastas indexadas para ver se há novas mensagens com a flag $FilteredMessage */
843        cExecute ("$this.imap_functions.getFlaggedAlertMessages&folders="+fromRules, handlerMessageFilter);
844});
845
Note: See TracBrowser for help on using the repository browser.