HEX
Server: nginx/1.27.1
System: Linux in-4 5.15.0-131-generic #141-Ubuntu SMP Fri Jan 10 21:18:28 UTC 2025 x86_64
User: ilikadirect (1186)
PHP: 7.4.33
Disabled: exec,passthru,shell_exec,system,proc_open,popen,parse_ini_file,show_source
Upload Files
File: /storage/v6964/gopalak/public_html/wp-content/plugins/jobboardwp/assets/frontend/js/dropdown.js
(function ($) {

    /**
     * The constructor of the dropdown object
     * @param   {object}  element  The menu element.
     * @returns {object}           The dropdown menu object.
     */
    function JBDropdownMenu(element) {

        var self = {
            get: function(){
                return self;
            },

            show: function () {
                self.hideAll();

                /* add dropdown into the <body> */
                self.$menu = self.$element.find('.jb-dropdown');
                if ( !self.$menu.length ) {
                    self.$menu = $('div.jb-dropdown[data-element="' + self.data.element + '"]').first();
                }
                self.$dropdown = self.$menu.clone();
                self.$dropdown.on('click', 'li a', self.itemHandlerA); /* add the handler for menu items */
                self.$dropdown.on('click', 'li span', self.itemHandlerSpan); /* add the handler for menu items */
                $(window).on('resize', self.updatePosition); /* update the position on window resize */
                $(document.body).append(self.$dropdown);

                /* trigger event */
                self.$element.trigger('jb_dropdown_render', {
                    dropdown_layout: self.$dropdown,
                    trigger: self.data.trigger,
                    element: self.data.elemen,
                    obj: self.$element
                });

                /* set styles and show */
                self.$dropdown.css(self.calculatePosition()).show();
                self.$element.addClass('jb-dropdown-shown').data('jb-dropdown-show', true);

                return self;
            },

            hide: function () {
                if ( self.$dropdown && self.$dropdown.is(':visible') ) {
                    $(window).off('resize', self.updatePosition);
                    self.$dropdown.remove();
                    self.$element.removeClass('jb-dropdown-shown').data('jb-dropdown-show', false);
                }

                return self;
            },

            hideAll: function () {
                self.hide();
                $('body > div.jb-dropdown').remove();
                $('.jb-dropdown-shown').removeClass('jb-dropdown-shown').data('jb-dropdown-show', false);

                return self;
            },

            calculatePosition: function () {
                var offset = self.$element.offset(),
                    rect = self.$element.get(0).getBoundingClientRect(),
                    height = self.$dropdown.innerHeight() || 150,
                    width = self.$menu.data('width') || 150,
                    place = '';

                var css = {
                    position: 'absolute',
                    width: width + 'px'
                };

                /* vertical position */
                if ( window.innerHeight - rect.bottom > height ) {
                    css.top = offset.top + rect.height + 'px';
                    place += 'bottom';
                } else {
                    place += 'top';
                    css.top = offset.top - height + 'px';
                }

                /* horisontal position */
                if ( offset.left > width || offset.left > window.innerWidth / 2 ) {
                    css.left = offset.left + rect.width - width + 'px';
                    place += '-left';
                } else {
                    css.left = offset.left + 'px';
                    place += '-right';
                }

                /* border */
                switch ( place ) {
                    case 'bottom-right':
                        css.borderRadius = '0px 5px 5px 5px';
                        break;
                    case 'bottom-left':
                        css.borderRadius = '5px 0px 5px 5px';
                        break;
                    case 'top-right':
                        css.borderRadius = '5px 5px 5px 0px';
                        break;
                    case 'top-left':
                        css.borderRadius = '5px 5px 0px 5px';
                        break;
                }

                return css;
            },

            updatePosition: function () {
                if ( self.$dropdown && self.$dropdown.is(':visible') ) {
                    self.$dropdown.css(self.calculatePosition());
                }

                return self;
            },

			itemHandlerA: function (e) {
                e.stopPropagation();

                /* trigger 'click' in the original menu */
                var attrClass = $(e.currentTarget).attr('class');
                self.$menu.find('li a[class="' + attrClass + '"]').trigger('click');

                /* hide dropdown */
                self.hide();
            },
			itemHandlerSpan: function (e) {
				e.stopPropagation();
				// /* trigger 'click' in the original menu */
                var attrClass = $(e.currentTarget).attr('class');
				self.$menu.find('li span[class="' + attrClass + '"]').trigger('click');

                /* hide dropdown */
                self.hideAll();
            },

            triggerHandler: function (e) {
                e.stopPropagation();

                self.$element = $(e.currentTarget);

                if ( self.$element.data('jb-dropdown-show') ) {
                    self.hide();
                } else {
                    self.show();
                }
            }
        };

        self.$menu = $(element);

        self.data = self.$menu.data();
        self.data.width = self.$menu.data('width');

        self.$element = self.$menu.closest(self.data.element);
        if ( !self.$element.length ) {
            self.$element = $(self.data.element).first();
        }

        self.$dropdown = $(document.body).children('div[data-element="' + self.data.element + '"]');

        if ( typeof self.data.initted === 'undefined' ) {
            self.$menu.data('initted', true);
            $(document.body).on(self.data.trigger, self.data.element, self.triggerHandler);
        }

        if ( typeof JBDropdownMenu.globalHandlersInitted === 'undefined' ) {
            JBDropdownMenu.globalHandlersInitted = true;
            $(document.body).on('click', function (e) {
                if ( !$(e.target).closest('.jb-dropdown').length ) {
                    self.hideAll();
                }
            });
        }

        return self;
    }

    /* Add the method JBDropdownMenu() to the jQuery */
    $.fn.JBDropdownMenu = function (action) {
        if ( typeof action === 'string' && action ) {
            return this.map( function (i, menu) {
                var obj = JBDropdownMenu( menu );
                return typeof obj[action] === 'function' ? obj[action]() : obj[action];
            } ).toArray();
        } else {
            return this.each( function (i, menu) {
                JBDropdownMenu( menu );
            } );
        }
    };

})(jQuery);


function jb_init_dropdown() {
    jQuery('.jb-dropdown').JBDropdownMenu();
}

/* Init all dropdown menus on page load */
jQuery( function() {
	jb_init_dropdown();
} );