Priority File Manager

📁 public_html
Base Directory:
/home/ecedu/public_html/wp-includes/js
NameTypeSizeActions
📁 .. Folder -
📄 admin-bar.js File 10547
Edit Download
📄 admin-bar.min.js File 3487
Edit Download
📄 api-request.js File 3324
Edit Download
📄 api-request.min.js File 1023
Edit Download
📄 autosave.js File 22476
Edit Download
📄 autosave.min.js File 5807
Edit Download
📄 backbone.js File 80390
Edit Download
📄 backbone.min.js File 24301
Edit Download
📄 clipboard.js File 26807
Edit Download
📄 clipboard.min.js File 9009
Edit Download
📁 codemirror Folder -
📄 colorpicker.js File 29083
Edit Download
📄 colorpicker.min.js File 16498
Edit Download
📄 comment-reply.js File 12513
Edit Download
📄 comment-reply.min.js File 3026
Edit Download
📁 crop Folder -
📄 customize-base.js File 25822
Edit Download
📄 customize-base.min.js File 7852
Edit Download
📄 customize-loader.js File 7903
Edit Download
📄 customize-loader.min.js File 3551
Edit Download
📄 customize-models.js File 6821
Edit Download
📄 customize-models.min.js File 3681
Edit Download
📄 customize-preview-nav-menus.js File 15024
Edit Download
📄 customize-preview-nav-menus.min.js File 5033
Edit Download
📄 customize-preview-widgets.js File 23253
Edit Download
📄 customize-preview-widgets.min.js File 7820
Edit Download
📄 customize-preview.js File 27960
Edit Download
📄 customize-preview.min.js File 10704
Edit Download
📄 customize-selective-refresh.js File 33335
Edit Download
📄 customize-selective-refresh.min.js File 10693
Edit Download
📄 customize-views.js File 5065
Edit Download
📄 customize-views.min.js File 2451
Edit Download
📁 dist Folder -
📄 heartbeat.js File 24052
Edit Download
📄 heartbeat.min.js File 5947
Edit Download
📄 hoverIntent.js File 7225
Edit Download
📄 hoverIntent.min.js File 1499
Edit Download
📄 hoverintent-js.min.js File 1718
Edit Download
📄 imagesloaded.min.js File 5520
Edit Download
📁 imgareaselect Folder -
📁 jcrop Folder -
📁 jquery Folder -
📄 json2.js File 18422
Edit Download
📄 json2.min.js File 3143
Edit Download
📄 masonry.min.js File 24138
Edit Download
📄 mce-view.js File 25849
Edit Download
📄 mce-view.min.js File 9770
Edit Download
📄 media-audiovideo.js File 24819
Edit Download
📄 media-audiovideo.min.js File 12052
Edit Download
📄 media-editor.js File 29119
Edit Download
📄 media-editor.min.js File 10885
Edit Download
📄 media-grid.js File 26651
Edit Download
📄 media-grid.min.js File 13258
Edit Download
📄 media-models.js File 43604
Edit Download
📄 media-models.min.js File 13284
Edit Download
📄 media-views.js File 273321
Edit Download
📄 media-views.min.js File 110712
Edit Download
📁 mediaelement Folder -
📁 plupload Folder -
📄 quicktags.js File 22601
Edit Download
📄 quicktags.min.js File 11132
Edit Download
📄 shortcode.js File 10758
Edit Download
📄 shortcode.min.js File 2643
Edit Download
📄 swfobject.js File 10231
Edit Download
📁 swfupload Folder -
📁 thickbox Folder -
📁 tinymce Folder -
📄 tw-sack.js File 4969
Edit Download
📄 tw-sack.min.js File 3288
Edit Download
📄 twemoji.js File 33459
Edit Download
📄 twemoji.min.js File 16312
Edit Download
📄 underscore.js File 68735
Edit Download
📄 underscore.min.js File 18905
Edit Download
📄 utils.js File 4665
Edit Download
📄 utils.min.js File 1864
Edit Download
📄 wp-ajax-response.js File 3903
Edit Download
📄 wp-ajax-response.min.js File 2571
Edit Download
📄 wp-api.js File 46983
Edit Download
📄 wp-api.min.js File 14682
Edit Download
📄 wp-auth-check.js File 4207
Edit Download
📄 wp-auth-check.min.js File 1658
Edit Download
📄 wp-backbone.js File 15241
Edit Download
📄 wp-backbone.min.js File 3039
Edit Download
📄 wp-custom-header.js File 10465
Edit Download
📄 wp-custom-header.min.js File 4442
Edit Download
📄 wp-embed-template.js File 6779
Edit Download
📄 wp-embed-template.min.js File 3174
Edit Download
📄 wp-embed.js File 3214
Edit Download
📄 wp-embed.min.js File 1251
Edit Download
📄 wp-emoji-loader.js File 14009
Edit Download
📄 wp-emoji-loader.min.js File 3088
Edit Download
📄 wp-emoji-release.min.js File 19251
Edit Download
📄 wp-emoji.js File 8969
Edit Download
📄 wp-emoji.min.js File 2890
Edit Download
📄 wp-list-revisions.js File 970
Edit Download
📄 wp-list-revisions.min.js File 597
Edit Download
📄 wp-lists.js File 25315
Edit Download
📄 wp-lists.min.js File 7521
Edit Download
📄 wp-pointer.js File 10233
Edit Download
📄 wp-pointer.min.js File 3621
Edit Download
📄 wp-sanitize.js File 1341
Edit Download
📄 wp-sanitize.min.js File 458
Edit Download
📄 wp-util.js File 4679
Edit Download
📄 wp-util.min.js File 1426
Edit Download
📄 wpdialog.js File 569
Edit Download
📄 wpdialog.min.js File 281
Edit Download
📄 wplink.js File 21240
Edit Download
📄 wplink.min.js File 11317
Edit Download
📄 zxcvbn-async.js File 821
Edit Download
📄 zxcvbn-async.min.js File 351
Edit Download
📄 zxcvbn.min.js File 822237
Edit Download

