- GRAYBYTE UNDETECTABLE CODES -

403Webshell
Server IP : 184.154.167.98  /  Your IP : 18.223.125.226
Web Server : Apache
System : Linux pink.dnsnetservice.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64
User : puertode ( 1767)
PHP Version : 8.2.26
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : ON  |  Pkexec : ON
Directory :  /home/puertode/public_html/mesa/scp/js/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /home/puertode/public_html/mesa/scp/js/jb.overflow.menu.js
/*
 * jQuery UI jb.overflowmenu
 *
 * Copyright 2011, Jesse Baird <jebaird@gmail.com> jebaird.com
 * Dual licensed under the MIT or GPL Version 2 licenses.
 *
 * http://jebaird.com/blog/overflow-menu-jquery-ui-widget
 *
 * Depends:
 *   jquery.ui.core.js
 *   jquery.ui.widget.js
 *
 *
 * suggested markup
 * <nav>
 *  <ul>
 *      <li>
 *  </ul>
 * </nav>
 *
 * $('nav').overflowmenu()
 *
 *
 *
 * events
 *  change - after items are moved to / from the secondary menu
 *  beforeChange - called before items are moved to / from the secondary menu
 *  open - when the secondary menu is shown
 *  close - when the secondary menu is closed
 */

(function( $, undefined ) {

$.widget( "jb.overflowmenu", {
    options: {
        items: '> *',
        itemsParentTag: 'ul',
        label: '<i class="icon-ellipsis-vertical"></i>',
        //call the refresh method when this element changes size, with out a special event window is the only element that this gets called on
        refreshOn: $( window ),

        //attempt to guess the height of the menu, if not the target element needs to have a height
        guessHeight: true
    },

    _create: function() {
        var self = this;

        this.element
            .addClass('jb-overflowmenu');

        this.primaryMenu = this.element
                        .children( this.options.itemsParentTag )
                        .addClass( 'jb-overflowmenu-menu jb-overflowmenu-menu-primary jb-overflowmenu-helper-postion' );

        this._setHeight();

        //TODO: allow the user to change the markup for this because they might not be using ul -> li
        this.secondaryMenuContainer = $(
                            [
                                '<div class="jb-overflowmenu-container jb-overflowmenu-helper-postion">',
                                    '<a href="javascript://" class="jb-overflowmenu-menu-secondary-handle"></a>',
                                    '<' + this.options.itemsParentTag + ' class="jb-overflowmenu-menu jb-overflowmenu-menu-secondary jb-overflowmenu-helper-postion"></' + this.options.itemsParentTag + '>',
                                '</div>'
                            ].join('')
                        )
                        .appendTo( this.element )

        this.secondaryMenu = this.secondaryMenuContainer.find('ul');

        this.secondaryMenuContainer.children( 'a' ).bind( 'click.overflowmenu', function( e ){
            self.toggle();
        });

        //has to be set first
        this._setOption( 'label', this.options.label )
        this._setOption( 'refreshOn', this.options.refreshOn )
        this.secondaryMenuContainer.find('i.icon-sort-down').remove('i.icon-sort-down');
    },

    destroy: function() {
        this.element
            .removeClass('jb-overflowmenu')

        this.primaryMenu
            .removeClass('jb-overflowmenu-menu-primary jb-overflowmenu-helper-postion')
            .find( this.options.items )
            .filter( ':hidden' )
            .css( 'display', '' )

        this.options.refreshOn.unbind( 'resize.overflowmenu' );

        this.secondaryMenuContainer.remove()

        //TODO: possibly clean up the height & right on the ul

        $.Widget.prototype.destroy.apply( this, arguments );
    },


    refresh: function() {

        this._trigger( 'beforeChange', {}, this._uiHash() );

        //move any items in the secondary menu back in to the primary
        this.secondaryMenu
            .children()
            .appendTo( this.primaryMenu )


        var vHeight = this.primaryMenuHeight,
            hWidth = this.secondaryMenuContainer.find('.jb-overflowmenu-menu-secondary-handle')
                .outerWidth(),
            vWidth = this.primaryMenuWidth - hWidth,
            previousRight = this.primaryMenu.offset().left;

            // Items classed 'primary-only' should always be primary
            this._getItems()
                .each(function() {
                    var $this = $(this);
                    if ($this.hasClass('primary-only'))
                      vWidth -= $this.outerWidth(true);
                });

            //get the items, filter out the visible ones
            itemsToHide = this._getItems()
                .filter(function() {
                    var $this = $(this),
                        left = $this.offset().left,
                        dLeft = Math.max(0, left - previousRight);
                    previousRight = left + $this.width();

                    if ($this.hasClass('primary-only'))
                        return false;

                    vWidth -= dLeft + $this.outerWidth(true);
                    return vWidth < 1;
                });

        itemsToHide.appendTo( this.secondaryMenu )
            .find('i.icon-sort-down').remove('i.icon-sort-down');


        if( itemsToHide.length == 0 ){
            this.close();
        }

        //TODO: add the items to the UI Hash
        this._trigger( 'change', {}, this._uiHash() );
        return this;
    },

    //more menu opitons

    open: function(){
        if( this.secondaryMenu.find( this.options.items ).length == 0){
            return;
        }
        this.primaryMenu.css( 'right',  this.primaryMenu.data( 'right' ) )
        this.secondaryMenu.show();
        this._trigger( 'open', {}, this._uiHash() );
        return this;
    },
    close: function(){
        this.secondaryMenu.hide();
        this._trigger( 'close', {}, this._uiHash() );
        return this;
    },
    toggle: function(){
        if( this.secondaryMenu.is( ':visible') ){
            this.close();
        }else{
            this.open();
        }
        return this;
    },
    _getItems: function(){
        return this.primaryMenu.find( this.options.items );
    },
    _setHeight: function(){
        if( this.options.guessHeight ){
            //get the first items height and set that as the height of the parent
            this.primaryMenuHeight = this.primaryMenu.find( this.options.items ).filter(':first').outerHeight();
            this.primaryMenu.css('height', this.primaryMenuHeight )

        }else{
            this.primaryMenuHeight = this.element.innerHeight();
        }
        this.primaryMenuWidth = this.options.width ||
            this.element.innerWidth();

    },
    _setOption: function( key, value ) {
        var self = this;
        if( key == 'refreshOn' && value ){
            this.options.refreshOn.unbind( 'resize.overflowmenu' );

            this.options.refreshOn = $( value )
                                        .bind( 'resize.overflowmenu', function(){
                                            self.refresh();
                                        })
                                        //call to set option
                                        self.refresh();

        }else if( key == 'label' && value ){
            //figure out the width of the hadel and subtract that from the parend with and set that as the right

            var width = this.secondaryMenuContainer.find('.jb-overflowmenu-menu-secondary-handle')
                        .html( value )
                        .outerWidth();
            this.primaryMenu.data( 'right',  width )

        }

        $.Widget.prototype._setOption.apply( this, arguments );
    },
    _uiHash: function(){
        return {
            primary: this.primaryMenu,
            secondary: this.secondaryMenu,
            container: this.secondaryMenuContainer
        };
    }

});





})( jQuery );

Youez - 2016 - github.com/yon3zu
LinuXploit