mirror of
				https://github.com/e107inc/e107.git
				synced 2025-10-26 03:07:43 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			1220 lines
		
	
	
		
			29 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			1220 lines
		
	
	
		
			29 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| var e107 = e107 || {'settings': {}, 'behaviors': {}};
 | |
| 
 | |
| (function ($)
 | |
| {
 | |
| 
 | |
| 	/**
 | |
| 	 * Initializes click event on '.e-modal' elements.
 | |
| 	 *
 | |
| 	 * @type {{attach: e107.behaviors.eModalAdmin.attach}}
 | |
| 	 */
 | |
| 	e107.behaviors.eModalAdmin = {
 | |
| 		attach: function (context, settings)
 | |
| 		{
 | |
| 			$(context).find('.e-modal').once('e-modal-admin').each(function ()
 | |
| 			{
 | |
| 				var $that = $(this);
 | |
| 
 | |
| 				$that.on('click', function ()
 | |
| 				{
 | |
| 					var $this = $(this);
 | |
| 
 | |
| 					if($this.attr('data-cache') === 'false')
 | |
| 					{
 | |
| 						$('#uiModal').on('shown.bs.modal', function ()
 | |
| 						{
 | |
| 							$(this).removeData('bs.modal');
 | |
| 						});
 | |
| 					}
 | |
| 
 | |
| 					var url = $this.attr('href');
 | |
| 					var caption = $this.attr('data-modal-caption');
 | |
| 					var height = ($(window).height() * 0.7) - 120;
 | |
| 					var target = $this.attr('data-modal-target');
 | |
| 
 | |
| 					if(caption === undefined)
 | |
| 					{
 | |
| 						caption = '';
 | |
| 					}
 | |
| 
 | |
| 					if(target === undefined)
 | |
| 					{
 | |
| 						target = '#uiModal';
 | |
| 					}
 | |
| 
 | |
| 					$(target+' .modal-body').html('<div class="well"><iframe id="e-modal-iframe" width="100%" height="' + height + 'px" frameborder="0" scrolling="auto" style="display:block;background-color:transparent" allowtransparency="true" src="' + url + '"></iframe></div>');
 | |
| 					$(target+' .modal-caption').html(caption + ' <i id="e-modal-loading" class="fa fa-spin fa-spinner"></i>');
 | |
| 					$(target+'.modal').modal('show');
 | |
| 
 | |
| 					$("#e-modal-iframe").on("load", function ()
 | |
| 					{
 | |
| 						$('#e-modal-loading').hide();
 | |
| 
 | |
| 						if($this.attr('data-modal-submit'))
 | |
| 						{
 | |
| 							var buttonCaption = $('#e-modal-iframe').contents().find('#etrigger-submit').text(); // copy submit button caption from iframe form.
 | |
| 
 | |
| 							var buttonClass = $('#e-modal-iframe').contents().find('#etrigger-submit').attr('data-modal-submit-class'); // co
 | |
| 							if(buttonCaption)
 | |
| 							{
 | |
| 								$('#e-modal-submit').text(buttonCaption).fadeIn(); // display the button in the modal footer.
 | |
| 							}
 | |
| 
 | |
| 							if(buttonClass)
 | |
| 							{
 | |
| 								$('#e-modal-submit').addClass(buttonClass);
 | |
| 							}
 | |
| 
 | |
| 
 | |
| 							$('#e-modal-iframe').contents().find('.buttons-bar').hide(); // hide buttons in the iframe's form.
 | |
| 						}
 | |
| 
 | |
| 					});
 | |
| 
 | |
| 
 | |
| 
 | |
| 					return false;
 | |
| 				});
 | |
| 			});
 | |
| 		}
 | |
| 	};
 | |
| 
 | |
| 	/**
 | |
| 	 * Run tips on .field-help.
 | |
| 	 *
 | |
| 	 * @type {{attach: e107.behaviors.fieldHelpTooltip.attach}}
 | |
| 	 */
 | |
| 	e107.behaviors.fieldHelpTooltip = {
 | |
| 		attach: function (context, settings)
 | |
| 		{
 | |
| 			var selector = '.admin-ui-help-tip,div.tbox,div.checkboxes,input,textarea,select,.e-tip,div.form-control';
 | |
| 
 | |
| 			$(context).find(selector).once('field-help-tooltip').each(function ()
 | |
| 			{
 | |
| 				var $this = $(this);
 | |
| 				var $fieldHelp = $this.nextAll(".field-help");
 | |
| 				var placement = 'bottom';
 | |
| 
 | |
| 				if($this.is("textarea"))
 | |
| 				{
 | |
| 					placement = 'top';
 | |
| 				}
 | |
| 
 | |
| 				// custom position defined in field-help container class
 | |
| 				var custPlace = $fieldHelp.attr('data-placement'); // ie top|left|bottom|right
 | |
| 				if(custPlace !== undefined)
 | |
| 				{
 | |
| 					placement = custPlace;
 | |
| 				}
 | |
| 
 | |
| 				// custom position defined in selector tag.
 | |
| 				var pos = $(this).attr('data-tooltip-position');
 | |
| 				if(pos !== undefined)
 | |
| 				{
 | |
| 					placement = pos;
 | |
| 				}
 | |
| 				
 | |
| 
 | |
| 				$fieldHelp.hide();
 | |
| 
 | |
| 				$this.tooltip({
 | |
| 					title: function ()
 | |
| 					{
 | |
| 						return $fieldHelp.html();
 | |
| 					},
 | |
| 					fade: true,
 | |
| 					html: true,
 | |
| 					opacity: 1.0,
 | |
| 			//		trigger: 'hover focus',
 | |
| 					placement: placement,
 | |
| 					container: 'body',
 | |
| 					delay: {
 | |
| 						show: 0,
 | |
| 						hide: 600
 | |
| 					}
 | |
| 				});
 | |
| 			});
 | |
| 		}
 | |
| 	};
 | |
| 
 | |
| })(jQuery);
 | |
| 
 | |
