You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							308 lines
						
					
					
						
							8.3 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							308 lines
						
					
					
						
							8.3 KiB
						
					
					
				| var AppInbox = function () { | |
| 
 | |
|     var content = $('.inbox-content'); | |
|     var listListing = ''; | |
| 
 | |
|     var loadInbox = function (el, name) { | |
|         var url = 'app_inbox_inbox.html'; | |
|         var title = el.attr('data-title'); | |
|         listListing = name; | |
| 
 | |
|         App.blockUI({ | |
|             target: content, | |
|             overlayColor: 'none', | |
|             animate: true | |
|         }); | |
| 
 | |
|         toggleButton(el); | |
| 
 | |
|         $.ajax({ | |
|             type: "GET", | |
|             cache: false, | |
|             url: url, | |
|             dataType: "html", | |
|             success: function(res)  | |
|             { | |
|                 toggleButton(el); | |
| 
 | |
|                 App.unblockUI('.inbox-content'); | |
| 
 | |
|                 $('.inbox-nav > li.active').removeClass('active'); | |
|                 el.closest('li').addClass('active'); | |
|                 $('.inbox-header > h1').text(title); | |
| 
 | |
|                 content.html(res); | |
| 
 | |
|                 if (Layout.fixContentHeight) { | |
|                     Layout.fixContentHeight(); | |
|                 } | |
| 
 | |
|                 App.initUniform(); | |
|             }, | |
|             error: function(xhr, ajaxOptions, thrownError) | |
|             { | |
|                 toggleButton(el); | |
|             }, | |
|             async: false | |
|         }); | |
| 
 | |
|         // handle group checkbox: | |
|         jQuery('body').on('change', '.mail-group-checkbox', function () { | |
|             var set = jQuery('.mail-checkbox'); | |
|             var checked = jQuery(this).is(":checked"); | |
|             jQuery(set).each(function () { | |
|                 $(this).attr("checked", checked); | |
|             }); | |
|             jQuery.uniform.update(set); | |
|         }); | |
|     } | |
| 
 | |
|     var loadMessage = function (el, name, resetMenu) { | |
|         var url = 'app_inbox_view.html'; | |
| 
 | |
|         App.blockUI({ | |
|             target: content, | |
|             overlayColor: 'none', | |
|             animate: true | |
|         }); | |
| 
 | |
|         toggleButton(el); | |
| 
 | |
|         var message_id = el.parent('tr').attr("data-messageid");   | |
|          | |
|         $.ajax({ | |
|             type: "GET", | |
|             cache: false, | |
|             url: url, | |
|             dataType: "html", | |
|             data: {'message_id': message_id}, | |
|             success: function(res)  | |
|             { | |
|                 App.unblockUI(content); | |
| 
 | |
|                 toggleButton(el); | |
| 
 | |
|                 if (resetMenu) { | |
|                     $('.inbox-nav > li.active').removeClass('active'); | |
|                 } | |
|                 $('.inbox-header > h1').text('View Message'); | |
| 
 | |
|                 content.html(res); | |
|                 Layout.fixContentHeight(); | |
|                 App.initUniform(); | |
|             }, | |
|             error: function(xhr, ajaxOptions, thrownError) | |
|             { | |
|                 toggleButton(el); | |
|             }, | |
|             async: false | |
|         }); | |
|     } | |
| 
 | |
|     var initWysihtml5 = function () { | |
|         $('.inbox-wysihtml5').wysihtml5({ | |
|             "stylesheets": ["../assets/global/plugins/bootstrap-wysihtml5/wysiwyg-color.css"] | |
|         }); | |
|     } | |
| 
 | |
|     var initFileupload = function () { | |
| 
 | |
|         $('#fileupload').fileupload({ | |
|             // Uncomment the following to send cross-domain cookies: | |
|             //xhrFields: {withCredentials: true}, | |
|             url: '../assets/global/plugins/jquery-file-upload/server/php/', | |
|             autoUpload: true | |
|         }); | |
| 
 | |
|         // Upload server status check for browsers with CORS support: | |
|         if ($.support.cors) { | |
|             $.ajax({ | |
|                 url: '../assets/global/plugins/jquery-file-upload/server/php/', | |
|                 type: 'HEAD' | |
|             }).fail(function () { | |
|                 $('<span class="alert alert-error"/>') | |
|                     .text('Upload server currently unavailable - ' + | |
|                     new Date()) | |
|                     .appendTo('#fileupload'); | |
|             }); | |
|         } | |
|     } | |
| 
 | |
|     var loadCompose = function (el) { | |
|         var url = 'app_inbox_compose.html'; | |
| 
 | |
|         App.blockUI({ | |
|             target: content, | |
|             overlayColor: 'none', | |
|             animate: true | |
|         }); | |
| 
 | |
|         toggleButton(el); | |
| 
 | |
|         // load the form via ajax | |
|         $.ajax({ | |
|             type: "GET", | |
|             cache: false, | |
|             url: url, | |
|             dataType: "html", | |
|             success: function(res)  | |
|             { | |
|                 App.unblockUI(content); | |
|                 toggleButton(el); | |
| 
 | |
|                 $('.inbox-nav > li.active').removeClass('active'); | |
|                 $('.inbox-header > h1').text('Compose'); | |
| 
 | |
|                 content.html(res); | |
| 
 | |
|                 initFileupload(); | |
|                 initWysihtml5(); | |
| 
 | |
|                 $('.inbox-wysihtml5').focus(); | |
|                 Layout.fixContentHeight(); | |
|                 App.initUniform(); | |
|             }, | |
|             error: function(xhr, ajaxOptions, thrownError) | |
|             { | |
|                 toggleButton(el); | |
|             }, | |
|             async: false | |
|         }); | |
|     } | |
| 
 | |
|     var loadReply = function (el) { | |
|         var messageid = $(el).attr("data-messageid"); | |
|         var url = 'app_inbox_reply.html'; | |
|          | |
|         App.blockUI({ | |
|             target: content, | |
|             overlayColor: 'none', | |
|             animate: true | |
|         }); | |
| 
 | |
|         toggleButton(el); | |
| 
 | |
|         // load the form via ajax | |
|         $.ajax({ | |
|             type: "GET", | |
|             cache: false, | |
|             url: url, | |
|             dataType: "html", | |
|             success: function(res)  | |
|             { | |
|                 App.unblockUI(content); | |
|                 toggleButton(el); | |
| 
 | |
|                 $('.inbox-nav > li.active').removeClass('active'); | |
|                 $('.inbox-header > h1').text('Reply'); | |
| 
 | |
|                 content.html(res); | |
|                 $('[name="message"]').val($('#reply_email_content_body').html()); | |
| 
 | |
|                 handleCCInput(); // init "CC" input field | |
|  | |
|                 initFileupload(); | |
|                 initWysihtml5(); | |
|                 Layout.fixContentHeight(); | |
|                 App.initUniform(); | |
|             }, | |
|             error: function(xhr, ajaxOptions, thrownError) | |
|             { | |
|                 toggleButton(el); | |
|             }, | |
|             async: false | |
|         }); | |
|     } | |
| 
 | |
|     var handleCCInput = function () { | |
|         var the = $('.inbox-compose .mail-to .inbox-cc'); | |
|         var input = $('.inbox-compose .input-cc'); | |
|         the.hide(); | |
|         input.show(); | |
|         $('.close', input).click(function () { | |
|             input.hide(); | |
|             the.show(); | |
|         }); | |
|     } | |
| 
 | |
|     var handleBCCInput = function () { | |
| 
 | |
|         var the = $('.inbox-compose .mail-to .inbox-bcc'); | |
|         var input = $('.inbox-compose .input-bcc'); | |
|         the.hide(); | |
|         input.show(); | |
|         $('.close', input).click(function () { | |
|             input.hide(); | |
|             the.show(); | |
|         }); | |
|     } | |
| 
 | |
|     var toggleButton = function(el) { | |
|         if (typeof el == 'undefined') { | |
|             return; | |
|         } | |
|         if (el.attr("disabled")) { | |
|             el.attr("disabled", false); | |
|         } else { | |
|             el.attr("disabled", true); | |
|         } | |
|     } | |
| 
 | |
|     return { | |
|         //main function to initiate the module | |
|         init: function () { | |
| 
 | |
|             // handle compose btn click | |
|             $('.inbox').on('click', '.compose-btn', function () { | |
|                 loadCompose($(this)); | |
|             }); | |
| 
 | |
|             // handle discard btn | |
|             $('.inbox').on('click', '.inbox-discard-btn', function(e) { | |
|                 e.preventDefault(); | |
|                 loadInbox($(this), listListing); | |
|             }); | |
| 
 | |
|             // handle reply and forward button click | |
|             $('.inbox').on('click', '.reply-btn', function () { | |
|                 loadReply($(this)); | |
|             }); | |
| 
 | |
|             // handle view message | |
|             $('.inbox').on('click', '.view-message', function () { | |
|                 loadMessage($(this)); | |
|             }); | |
| 
 | |
|             // handle inbox listing | |
|             $('.inbox-nav > li > a').click(function () { | |
|                 loadInbox($(this), 'inbox'); | |
|             }); | |
| 
 | |
|             //handle compose/reply cc input toggle | |
|             $('.inbox-content').on('click', '.mail-to .inbox-cc', function () { | |
|                 handleCCInput(); | |
|             }); | |
| 
 | |
|             //handle compose/reply bcc input toggle | |
|             $('.inbox-content').on('click', '.mail-to .inbox-bcc', function () { | |
|                 handleBCCInput(); | |
|             }); | |
| 
 | |
|             //handle loading content based on URL parameter | |
|             if (App.getURLParameter("a") === "view") { | |
|                 loadMessage(); | |
|             } else if (App.getURLParameter("a") === "compose") { | |
|                 loadCompose(); | |
|             } else { | |
|                $('.inbox-nav > li:first > a').click(); | |
|             } | |
| 
 | |
|         } | |
| 
 | |
|     }; | |
| 
 | |
| }(); | |
| 
 | |
| jQuery(document).ready(function() { | |
|     AppInbox.init(); | |
| });
 |