[ Avaa Bypassed ]




Upload:

Command:

hmhc3928@18.222.115.155: ~ $
/**
 * Handle the site icon setting in options-general.php.
 *
 * @since 6.5.0
 * @output wp-admin/js/site-icon.js
 */

/* global jQuery, wp */

( function ( $ ) {
	var $chooseButton = $( '#choose-from-library-button' ),
		$iconPreview = $( '#site-icon-preview' ),
		$browserIconPreview = $( '#browser-icon-preview' ),
		$appIconPreview = $( '#app-icon-preview' ),
		$hiddenDataField = $( '#site_icon_hidden_field' ),
		$removeButton = $( '#js-remove-site-icon' ),
		frame;

	/**
	 * Calculate image selection options based on the attachment dimensions.
	 *
	 * @since 6.5.0
	 *
	 * @param {Object} attachment The attachment object representing the image.
	 * @return {Object} The image selection options.
	 */
	function calculateImageSelectOptions( attachment ) {
		var realWidth = attachment.get( 'width' ),
			realHeight = attachment.get( 'height' ),
			xInit = 512,
			yInit = 512,
			ratio = xInit / yInit,
			xImg = xInit,
			yImg = yInit,
			x1,
			y1,
			imgSelectOptions;

		if ( realWidth / realHeight > ratio ) {
			yInit = realHeight;
			xInit = yInit * ratio;
		} else {
			xInit = realWidth;
			yInit = xInit / ratio;
		}

		x1 = ( realWidth - xInit ) / 2;
		y1 = ( realHeight - yInit ) / 2;

		imgSelectOptions = {
			aspectRatio: xInit + ':' + yInit,
			handles: true,
			keys: true,
			instance: true,
			persistent: true,
			imageWidth: realWidth,
			imageHeight: realHeight,
			minWidth: xImg > xInit ? xInit : xImg,
			minHeight: yImg > yInit ? yInit : yImg,
			x1: x1,
			y1: y1,
			x2: xInit + x1,
			y2: yInit + y1,
		};

		return imgSelectOptions;
	}

	/**
	 * Initializes the media frame for selecting or cropping an image.
	 *
	 * @since 6.5.0
	 */
	$chooseButton.on( 'click', function () {
		var $el = $( this );

		// Create the media frame.
		frame = wp.media( {
			button: {
				// Set the text of the button.
				text: $el.data( 'update' ),

				// Don't close, we might need to crop.
				close: false,
			},
			states: [
				new wp.media.controller.Library( {
					title: $el.data( 'choose-text' ),
					library: wp.media.query( { type: 'image' } ),
					date: false,
					suggestedWidth: $el.data( 'size' ),
					suggestedHeight: $el.data( 'size' ),
				} ),
				new wp.media.controller.SiteIconCropper( {
					control: {
						params: {
							width: $el.data( 'size' ),
							height: $el.data( 'size' ),
						},
					},
					imgSelectOptions: calculateImageSelectOptions,
				} ),
			],
		} );

		frame.on( 'cropped', function ( attachment ) {
			$hiddenDataField.val( attachment.id );
			switchToUpdate( attachment );
			frame.close();

			// Start over with a frame that is so fresh and so clean clean.
			frame = null;
		} );

		// When an image is selected, run a callback.
		frame.on( 'select', function () {
			// Grab the selected attachment.
			var attachment = frame.state().get( 'selection' ).first();

			if (
				attachment.attributes.height === $el.data( 'size' ) &&
				$el.data( 'size' ) === attachment.attributes.width
			) {
				switchToUpdate( attachment.attributes );
				frame.close();

				// Set the value of the hidden input to the attachment id.
				$hiddenDataField.val( attachment.id );
			} else {
				frame.setState( 'cropper' );
			}
		} );

		frame.open();
	} );

	/**
	 * Update the UI when a site icon is selected.
	 *
	 * @since 6.5.0
	 *
	 * @param {array} attributes The attributes for the attachment.
	 */
	function switchToUpdate( attributes ) {
		var i18nAppAlternativeString, i18nBrowserAlternativeString;

		if ( attributes.alt ) {
			i18nAppAlternativeString = wp.i18n.sprintf(
				/* translators: %s: The selected image alt text. */
				wp.i18n.__( 'App icon preview: Current image: %s' ),
				attributes.alt
			);
			i18nBrowserAlternativeString = wp.i18n.sprintf(
				/* translators: %s: The selected image alt text. */
				wp.i18n.__( 'Browser icon preview: Current image: %s' ),
				attributes.alt
			);
		} else {
			i18nAppAlternativeString = wp.i18n.sprintf(
				/* translators: %s: The selected image filename. */
				wp.i18n.__(
					'App icon preview: The current image has no alternative text. The file name is: %s'
				),
				attributes.filename
			);
			i18nBrowserAlternativeString = wp.i18n.sprintf(
				/* translators: %s: The selected image filename. */
				wp.i18n.__(
					'Browser icon preview: The current image has no alternative text. The file name is: %s'
				),
				attributes.filename
			);
		}

		// Set site-icon-img src and alternative text to app icon preview.
		$appIconPreview.attr( {
			src: attributes.url,
			alt: i18nAppAlternativeString,
		} );

		// Set site-icon-img src and alternative text to browser preview.
		$browserIconPreview.attr( {
			src: attributes.url,
			alt: i18nBrowserAlternativeString,
		} );

		// Remove hidden class from icon preview div and remove button.
		$iconPreview.removeClass( 'hidden' );
		$removeButton.removeClass( 'hidden' );

		// Set the global CSS variable for --site-icon-url to the selected image URL.
		document.documentElement.style.setProperty(
			'--site-icon-url',
			'url(' + attributes.url + ')'
		);

		// If the choose button is not in the update state, swap the classes.
		if ( $chooseButton.attr( 'data-state' ) !== '1' ) {
			$chooseButton.attr( {
				class: $chooseButton.attr( 'data-alt-classes' ),
				'data-alt-classes': $chooseButton.attr( 'class' ),
				'data-state': '1',
			} );
		}

		// Swap the text of the choose button.
		$chooseButton.text( $chooseButton.attr( 'data-update-text' ) );
	}

	/**
	 * Handles the click event of the remove button.
	 *
	 * @since 6.5.0
	 */
	$removeButton.on( 'click', function () {
		$hiddenDataField.val( 'false' );
		$( this ).toggleClass( 'hidden' );
		$iconPreview.toggleClass( 'hidden' );
		$browserIconPreview.attr( {
			src: '',
			alt: '',
		} );
		$appIconPreview.attr( {
			src: '',
			alt: '',
		} );

		/**
		 * Resets state to the button, for correct visual style and state.
		 * Updates the text of the button.
		 * Sets focus state to the button.
		 */
		$chooseButton
			.attr( {
				class: $chooseButton.attr( 'data-alt-classes' ),
				'data-alt-classes': $chooseButton.attr( 'class' ),
				'data-state': '',
			} )
			.text( $chooseButton.attr( 'data-choose-text' ) )
			.trigger( 'focus' );
	} );
} )( jQuery );

