HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux aritmodecarnaval.es 5.15.0-79-generic #86-Ubuntu SMP Mon Jul 10 16:07:21 UTC 2023 x86_64
User: www-data (33)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /home/www/terrazasgreen2/wp-content/plugins/wp-nested-pages/assets/js/lib/nestedpages.dropdowns.js
var NestedPages = NestedPages || {};
/**
* Dropdowns
* 
* @author Kyle Phillips
* 
* To use, wrap dropdown content and toggle link/button in an element with data attribute of data-dropdown
* Give content data attribute of data-dropdown-content and toggle element data attribute of data-dropdown-toggle
* For CSS, wrapping/parent element gets class of "dropdown", content gets class of "dropdown-content"
*/
NestedPages.Dropdowns = function()
{
	var self = this;
	var $ = jQuery;

	self.dropdown = ''; // The Active Dropdown
	self.activeBtn = ''; // The Active Button
	self.activeContent = ''; // The Active Dropdown Content
	self.toggleBtn = '[data-dropdown-toggle]';
	self.dropdownContainer = '[data-dropdown]';
	self.dropdownContent = '[data-dropdown-content]'

	self.selectors = {
		caret_up : 'icon-arrow_drop_up',
		caret_down : 'icon-arrow_drop_down'
	}

	self.bindEvents = function()
	{
		$(document).on('click', self.toggleBtn, function(e){
			e.preventDefault();
			self.activeBtn = $(this);
			self.dropdown = $(this).parents(self.dropdownContainer);
			self.toggleDropdown();
		});
		$(document).on('click', function(e){
			self.closeDropdowns(e.target);
		});
		$(document).on('dropdown-opened', function(e, content){
			if ( $(content).parents(NestedPages.selectors.row).length > 0 ){
				$(content).parents(NestedPages.selectors.row).addClass('active');
			}
		});
		$(document).on('dropdown-closed', function(){
			$(NestedPages.selectors.row).removeClass('active');
		});
	}

	self.toggleDropdown = function()
	{
		$('.' + self.selectors.caret_up).attr('class', self.selectors.caret_down);
		var content = $(self.dropdown).find(self.dropdownContent);
		self.activeContent = content;
		if ( $(content).hasClass('active') ){
			$(content).removeClass('active');
			$(self.activeBtn).removeClass('active');
			$(self.activeBtn).find('.' + self.selectors.caret_up).attr('class', self.selectors.caret_down);
			$(document).trigger('dropdown-closed', content);
			return;
		}
		self.setPositioning();
		$(self.toggleBtn).removeClass('active');
		$(self.dropdownContent).removeClass('active');
		$(content).addClass('active');
		$(self.activeBtn).find('.' + self.selectors.caret_down).attr('class', self.selectors.caret_up);
		$(self.activeBtn).addClass('active');
		$(document).trigger('dropdown-opened', content);
	}


	self.setPositioning = function()
	{
		var buttonHeight = $(self.activeBtn).outerHeight();
		$(self.activeContent).css('top', buttonHeight + 'px');
	}

	self.closeDropdowns = function(target)
	{
		if ( $(target).parents(self.dropdownContainer).length === 0 ){
			$(self.dropdownContent).removeClass('active');
			$(self.toggleBtn).removeClass('active');
			$(self.activeBtn).find('.' + self.selectors.caret_up).attr('class', self.selectors.caret_down);
			var content;
			$(document).trigger('dropdown-closed', content);
		}
	}

	return self.bindEvents();
}