| (function (jQuery)
 | |
| {
 | |
| 
 | |
| 	/**
 | |
| 	 * jQuery extension to make admin tab 'fadeIn' with 'display: inline-block'.
 | |
| 	 *
 | |
| 	 * @param displayMode
 | |
| 	 *  A string determining display mode for element after the animation.
 | |
| 	 *  Default: 'inline-block'.
 | |
| 	 * @param duration
 | |
| 	 *  A string or number determining how long the animation will run.
 | |
| 	 *  Default: 400.
 | |
| 	 */
 | |
| 	jQuery.fn.fadeInAdminTab = function (displayMode, duration)
 | |
| 	{
 | |
| 		var $this = $(this);
 | |
| 
 | |
| 		if($this.css('display') !== 'none')
 | |
| 		{
 | |
| 			return;
 | |
| 		}
 | |
| 
 | |
| 		displayMode = displayMode || 'inline-block';
 | |
| 		duration = duration || 400;
 | |
| 
 | |
| 		$this.fadeIn(duration, function ()
 | |
| 		{
 | |
| 			$this.css('display', displayMode);
 | |
| 		});
 | |
| 	};
 | |
| 
 | |
| })(jQuery);
 | |
| 
 | |
| 
 | |
| $(document).ready(function()
 | |
| {
 | |
|             $('a.e-spinner').on('click', function() {
 | |
| 
 | |
| 			  	var orig = $(this).text();
 | |
| 			  	var spin = "<i class='fa fa-spin fa-spinner fa-fw'></i>";
 | |
| 
 | |
| 				$(this).html(orig + spin);
 | |
|             });
 | |
| 
 | |
|             $('textarea').on("input", function(){
 | |
| 
 | |
|                 if($(this).attr("maxlength") === undefined)
 | |
|                 {
 | |
|                     return;
 | |
|                 }
 | |
| 
 | |
|                 var maxlength = $(this).attr("maxlength");
 | |
|                 var currentLength = $(this).val().length;
 | |
|                 var countID = $(this).attr('id') + '-char-count';
 | |
| 
 | |
|                 if( currentLength >= maxlength )
 | |
|                 {
 | |
|                    $('#'+ countID + ' span').text('0');
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     $('#'+ countID).show();
 | |
|                     $('#'+ countID + ' span').text(maxlength - currentLength);
 | |
|                 }
 | |
|             });
 | |
| 
 | |
| 
 | |
| 
 | |
| 			$('#e-modal-submit').click(function () {
 | |
| 			  $('#e-modal-iframe').contents().find('#etrigger-submit').trigger('click');
 | |
| 
 | |
| 			  	var type = $(this).data('loading-icon');
 | |
| 			  	var orig = $(this).text();
 | |
| 
 | |
| 				var caption = "<i class='fa fa-spin " + type + " fa-fw'></i>";
 | |
| 				caption += "<span>" + orig + "</span>";
 | |
| 
 | |
| 				$(this).html(caption);
 | |
| 
 | |
| 				  $('#e-modal-iframe').on('load', function(){
 | |
| 
 | |
| 				  	 var buttonFound = $('#e-modal-iframe').contents().find('#etrigger-submit');
 | |
| 
 | |
| 				  	if(buttonFound.length === 0) // disable resubmitting if not button found after submit.
 | |
| 				  	{
 | |
| 				  		$('#e-modal-submit').fadeOut(1000);
 | |
| 				  	}
 | |
| 
 | |
| 				  	$('#e-modal-submit').text(orig); // remove spinner.
 | |
| 
 | |
| 				  });
 | |
| 
 | |
| 			});
 | |
| 
 | |
| 			$('[data-dismiss="modal"]').click(function(){ // hide button for next modal popup usage.
 | |
| 
 | |
| 				$('#e-modal-submit').hide(1000);
 | |
| 
 | |
| 			});
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 		$('form').h5Validate(
 | |
| 			{ errorClass: 'has-error' }
 | |
| 		); // allow older browsers to use html5 validation. 
 | |
| 	
 | |
| 		// Change hash when a tab changes
 | |
| 		$('.nav-tabs a').on('shown', function (event) {
 | |
| 			var hash = event.target.href.toString().split('#')[1], form = $(event.target).parents('form')[0];
 | |
| 		    window.location.hash = '/' + hash;
 | |
| 		    if(form) {
 | |
| 				$(form).attr('action', $(form).attr('action').split('#')[0] + '#/' + hash);
 | |
| 		    }
 | |
| 		});
 | |
| 		
 | |
| 		// tabs hash
 | |
| 		if(/^#\/\w+/.test(window.location.hash)) {
 | |
| 			var hash = window.location.hash.substr(2);
 | |
| 			if(hash.match('^tab')){ $('.nav-tabs a[href=#' + hash + ']').tab('show'); }
 | |
| 		}
 | |
| 	
 | |
| 		$('.e-typeahead').each( function(){ 		
 | |
| 	
 | |
| 			var id = $(this).attr("id");
 | |
| 			var name = '#' + id.replace('-usersearch', '');
 | |
| 			var newval = $(this).attr("data-value");
 | |
| 			
 | |
| 			$(this).typeahead({
 | |
| 			source: $(this).attr("data-source"), 
 | |
| 			updater: function(text, type){
 | |
| 				if(type === 'value')
 | |
| 				{
 | |
| 					$(name).val(text);	
 | |
| 				}
 | |
| 				return text;	
 | |
| 				}
 | |
| 			});
 | |
| 		});
 | |
| 	
 | |
| 		/* Switch to Tab containing invalid form field. */
 | |
| 		$('input[type=submit],button[type=submit]').on('click', function() {
 | |
| 			
 | |
| 			var id 		= $(this).closest('form').attr('id');
 | |
| 			var found 	= false;
 | |
| 		       
 | |
| 			 $('#'+id).find('input:invalid,select:invalid,textarea:invalid').each(function(index, node) {
 | |
| 			
 | |
| 				var tab = $('#'+node.id).closest('.tab-pane').attr('id');
 | |
| 			
 | |
| 				if(tab && (found === false))
 | |
| 				{
 | |
| 					$('a[href="#'+tab+'"]').tab('show');
 | |
| 					found = true;
 | |
| 				//	alert(node.id+' : '+tab + ' '.index);
 | |
| 				}
 | |
| 			//   var label = $('label[for=' + node.id + ']');
 | |
|             });
 | |
|             
 | |
|             return true;
 | |
| 		});
 | |
| 	
 | |
| 	
 | |
| 
 | |
| 		// run tips on title attribute. 
 | |
| 		$(".e-tip").each(function() {
 | |
| 						
 | |
| 			
 | |
| 			var tip = $(this).attr('title');
 | |
| 			if(!tip)
 | |
| 			{
 | |
| 				return;
 | |
| 			}
 | |
| 			
 | |
| 			var pos = $(this).attr('data-placement'); 
 | |
| 			if(!pos)
 | |
| 			{
 | |
| 				pos = 'top';
 | |
| 			}
 | |
| 			
 | |
| 			$(this).tooltip({opacity:1.0,fade:true, placement: pos});
 | |
| 			// $(this).css( 'cursor', 'pointer' )
 | |
| 		});
 | |
| 		
 | |
| 		
 | |
| 		$("#uiModal").draggable({
 | |
|    			 handle: ".modal-header"
 | |
| 		});
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 	$('div.e-container').editable({
 | |
| 		selector: '.e-editable',
 | |
| 		params: function(params) {
 | |
| 			params.token = $(this).attr('data-token');
 | |
|            return params;
 | |
| 		},
 | |
| 		display: function (value, sourceData)
 | |
| 		{
 | |
| 			// HTML entities decoding... fix for:
 | |
| 			// @see https://github.com/e107inc/e107/issues/2351
 | |
| 			$.each(sourceData, function (index, element)
 | |
| 			{
 | |
| 				element.text = $("<div/>").html(element.text).text();
 | |
| 				sourceData[index] = element;
 | |
| 			});
 | |
| 
 | |
| 			// Display checklist as comma-separated values.
 | |
| 			var html = [];
 | |
| 			var checked = $.fn.editableutils.itemsByValue(value, sourceData);
 | |
| 
 | |
| 			if(checked.length)
 | |
| 			{
 | |
| 				$.each(checked, function (i, v)
 | |
| 				{
 | |
| 					html.push($.fn.editableutils.escape(v.text));
 | |
| 				});
 | |
| 
 | |
| 				$(this).html(html.join(', '));
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				$(this).text(value);
 | |
| 			}
 | |
| 		}
 | |
| 	});
 | |
| 		
 | |
| //		$('.e-editable').editable();
 | |
| 		
 | |
| 		// Fix for boostrap modal cache. 
 | |
| 		
 | |
| 	//	$('.modal').on('hidden',function(){
 | |
| 	//	    $(this).removeData('.modal');
 | |
| 		 //   $('#uiModal .modal-label').text('Loading');
 | |
| 		 //   $('#uiModal .modal-body').html('default_body');
 | |
| 	//	});
 | |
| 		
 | |
| 		$('body').on('hidden', '.modal', function () {
 | |
| 			$(this).removeData('modal');
 | |
| 			 $('#uiModal .modal-label').text('Loading...');
 | |
| 			$('#uiModal .modal-body').html(' ');
 | |
| 			});
 | |
| 		
 | |
| 		
 | |
| 		
 | |
| 			
 | |
| 		$('a[data-toggle="modal"]').on('click', function()
 | |
| 			{
 | |
| 				var link = $(this).attr('href');
 | |
| 				var caption  = $(this).attr('data-modal-caption');
 | |
| 				var height 		= ($(window).height() * 0.9) - 50;
 | |
| 				
 | |
| 				 $('#uiModal .modal-caption').text(caption);
 | |
| 				 $('.modal').height(height);
 | |
| 				// $('#uiModal .modal-label').text('Loading...');
 | |
| 				// $('#uiModal .modal-body').html(link);
 | |
| 				// alert(caption);
 | |
| 			}
 | |
| 		);
 | |
| 		
 | |
| 		
 | |
| 		$('button[data-loading-text],a[data-loading-text]').on('click', function()
 | |
| 			{
 | |
| 				var caption  = $(this).attr('data-loading-text');
 | |
| 				$(this).removeClass('btn-success');	
 | |
| 				$(this).removeClass('btn-primary');		
 | |
| 				$(this).html(caption);
 | |
| 				if($(this).attr('data-disable') == 'true')
 | |
| 				{	
 | |
| 					$(this).attr('disabled', 'disabled');
 | |
| 				}
 | |
| 				return true;
 | |
| 			}
 | |
| 		);
 | |
| 		
 | |
| 		$('input[data-loading-text]').on('click', function()
 | |
| 			{
 | |
| 				var caption  = $(this).attr('data-loading-text');	
 | |
| 				$(this).val(caption);
 | |
| 				$(this).removeClass('btn-success');	
 | |
| 				$(this).removeClass('btn-primary');		
 | |
| 				//$(this).attr('disabled', 'disabled').val(caption);
 | |
| 				return true;
 | |
| 			}
 | |
| 		);
 | |
| 
 | |
| 
 | |
| 		$('a[data-toggle-sidebar], .e-toggle-sidebar').on('click', function(e)
 | |
|         {
 | |
|             e.preventDefault();
 | |
| 
 | |
| 	        if ($(".is-table-row").hasClass("admin-left-panel-collapsed"))
 | |
| 	        {
 | |
| 		        $(".is-table-row").toggleClass("admin-left-panel-collapsed");
 | |
| 	        }
 | |
| 	        else
 | |
| 	        {
 | |
|                   $(".is-table-row").toggleClass("admin-left-panel-collapsed");
 | |
| 	        }
 | |
| 
 | |
| 
 | |
|             var tmp =  $(".is-table-row").hasClass("admin-left-panel-collapsed");
 | |
| 
 | |
|             if(tmp === true)
 | |
|             {
 | |
|                var toggleStatus = 'closed';
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                var toggleStatus = 'open';
 | |
|             }
 | |
| 
 | |
|             document.cookie = 'e107_adminLeftPanel = ' + toggleStatus +'; path=/; expires = 1; samesite=strict';
 | |
| 
 | |
| 
 | |
|         });
 | |
| 
 | |
| 
 | |
| 
 | |
| 		/* InfoPanel Comment approval and deletion */
 | |
| 		$(document).on("click", "button[data-comment-action]", function(){
 | |
| 				
 | |
| 				var url 	= $(this).attr("data-target");
 | |
| 				var action 	= $(this).attr('data-comment-action');	
 | |
| 				var id 		= $(this).attr("data-comment-id");
 | |
| 				var next	= $('#comment-'+ id).nextAll('.hide').attr("id");	
 | |
| 				
 | |
| 				$.ajax({
 | |
| 				  type: 'POST',
 | |
| 				  url: url + '?ajax_used=1&mode='+action,
 | |
| 				  data: { itemid: id },
 | |
| 				  success: function(data) {
 | |
| 				  	var a = $.parseJSON(data);
 | |
| 				 // 	alert(data);
 | |
| 					if(!a.error)
 | |
| 					{
 | |
| 						$('#comment-'+ id).hide(800, function () {
 | |
| 							$('#'+next).show('slow');
 | |
| 							$('#'+next).removeClass('hide');
 | |
| 						});
 | |
| 
 | |
| 					}
 | |
| 	
 | |
| 				  }
 | |
| 				});
 | |
| 				
 | |
| 				return false;
 | |
| 	
 | |
| 		});
 | |
| 
 | |
| 
 | |
| 		
 | |
| 
 | |
| 		var progresspump = null;
 | |
| 
 | |
| 		$('.e-progress-cancel').on('click', function(e) 
 | |
| 		{
 | |
| 			clearInterval(progresspump);
 | |
| 			var target	= $(this).attr('data-progress-target');
 | |
| 			$("#"+target).closest('.progress').removeClass("active");
 | |
| 			progresspump = null;
 | |
| 			alert('stopped');
 | |
| 		});
 | |
| 
 | |
| 		$('.e-progress').on('click', function(e) 
 | |
| 		{
 | |
| 		//	alert('Process Started');
 | |
| 
 | |
| 			var target	= $(this).attr('data-progress-target');
 | |
| 			var script 	= $(this).attr('data-progress');
 | |
| 			var show 	= $(this).attr('data-progress-show');
 | |
| 			var hide 	= $(this).attr('data-progress-hide');
 | |
| 			var mode 	= $(this).attr('data-progress-mode');
 | |
| 			var interval = $(this).attr('data-progress-interval');
 | |
| 			
 | |
| 			if(interval === undefined)
 | |
| 			{
 | |
| 				interval = 1000;	
 | |
| 			}
 | |
| 			
 | |
| 			$("#"+target).css('width','1%'); // so we know it's running.   
 | |
| 			
 | |
| 			progresspump = setInterval(function(){
 | |
| 		
 | |
| 			$.get(script, { mode: mode }).done( function(data){		  	  	
 | |
| 		  
 | |
| 				//	alert(data);
 | |
| 				$("#"+target).css('width', data+'%');   	// update the progress bar width */
 | |
| 				$("#"+target).html(data+'%');     		// display the numeric value */
 | |
| 
 | |
| 
 | |
| 		        data = parseInt(data);
 | |
| 
 | |
| 				if(data > 99.999) {
 | |
| 				
 | |
| 					clearInterval(progresspump);
 | |
| 			        $("#"+target).closest('.progress').removeClass("active");
 | |
| 
 | |
| 
 | |
| 			        
 | |
| 			        if(hide !== 'undefined')
 | |
| 			        {
 | |
| 						$('#'+hide).hide();	
 | |
| 			        }
 | |
| 			        
 | |
| 			        if(show !== 'undefined')
 | |
| 			        {
 | |
| 						$('#'+show).show('slow');	
 | |
| 			        }
 | |
| 
 | |
| 			         $("#"+target).html("Done");
 | |
| 		        
 | |
| 					}
 | |
| 		    
 | |
| 		     });  
 | |
| 
 | |
| 		  }, interval);
 | |
| 		});
 | |
| 		
 | |
| 		
 | |
| 		
 | |
| 		
 | |
| 		
 | |
| 
 | |
| 	/*
 | |
| 		
 | |
| 		$('a[data-toggle="modal"]').on('click', function()
 | |
| 		{
 | |
| 			$(this).removeData('modal');
 | |
| 			$('#uiModal .modal-header').text($(this).attr('title'));
 | |
| 			var link = $(this).attr('href');
 | |
| 			alert(link);
 | |
| 			$('#uiModal .modal-body').html( 'table' );
 | |
| 			//return false;
 | |
| 			
 | |
| 			return this;
 | |
| 			
 | |
| 			$('#uiModal .modal-body').load(link, function(response, status, xhr) 
 | |
| 		        {
 | |
| 		            if (status === 'error') 
 | |
| 		            {
 | |
| 		                //console.log('got here');
 | |
| 		                $('#uiModal .modal-body').html('<h2>Oh boy</h2><p>Sorry, but there was an error:' + xhr.status + ' ' + xhr.statusText+ '</p>');
 | |
| 		            }
 | |
| 		return false;
 | |
| 		            return this;
 | |
| 		        }
 | |
| 		    )
 | |
| 			
 | |
| 		});
 | |
| 		
 | |
| 		*/
 | |
| 
 | |
| 		
 | |
| 		
 | |
| 	
 | |
| 		
 | |
| 		
 | |
| 		$('.e-noclick').click(function(e) {
 | |
| 	    	e.stopPropagation();
 | |
| 	  	});
 | |
| 	
 | |
| 
 | |
| 		// BC Compatible 
 | |
| 		$("select.tbox").each(function() {
 | |
| 			
 | |
| 			var multi = $(this).attr('multiple');
 | |
| 			var tagName = $(this).attr('name');
 | |
| 
 | |
| 			if(multi === undefined)
 | |
| 			{
 | |
| 			//	 $(this).selectpicker();	// causes HTML5 validation alert to be hidden. 
 | |
| 				return;
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				$(this).multiselect({
 | |
| 					buttonClass: 'btn btn-default',
 | |
| 					 buttonText: function(options) {
 | |
| 						if (options.length == 0) {
 | |
| 
 | |
| 							return '(Optional) <b class="caret"></b><input type="hidden" name="' + tagName + '" value="" />'; // send empty value to server so value is saved.
 | |
| 						}
 | |
| 						else if (options.length > 5) {
 | |
| 							return options.length + ' selected <b class="caret"></b>';
 | |
| 						}
 | |
| 						else {
 | |
| 							var selected = '';
 | |
| 							options.each(function() {
 | |
| 								selected += $(this).text() + ', ';
 | |
| 							});
 | |
| 							return selected.substr(0, selected.length -2) + ' <b class="caret"></b>';
 | |
| 						}
 | |
| 					},
 | |
| 
 | |
| 
 | |
| 					});
 | |
| 			}
 | |
| 			
 | |
| 
 | |
| 			/*            optionLabel: function(element) {
 | |
|                 return $(element).html() + '(' + $(element).val() + ')';
 | |
|             }*/
 | |
| 			
 | |
| 		});
 | |
| 		
 | |
| 
 | |
| 	
 | |
| 	//	 $(".e-spinner").spinner(); //FIXME breaks tooltips etc. 
 | |
| 
 | |
| 
 | |
|     $(document).on("click", ".e-alert", function(){
 | |
| 			
 | |
| 			var message = $(this).html();
 | |
| 			alert(message);
 | |
| 			$("#uiAlert").val(message);
 | |
| 			$("#uiAlert").alert();
 | |
| 			$("#uiAlert").fadeIn('slow');
 | |
| 			window.setTimeout(function() { 	$("#uiAlert").alert('close'); }, 4000);
 | |
| 				
 | |
| 		});
 | |
| 		
 | |
| 	
 | |
| 	
 | |
| 	
 | |
| 	
 | |
| 		$(".e-radio-multi").each(function() {
 | |
| 		//	$(this).nextAll(".field-help").hide();
 | |
| 		//	$(this).nextAll(":input").tipsy({title: 'hello'});
 | |
| 			
 | |
| 		});
 | |
| 		
 | |
| 	//	$(".e-tags").tag();
 | |
| 		
 | |
| 		
 | |
| 
 | |
| 		// Decorate		
 | |
| 		$(".adminlist tr:even").addClass("even");
 | |
| 		$(".adminlist tr:odd").addClass("odd");
 | |
| 		$(".adminlist tr:first").addClass("first");
 | |
|   		$(".adminlist tr:last").addClass("last");
 | |
| 				
 | |
| 		
 | |
| 		
 | |
| 		// Admin Prefs Navigation
 | |
| 		
 | |
| 		 $(".plugin-navigation a").click(function () {
 | |
| 		 	$(".plugin-navigation a").each(function(index) {
 | |
|     			var ot = $(this).attr("href");
 | |
|     			if (ot.split('#')[1]) {
 | |
|                     $(ot).hide().removeClass('e-hideme');
 | |
|                 }
 | |
| 				$(this).closest("li").removeClass("active");
 | |
| 				$(this).switchClass( "link-active", "link", 0 );
 | |
| 			});
 | |
| 	   		var id = $(this).attr("href"), hash = id.split('#')[1], form = $('.admin-menu')[0]; // FIXME - a better way to detect the page form
 | |
| 	   		
 | |
| 			$(this).switchClass( "link", "link-active", 30 );
 | |
| 			$(this).closest("li").addClass("active");
 | |
| 
 | |
| 			// 'remember' the active navigation pane
 | |
| 			if(hash) {
 | |
|                 $(id).removeClass('e-hideme').show({
 | |
|                     effect: "slide"
 | |
|                 });
 | |
| 				window.location.hash = 'nav-' + hash;
 | |
| 			  	if(form) {
 | |
| 
 | |
| 			  //  	$(form).attr('action', $(form).attr('action').split('#')[0] + '#nav-' + hash); // breaks menu-manager nav.
 | |
| 			    }
 | |
| 			    return false; 
 | |
| 			}
 | |
| 		}); 
 | |
| 		
 | |
| 		// plugin navigation hash
 | |
| 		if(/^#nav-+/.test(window.location.hash)) {
 | |
| 			$("a[href='" + window.location.hash.replace('nav-', '') + "']").click();
 | |
| 		}
 | |
| 		
 | |
| 		// backend 
 | |
| 	/*
 | |
| 	    $(".e-password").pwdMeter({
 | |
| 	            minLength: 6,
 | |
| 	            displayGeneratePassword: true,
 | |
| 	            generatePassText: "Generate",
 | |
| 	            randomPassLength: 12
 | |
| 	    });*/
 | |
| 		
 | |
| 		
 | |
| 		
 | |
| 		// Sorting
 | |
| 		var fixHelper = function(e, ui) {
 | |
| 			ui.closest("tr").switchClass( "odd", "highlight-odd e-sort", 0 );
 | |
| 			ui.closest("tr").switchClass( "even", "highlight-even e-sort", 0 );
 | |
| 			ui.children().each(function() {
 | |
| 				$(this).width($(this).width());
 | |
| 			// 	$(this).closest("tr").switchClass( "odd", "highlight-odd", 0 );
 | |
| 			//	$(this).closest("tr").switchClass( "even", "highlight-even", 0 );
 | |
| 			});
 | |
| 			return ui;
 | |
| 		};
 | |
| 		
 | |
| 		$("#e-sort").sortable({
 | |
| 			helper: fixHelper,
 | |
| 			cursor: "move",
 | |
| 			opacity: 0.9,
 | |
| 			handle: ".e-sort",
 | |
| 			distance: 20,
 | |
| 			containment: "parent",
 | |
| 			stop: function(e,ui) {
 | |
| 			    var allItems = $(this).sortable("toArray");
 | |
| 			    var newSortValue = allItems.indexOf( $(ui.item).attr("id") );
 | |
| 			 //   alert($(ui.item).attr("id") + " was moved to index " + newSortValue);
 | |
| 			 	$(".highlight-even").switchClass( "highlight-even", "even", 600 );
 | |
| 				$(".highlight-odd").switchClass( "highlight-odd", "odd", 600 );
 | |
| 				$("tr.e-sort").removeClass( "e-sort");  
 | |
| 				  
 | |
| 			},
 | |
| 			
 | |
| 			update: function(event, ui) {         	
 | |
| 				var allItems = $(this).sortable("toArray");
 | |
| 			//	console.log(allItems);
 | |
| 				var neworder = allItems.indexOf( $(ui.item).attr("id") );
 | |
| 				var linkid = $(ui.item).attr("id"); 
 | |
| 			//	 $("td").removeClass("e-moving","slow"); 
 | |
| 			     	
 | |
| 				var script = $(".sort-trigger:first").attr("data-target"); 
 | |
| 
 | |
| 				$.ajax({
 | |
| 				  type: "POST",
 | |
| 				  url: script,
 | |
| 				  data: { all: allItems, linkid: linkid, neworder: neworder }
 | |
| 			//	  data: { linkid: linkid, neworder: neworder }
 | |
| 				}).done(function( msg ) {
 | |
| 				
 | |
| 				// alert("Posted: "+allItems+" Updated: "+ msg );
 | |
| 				});
 | |
| 
 | |
|  			}
 | |
| 		
 | |
| 		});	
 | |
| 	//	}).disableSelection(); // causes issue with admin->users drop-down selection. 
 | |
| 	
 | |
| 		
 | |
| 		// Check ALl Button
 | |
| 		$("#e-check-all").click(function(){
 | |
| 			$('input[type="checkbox"]').attr("checked", "checked");
 | |
| 		});
 | |
| 		
 | |
| 		// Uncheck all button. 
 | |
| 		$("#e-uncheck-all").click(function(){
 | |
| 			$('input[type="checkbox"]').removeAttr("checked");
 | |
| 		});
 | |
| 		
 | |
| 		
 | |
| 		
 | |
| 		// Check-All checkbox toggle
 | |
| 		$("input.toggle-all").click(function(evt) {
 | |
| 			var selector = 'input[type="checkbox"].checkbox';
 | |
| 
 | |
| 			if($(this).val().indexOf('jstarget:') === 0) {
 | |
| 				selector = 'input[type="checkbox"][name^="' + $(this).val().split(/jstarget\:/)[1] + '"]';
 | |
| 			}
 | |
| 
 | |
|  			if($(this).is(":checked")){
 | |
| 				//$(selector).attr("checked", "checked");
 | |
|                 $(selector).prop('checked', true);
 | |
| 			}
 | |
| 			else{
 | |
|                 $(selector).prop('checked',false);
 | |
| 			//	$(selector).removeAttr("checked");
 | |
| 			}
 | |
| 		});
 | |
| 
 | |
| 
 | |
|     $("ul.col-selection input[type='checkbox']").click(function(evt){
 | |
| 
 | |
|         if(this.checked)
 | |
|         {
 | |
|              $(this).closest("label").addClass( "active", 0 );
 | |
|         //    $(this).closest("tr.even").switchClass( "even", "highlight-even", 50 );
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             $(this).closest("label").removeClass( "active", 0 );
 | |
|         }
 | |
| 
 | |
|     });
 | |
| 		
 | |
| 		// highlight checked row
 | |
| 		$(".adminlist input[type='checkbox']").click(function(evt){
 | |
| 					
 | |
| 			if(this.checked)
 | |
| 			{
 | |
| 				$(this).closest("tr.odd").switchClass( "odd", "highlight-odd", 50 );	
 | |
| 				$(this).closest("tr.even").switchClass( "even", "highlight-even", 50 );	
 | |
|     		}
 | |
| 			else
 | |
| 			{
 | |
| 				$(this).closest("tr.highlight-odd").switchClass( "highlight-odd", "odd", 300 );	
 | |
| 				$(this).closest("tr.highlight-even").switchClass( "highlight-even", "even", 300 );	
 | |
| 			}	
 | |
| 			
 | |
| 		});
 | |
| 		
 | |
| 			
 | |
| 		
 | |
| 	
 | |
| 		// Basic Delete Confirmation
 | |
| 		/*
 | |
| 		$('input.delete,button.delete,a[data-confirm]').click(function(){
 | |
|   			answer = confirm($(this).attr("data-confirm"));
 | |
|   			return answer; // answer is a boolean
 | |
| 		});
 | |
| 	*/
 | |
| 		$(".e-confirm").click(function(){
 | |
|   			answer = confirm($(this).attr("title"));
 | |
|   			return answer; // answer is a boolean
 | |
| 		});
 | |
| 
 | |
| 
 | |
|         // see boot.php for main processing. (works only in admin)
 | |
|         $(".e-sef-generate").click(function(){
 | |
| 
 | |
|             src         = $(this).attr("data-src");
 | |
|             target      = $(this).attr("data-target");
 | |
|             toconvert   = $('#'+src).val();
 | |
|             script      = window.location;
 | |
|             confirmation = $(this).attr("data-sef-generate-confirm");
 | |
|             targetLength = $('#'+target).val().length ;
 | |
| 
 | |
|             if(confirmation !== undefined && targetLength > 0)
 | |
| 			{
 | |
| 				answer = confirm(confirmation);
 | |
| 
 | |
| 				if(answer === false)
 | |
| 				{
 | |
| 					return;
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 
 | |
| 
 | |
|             $.ajax({
 | |
|                 type: "POST",
 | |
|                 url: script,
 | |
|                 data: { source: toconvert, mode: 'sef' }
 | |
| 
 | |
|             }).done(function( data ) {
 | |
| 
 | |
|                 var a = $.parseJSON(data);
 | |
|           //      alert(a.converted);
 | |
|                 if(a.converted)
 | |
|                 {
 | |
|                     $('#'+target).val(a.converted);
 | |
| 
 | |
|                     //	$('#uiAlert').notify({
 | |
|                     //		type: 'success',
 | |
|                     //       message: { text: 'Completed' },
 | |
|                     //        fadeOut: { enabled: true, delay: 2000 }
 | |
|                     //    }).show();
 | |
| 
 | |
|                 }
 | |
|             });
 | |
| 
 | |
|         });
 | |
| 
 | |
| 
 | |
| 		$('body').on('slid.bs.carousel', '.carousel', function(){
 | |
| 
 | |
| 			var label = $(this).find('.carousel-item.active').attr('data-label');
 | |
| 			var id = $(this).attr('id') + '-index'; // admin-ui-carousel-index etc.
 | |
| 
 | |
| 			if(label !== undefined)
 | |
| 			{
 | |
| 				$('#'+id).text(label);
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				var currentIndex = $(this).find('.active').index();
 | |
| 				var text = (currentIndex + 1);
 | |
| 
 | |
| 				$('#'+id).text(text);
 | |
| 			}
 | |
| 
 | |
| 
 | |
| 			// this takes commented content for each carousel slide and enables it, one slide at a time as we scroll.
 | |
| 
 | |
| 			$(this).find('.item').each(function(index, node)
 | |
| 			{
 | |
| 				var content = $(this).contents();
 | |
| 
 | |
| 				var item = content[0];
 | |
| 
 | |
| 				if(item.nodeType === 8) // commented code @see e_media::browserCarousel() using '<!--'
 | |
| 				{
 | |
| 					$(item).replaceWith(item.nodeValue);
 | |
| 					return false;
 | |
| 				}
 | |
| 
 | |
| 			});
 | |
| 
 | |
| 		});
 | |
| 		
 | |
| 
 | |
| 		$(window).load(function() {
 | |
| 
 | |
| 			$('.carousel').each(function(){
 | |
| 
 | |
| 				$(this).carouselHeights();
 | |
| 
 | |
| 			});
 | |
| 
 | |
| 		});
 | |
| 
 | |
| 		// Normalize Bootstrap Carousel Heights
 | |
| 
 | |
| 		$.fn.carouselHeights = function() {
 | |
| 
 | |
| 			var items = $(this).find('.item'), // grab all slides
 | |
| 
 | |
| 				heights = [], // create empty array to store height values
 | |
| 
 | |
| 				tallest, // create variable to make note of the tallest slide
 | |
| 
 | |
| 				call;
 | |
| 
 | |
| 			var normalizeHeights = function() {
 | |
| 
 | |
| 				items.each(function() { // add heights to array
 | |
| 
 | |
| 					heights.push($(this).outerHeight());
 | |
| 
 | |
| 				});
 | |
| 
 | |
| 				tallest = Math.max.apply(null, heights); // cache largest value
 | |
| 
 | |
| 				items.css('height', tallest);
 | |
| 
 | |
| 			};
 | |
| 
 | |
| 			normalizeHeights();
 | |
| 
 | |
| 			$(window).on('resize orientationchange', function() {
 | |
| 
 | |
| 				// reset vars
 | |
| 
 | |
| 				tallest = 0;
 | |
| 
 | |
| 				heights.length = 0;
 | |
| 
 | |
| 				items.css('height', ''); // reset height
 | |
| 
 | |
| 				if(call){
 | |
| 
 | |
| 					clearTimeout(call);
 | |
| 
 | |
| 				};
 | |
| 
 | |
| 				call = setTimeout(normalizeHeights, 100); // run it again
 | |
| 
 | |
| 			});
 | |
| 
 | |
| 		};
 | |
| 
 | |
| 
 | |
| 
 | |
| 		$("a.menuManagerSelect").click(function(e){
 | |
| 
 | |
| 
 | |
| 			var link = $(this).attr('data-url');
 | |
| 			var layout= $(this).attr('data-layout');
 | |
| 
 | |
| 			$('#curLayout').val(layout);
 | |
| 			$('ul.e-mm-selector').hide();
 | |
| 			$('form#e-mm-selector').attr('action',link);
 | |
| 
 | |
| 			var text = $(this).text();
 | |
| 			$(this).html(text + ' <i class="e-mm-select-loading fa fa-spin fa-spinner"></i>');
 | |
| 
 | |
| 			$("#menu_iframe").attr("src",link);
 | |
| 
 | |
| 			$("#menu_iframe").on("load", function () {
 | |
| 				$('.e-mm-select-loading').hide();
 | |
| 			});
 | |
| 
 | |
| 
 | |
| 			return false;
 | |
| 		});
 | |
| 
 | |
| 
 | |
|     // Menu Manager Layout drop-down options
 | |
| 		$("#menuManagerSelect").change(function(){
 | |
| 			var link = $(this).val();
 | |
| 			$("#menu_iframe").attr("src",link);			
 | |
| 			return false;		
 | |
| 		});
 | |
| 
 | |
| 			
 | |
| 
 | |
| 		$("a.e-mm-selector").click(function(e){
 | |
| 
 | |
| 			 var hash = $('#curLayout').val();
 | |
| 			//	alert(hash);
 | |
| 
 | |
| 			var selector = 'ul.dropdown-menu.e-mm-selector.' + hash;
 | |
| 		
 | |
| 			$(selector).toggle();
 | |
| 
 | |
| 		//	$('.menu-selector input[type="checkbox"]').removeAttr("checked");
 | |
| 
 | |
| 			return false; 
 | |
| 		});
 | |
| 
 | |
| 		
 | |
| 
 | |
| 
 | |
| 		$(".e-mm-selector li input").click(function(e){
 | |
| 
 | |
| 			$("ul.dropdown-menu.e-mm-selector").css('display','none');
 | |
| 
 | |
| 		});
 | |
| 
 | |
| 		
 | |
| 		$(".e-shake" ).effect("shake",{times: 10, distance: 2},20);
 | |
| 		
 | |
| 		
 | |
| 		$("select.filter").change(function() {
 | |
| 			$(this).closest("form").submit();
 | |
| 		});
 | |
| 		
 | |
| 		
 | |
| 		$("div.e-autocomplete").keyup(function() { //TODO. 
 | |
| 				
 | |
| 			
 | |
| 		});
 | |
| 
 | |
| 
 | |
| 	$(function() {
 | |
| 		
 | |
| 		//$(".e-menumanager-delete").live("click", function(e){
 | |
| 		
 | |
| 			
 | |
| 			$( ".column" ).sortable({
 | |
| 				connectWith: ".column",
 | |
| 				constain: 'table',
 | |
| 		//	stop: function(e,ui) {
 | |
| 		//	    var allItems = $(this).sortable("toArray");
 | |
| 		//	    var newSortValue = allItems.indexOf( $(ui.item).attr("id") );
 | |
| 		//	   // alert($(ui.item).attr("id") + " was moved to index " + newSortValue);
 | |
| 	
 | |
| 		//	},
 | |
| 			cursor: "move",
 | |
| 			opacity: 0.9,
 | |
| 			handle: ".portlet-header",
 | |
| 			distance: 20,
 | |
| 			remove: function(event, ui) {
 | |
|                // ui.item.clone().appendTo(this);
 | |
|                //  $(this).sortable('cancel');
 | |
|            },
 | |
| 			stop: function(event, ui) {         	
 | |
| 				
 | |
| 				var linkid = $(ui.item).attr("id"); 
 | |
| 			    var area = $('#'+linkid).closest('.column').attr('id'); 
 | |
| 				var areaList = $('#'+linkid).closest('.column').sortable("toArray");
 | |
| 			    //  alert(areaList);
 | |
| 			    
 | |
| 			    $(ui.item).attr("id")
 | |
| 			    
 | |
| 			    var layout = $('#dbLayout').attr("value");
 | |
| 			    //	alert(layout);
 | |
| 			    	
 | |
| 			    var opt = linkid.split('-');
 | |
| 			    
 | |
| 			    if(area == 'remove')
 | |
| 			    {	// alert(area);
 | |
| 			    	var remove = linkid;
 | |
| 			    	areaList = '';
 | |
| 			    	$('#check-' + opt[1]).show('fast');
 | |
| 			    	$('#option-' + opt[1]).hide('fast');
 | |
| 			    	$('#status-' + opt[1]).text('remove');
 | |
| 			    }	
 | |
| 			    else
 | |
| 			    {	
 | |
| 			    	if($('#status-' + opt[1]).text() == 'insert' || $('#status-' + opt[1]).text() == 'update')
 | |
| 			    	{
 | |
| 			    		var stat = 'update';	
 | |
| 			    	}
 | |
| 			    	else
 | |
| 			    	{ 
 | |
| 			    		var stat = 'insert';
 | |
| 			    		
 | |
| 			    	}
 | |
| 			    	var aId = area.split('-');
 | |
| 			    	var newId =  linkid + '-' + aId[1];
 | |
| 			    	
 | |
| 			    	var remId = $('#'+linkid).find(".delete").attr('id') + aId[1];
 | |
| 			    	$('#'+linkid).find(".delete").attr('id',remId);
 | |
| 			    	var hidem = "block-" + opt[1] +'-' + aId[1];
 | |
| 			    	$('#'+linkid).attr('id',hidem);  	   	
 | |
| 	
 | |
| 			    	$('#check-' + opt[1]).hide('fast');
 | |
| 			    	$('#option-' + opt[1]).show('fast');
 | |
| 			    	$('#status-' + opt[1]).text(stat);	
 | |
| 			    }
 | |
| 			    		    
 | |
| 				$.ajax({
 | |
| 				  type: "POST",
 | |
| 				  url: "menus.php?ajax_used=1",
 | |
| 				  data: { removeid: remove, insert:linkid, mode: stat, list: areaList, area: area, layout: layout }
 | |
| 			//	  data: { linkid: linkid, neworder: neworder }
 | |
| 				}).done(function( msg ) {
 | |
| 				
 | |
| 				// alert(" Updated: "+ msg );
 | |
| 				});
 | |
| 
 | |
|  			}
 | |
| 		});
 | |
| 
 | |
| 		$( ".portlet" ).addClass( "ui-widget ui-widget-content ui-helper-clearfix ui-corner-all" )
 | |
| 	//	$( ".portlet" ).addClass( "ui-widget ui-widget-content ui-helper-clearfix ui-corner-all" )
 | |
| 			.find( ".portlet-header" )
 | |
| 				.addClass( "ui-widget-header ui-corner-all" )
 | |
| 				.prepend( "<span class='ui-icon ui-icon-minusthick'></span>")
 | |
| 				.end()
 | |
| 			.find( ".portlet-content" );
 | |
| 
 | |
| 		$( ".portlet-header .ui-icon" ).click(function() {
 | |
| 			$( this ).toggleClass( "ui-icon-minusthick" ).toggleClass( "ui-icon-plusthick" );
 | |
| 			$( this ).parents( ".portlet:first" ).find( ".portlet-content" ).toggle();
 | |
| 		});
 | |
| 
 | |
| 		$( ".column" ).disableSelection();
 | |
| 		});
 | |
| 
 | |
| 
 | |
| 
 | |
| 	
 | |
| 
 | |
| 
 | |
| 
 | |
| 		$.fn.extend({
 | |
|     	insertAtCaret: function(myValue) {
 | |
| 	        if (document.selection) {
 | |
| 	                this.focus();
 | |
| 	                sel = document.selection.createRange();
 | |
| 	                sel.text = myValue;
 | |
| 	                this.focus();
 | |
| 	        }
 | |
| 	        else if (this.selectionStart || this.selectionStart == '0') {
 | |
| 	            var startPos = this.selectionStart;
 | |
| 	            var endPos = this.selectionEnd;
 | |
| 	            var scrollTop = this.scrollTop;
 | |
| 	            this.value = this.value.substring(0, startPos)+myValue+this.value.substring(endPos,this.value.length);
 | |
| 	            this.focus();
 | |
| 	            this.selectionStart = startPos + myValue.length;
 | |
| 	            this.selectionEnd = startPos + myValue.length;
 | |
| 	            this.scrollTop = scrollTop;
 | |
| 		        } else {
 | |
| 		            this.value += myValue;
 | |
| 		            this.focus();
 | |
| 		        }
 | |
| 	    }
 | |
|     	
 | |
|   	
 | |
|     	
 | |
| })
 | |
| 
 | |
| 				// Text-area AutoGrow
 | |
| 	//	$("textarea.e-autoheight").elastic();
 | |
| });
 | |
| 
 | |
| 
 | |
| 
 |