Filemanager

Name Type Size Permission Actions
widgets Folder 0755
accordion.js File 2.86 KB 0644
accordion.min.js File 758 B 0644
application-passwords.js File 6.24 KB 0644
application-passwords.min.js File 2.95 KB 0644
auth-app.js File 5.66 KB 0644
auth-app.min.js File 2.04 KB 0644
code-editor.js File 11.32 KB 0644
code-editor.min.js File 3.01 KB 0644
color-picker.js File 9.54 KB 0644
color-picker.min.js File 3.4 KB 0644
comment.js File 2.85 KB 0644
comment.min.js File 1.28 KB 0644
common.js File 60.79 KB 0644
common.min.js File 22.95 KB 0644
custom-background.js File 3.35 KB 0644
custom-background.min.js File 1.18 KB 0644
custom-header.js File 1.98 KB 0644
customize-controls.js File 287.18 KB 0644
customize-controls.min.js File 108.98 KB 0644
customize-nav-menus.js File 109.7 KB 0644
customize-nav-menus.min.js File 46.2 KB 0644
customize-widgets.js File 70.05 KB 0644
customize-widgets.min.js File 27.41 KB 0644
dashboard.js File 26.92 KB 0644
dashboard.min.js File 8.59 KB 0644
edit-comments.js File 36.67 KB 0644
edit-comments.min.js File 15.01 KB 0644
editor-expand.js File 41.61 KB 0644
editor-expand.min.js File 13.14 KB 0644
editor.js File 43.98 KB 0644
editor.min.js File 12.76 KB 0644
farbtastic.js File 7.67 KB 0644
gallery.js File 5.41 KB 0644
gallery.min.js File 3.65 KB 0644
image-edit.js File 39.98 KB 0644
image-edit.min.js File 15.15 KB 0644
inline-edit-post.js File 20.17 KB 0644
inline-edit-post.min.js File 9.41 KB 0644
inline-edit-tax.js File 7.61 KB 0644
inline-edit-tax.min.js File 2.93 KB 0644
iris.min.js File 23.09 KB 0644
language-chooser.js File 890 B 0644
language-chooser.min.js File 423 B 0644
link.js File 3.89 KB 0644
link.min.js File 1.7 KB 0644
media-gallery.js File 1.27 KB 0644
media-gallery.min.js File 611 B 0644
media-upload.js File 3.38 KB 0644
media-upload.min.js File 1.13 KB 0644
media.js File 6.61 KB 0644
media.min.js File 2.38 KB 0644
nav-menu.js File 58.73 KB 0644
nav-menu.min.js File 29.17 KB 0644
password-strength-meter.js File 4.14 KB 0644
password-strength-meter.min.js File 1.1 KB 0644
password-toggle.js File 1.31 KB 0644
password-toggle.min.js File 847 B 0644
plugin-install.js File 6.92 KB 0644
plugin-install.min.js File 2.35 KB 0644
post.js File 38.64 KB 0644
post.min.js File 18.38 KB 0644
postbox.js File 18.4 KB 0644
postbox.min.js File 6.55 KB 0644
privacy-tools.js File 10.67 KB 0644
privacy-tools.min.js File 5.03 KB 0644
revisions.js File 33.92 KB 0644
revisions.min.js File 17.97 KB 0644
set-post-thumbnail.js File 876 B 0644
set-post-thumbnail.min.js File 620 B 0644
site-health.js File 13.15 KB 0644
site-health.min.js File 6.13 KB 0644
site-icon.js File 6.1 KB 0644
site-icon.min.js File 2.2 KB 0644
svg-painter.js File 3.2 KB 0644
svg-painter.min.js File 1.53 KB 0644
tags-box.js File 10.88 KB 0644
tags-box.min.js File 3 KB 0644
tags-suggest.js File 5.64 KB 0644
tags-suggest.min.js File 2.22 KB 0644
tags.js File 4.77 KB 0644
tags.min.js File 1.96 KB 0644
theme-plugin-editor.js File 24.79 KB 0644
theme-plugin-editor.min.js File 11.46 KB 0644
theme.js File 54.65 KB 0644
theme.min.js File 26.4 KB 0644
updates.js File 109.29 KB 0644
updates.min.js File 47.23 KB 0644
user-profile.js File 15 KB 0644
user-profile.min.js File 6.7 KB 0644
user-suggest.js File 2.25 KB 0644
user-suggest.min.js File 676 B 0644
widgets.js File 22.56 KB 0644
widgets.min.js File 12.31 KB 0644
word-count.js File 7.52 KB 0644
word-count.min.js File 1.49 KB 0644
xfn.js File 740 B 0644
xfn.min.js File 458 B 0644