View File: admin-bar.js

/**
 * @output wp-includes/js/admin-bar.js
 */
/**
 * Admin bar with Vanilla JS, no external dependencies.
 *
 * @since 5.3.1
 *
 * @param {Object} document  The document object.
 * @param {Object} window    The window object.
 * @param {Object} navigator The navigator object.
 *
 * @return {void}
 */
( function( document, window, navigator ) {
	document.addEventListener( 'DOMContentLoaded', function() {
		var adminBar = document.getElementById( 'wpadminbar' ),
			topMenuItems,
			allMenuItems,
			adminBarLogout,
			adminBarSearchForm,
			shortlink,
			skipLink,
			mobileEvent,
			adminBarSearchInput,
			i;

		if ( ! adminBar || ! ( 'querySelectorAll' in adminBar ) ) {
			return;
		}

		topMenuItems = adminBar.querySelectorAll( 'li.menupop' );
		allMenuItems = adminBar.querySelectorAll( '.ab-item' );
		adminBarLogout = document.querySelector( '#wp-admin-bar-logout a' );
		adminBarSearchForm = document.getElementById( 'adminbarsearch' );
		shortlink = document.getElementById( 'wp-admin-bar-get-shortlink' );
		skipLink = adminBar.querySelector( '.screen-reader-shortcut' );
		mobileEvent = /Mobile\/.+Safari/.test( navigator.userAgent ) ? 'touchstart' : 'click';

		// Remove nojs class after the DOM is loaded.
		removeClass( adminBar, 'nojs' );

		if ( 'ontouchstart' in window ) {
			// Remove hover class when the user touches outside the menu items.
			document.body.addEventListener( mobileEvent, function( e ) {
				if ( ! getClosest( e.target, 'li.menupop' ) ) {
					removeAllHoverClass( topMenuItems );
				}
			} );

			// Add listener for menu items to toggle hover class by touches.
			// Remove the callback later for better performance.
			adminBar.addEventListener( 'touchstart', function bindMobileEvents() {
				for ( var i = 0; i < topMenuItems.length; i++ ) {
					topMenuItems[i].addEventListener( 'click', mobileHover.bind( null, topMenuItems ) );
				}

				adminBar.removeEventListener( 'touchstart', bindMobileEvents );
			} );
		}

		// Scroll page to top when clicking on the admin bar.
		adminBar.addEventListener( 'click', scrollToTop );

		for ( i = 0; i < topMenuItems.length; i++ ) {
			// Adds or removes the hover class based on the hover intent.
			window.hoverintent(
				topMenuItems[i],
				addClass.bind( null, topMenuItems[i], 'hover' ),
				removeClass.bind( null, topMenuItems[i], 'hover' )
			).options( {
				timeout: 180
			} );

			// Toggle hover class if the enter key is pressed.
			topMenuItems[i].addEventListener( 'keydown', toggleHoverIfEnter );
		}

		// Remove hover class if the escape key is pressed.
		for ( i = 0; i < allMenuItems.length; i++ ) {
			allMenuItems[i].addEventListener( 'keydown', removeHoverIfEscape );
		}

		if ( adminBarSearchForm ) {
			adminBarSearchInput = document.getElementById( 'adminbar-search' );

			// Adds the adminbar-focused class on focus.
			adminBarSearchInput.addEventListener( 'focus', function() {
				addClass( adminBarSearchForm, 'adminbar-focused' );
			} );

			// Removes the adminbar-focused class on blur.
			adminBarSearchInput.addEventListener( 'blur', function() {
				removeClass( adminBarSearchForm, 'adminbar-focused' );
			} );
		}

		if ( shortlink ) {
			shortlink.addEventListener( 'click', clickShortlink );
		}

		// Prevents the toolbar from covering up content when a hash is present in the URL.
		if ( window.location.hash ) {
			window.scrollBy( 0, -32 );
		}

		// Clear sessionStorage on logging out.
		if ( adminBarLogout ) {
			adminBarLogout.addEventListener( 'click', emptySessionStorage );
		}
	} );

	/**
	 * Remove hover class for top level menu item when escape is pressed.
	 *
	 * @since 5.3.1
	 *
	 * @param {Event} event The keydown event.
	 */
	function removeHoverIfEscape( event ) {
		var wrapper;

		if ( event.which !== 27 ) {
			return;
		}

		wrapper = getClosest( event.target, '.menupop' );

		if ( ! wrapper ) {
			return;
		}

		wrapper.querySelector( '.menupop > .ab-item' ).focus();
		removeClass( wrapper, 'hover' );
	}

	/**
	 * Toggle hover class for top level menu item when enter is pressed.
	 *
	 * @since 5.3.1
	 *
	 * @param {Event} event The keydown event.
	 */
	function toggleHoverIfEnter( event ) {
		var wrapper;

		// Follow link if pressing Ctrl and/or Shift with Enter (opening in a new tab or window).
		if ( event.which !== 13 || event.ctrlKey || event.shiftKey ) {
			return;
		}

		if ( !! getClosest( event.target, '.ab-sub-wrapper' ) ) {
			return;
		}

		wrapper = getClosest( event.target, '.menupop' );

		if ( ! wrapper ) {
			return;
		}

		event.preventDefault();

		if ( hasClass( wrapper, 'hover' ) ) {
			removeClass( wrapper, 'hover' );
		} else {
			addClass( wrapper, 'hover' );
		}
	}

	/**
	 * Toggle hover class for mobile devices.
	 *
	 * @since 5.3.1
	 *
	 * @param {NodeList} topMenuItems All menu items.
	 * @param {Event} event The click event.
	 */
	function mobileHover( topMenuItems, event ) {
		var wrapper;

		if ( !! getClosest( event.target, '.ab-sub-wrapper' ) ) {
			return;
		}

		event.preventDefault();

		wrapper = getClosest( event.target, '.menupop' );

		if ( ! wrapper ) {
			return;
		}

		if ( hasClass( wrapper, 'hover' ) ) {
			removeClass( wrapper, 'hover' );
		} else {
			removeAllHoverClass( topMenuItems );
			addClass( wrapper, 'hover' );
		}
	}

	/**
	 * Handles the click on the Shortlink link in the adminbar.
	 *
	 * @since 3.1.0
	 * @since 5.3.1 Use querySelector to clean up the function.
	 *
	 * @param {Event} event The click event.
	 * @return {boolean} Returns false to prevent default click behavior.
	 */
	function clickShortlink( event ) {
		var wrapper = event.target.parentNode,
			input;

		if ( wrapper ) {
			input = wrapper.querySelector( '.shortlink-input' );
		}

		if ( ! input ) {
			return;
		}

		// (Old) IE doesn't support preventDefault, and does support returnValue.
		if ( event.preventDefault ) {
			event.preventDefault();
		}

		event.returnValue = false;

		addClass( wrapper, 'selected' );

		input.focus();
		input.select();
		input.onblur = function() {
			removeClass( wrapper, 'selected' );
		};

		return false;
	}

	/**
	 * Clear sessionStorage on logging out.
	 *
	 * @since 5.3.1
	 */
	function emptySessionStorage() {
		if ( 'sessionStorage' in window ) {
			try {
				for ( var key in sessionStorage ) {
					if ( key.indexOf( 'wp-autosave-' ) > -1 ) {
						sessionStorage.removeItem( key );
					}
				}
			} catch ( er ) {}
		}
	}

	/**
	 * Check if element has class.
	 *
	 * @since 5.3.1
	 *
	 * @param {HTMLElement} element The HTML element.
	 * @param {string}      className The class name.
	 * @return {boolean} Whether the element has the className.
	 */
	function hasClass( element, className ) {
		var classNames;

		if ( ! element ) {
			return false;
		}

		if ( element.classList && element.classList.contains ) {
			return element.classList.contains( className );
		} else if ( element.className ) {
			classNames = element.className.split( ' ' );
			return classNames.indexOf( className ) > -1;
		}

		return false;
	}

	/**
	 * Add class to an element.
	 *
	 * @since 5.3.1
	 *
	 * @param {HTMLElement} element The HTML element.
	 * @param {string}      className The class name.
	 */
	function addClass( element, className ) {
		if ( ! element ) {
			return;
		}

		if ( element.classList && element.classList.add ) {
			element.classList.add( className );
		} else if ( ! hasClass( element, className ) ) {
			if ( element.className ) {
				element.className += ' ';
			}

			element.className += className;
		}

		var menuItemToggle = element.querySelector( 'a' );
		if ( className === 'hover' && menuItemToggle && menuItemToggle.hasAttribute( 'aria-expanded' ) ) {
			menuItemToggle.setAttribute( 'aria-expanded', 'true' );
		}
	}

	/**
	 * Remove class from an element.
	 *
	 * @since 5.3.1
	 *
	 * @param {HTMLElement} element The HTML element.
	 * @param {string}      className The class name.
	 */
	function removeClass( element, className ) {
		var testName,
			classes;

		if ( ! element || ! hasClass( element, className ) ) {
			return;
		}

		if ( element.classList && element.classList.remove ) {
			element.classList.remove( className );
		} else {
			testName = ' ' + className + ' ';
			classes = ' ' + element.className + ' ';

			while ( classes.indexOf( testName ) > -1 ) {
				classes = classes.replace( testName, '' );
			}

			element.className = classes.replace( /^[\s]+|[\s]+$/g, '' );
		}

		var menuItemToggle = element.querySelector( 'a' );
		if ( className === 'hover' && menuItemToggle && menuItemToggle.hasAttribute( 'aria-expanded' ) ) {
			menuItemToggle.setAttribute( 'aria-expanded', 'false' );
		}
	}

	/**
	 * Remove hover class for all menu items.
	 *
	 * @since 5.3.1
	 *
	 * @param {NodeList} topMenuItems All menu items.
	 */
	function removeAllHoverClass( topMenuItems ) {
		if ( topMenuItems && topMenuItems.length ) {
			for ( var i = 0; i < topMenuItems.length; i++ ) {
				removeClass( topMenuItems[i], 'hover' );
			}
		}
	}

	/**
	 * Scrolls to the top of the page.
	 *
	 * @since 3.4.0
	 *
	 * @param {Event} event The Click event.
	 *
	 * @return {void}
	 */
	function scrollToTop( event ) {
		// Only scroll when clicking on the wpadminbar, not on menus or submenus.
		if (
			event.target &&
			event.target.id !== 'wpadminbar' &&
			event.target.id !== 'wp-admin-bar-top-secondary'
		) {
			return;
		}

		try {
			window.scrollTo( {
				top: -32,
				left: 0,
				behavior: 'smooth'
			} );
		} catch ( er ) {
			window.scrollTo( 0, -32 );
		}
	}

	/**
	 * Get closest Element.
	 *
	 * @since 5.3.1
	 *
	 * @param {HTMLElement} el Element to get parent.
	 * @param {string} selector CSS selector to match.
	 */
	function getClosest( el, selector ) {
		if ( ! window.Element.prototype.matches ) {
			// Polyfill from https://developer.mozilla.org/en-US/docs/Web/API/Element/matches.
			window.Element.prototype.matches =
				window.Element.prototype.matchesSelector ||
				window.Element.prototype.mozMatchesSelector ||
				window.Element.prototype.msMatchesSelector ||
				window.Element.prototype.oMatchesSelector ||
				window.Element.prototype.webkitMatchesSelector ||
				function( s ) {
					var matches = ( this.document || this.ownerDocument ).querySelectorAll( s ),
						i = matches.length;

					while ( --i >= 0 && matches.item( i ) !== this ) { }

					return i > -1;
				};
		}

		// Get the closest matching elent.
		for ( ; el && el !== document; el = el.parentNode ) {
			if ( el.matches( selector ) ) {
				return el;
			}
		}

		return null;
	}

} )( document, window, navigator );