PHP 8.1.33
Preview: site-icon.js Size: 6.10 KB
/home/jambtst2015/public_html/cccng.org/wp-admin/js/site-icon.js

/**
 * 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 );

Directory Contents

Dirs: 1 × Files: 97

Name Size Perms Modified Actions
widgets DIR
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
2.86 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
758 B lrw-r--r-- 2024-12-17 21:37:28
Edit Download
6.24 KB lrw-r--r-- 2023-09-18 08:21:24
Edit Download
2.95 KB lrw-r--r-- 2023-09-18 08:21:24
Edit Download
5.66 KB lrw-r--r-- 2021-02-24 06:15:04
Edit Download
2.04 KB lrw-r--r-- 2022-04-09 05:37:18
Edit Download
11.32 KB lrw-r--r-- 2020-07-28 09:05:02
Edit Download
3.01 KB lrw-r--r-- 2024-06-27 23:21:44
Edit Download
9.54 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
3.40 KB lrw-r--r-- 2022-04-09 05:37:18
Edit Download
2.85 KB lrw-r--r-- 2024-02-12 05:44:20
Edit Download
1.28 KB lrw-r--r-- 2022-04-09 05:37:18
Edit Download
61.15 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
23.12 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
3.35 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
1.18 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
1.98 KB lrw-r--r-- 2021-02-24 06:15:04
Edit Download
287.36 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
109.14 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
111.13 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
46.93 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
70.05 KB lrw-r--r-- 2024-06-22 03:47:14
Edit Download
27.41 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
27.02 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
8.65 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
37.12 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
15.13 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
41.61 KB lrw-r--r-- 2024-04-13 03:17:14
Edit Download
13.14 KB lrw-r--r-- 2024-06-27 23:21:44
Edit Download
43.98 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
12.76 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
7.67 KB lrw-r--r-- 2023-07-18 07:33:26
Edit Download
5.41 KB lrw-r--r-- 2023-10-10 07:01:28
Edit Download
3.65 KB lrw-r--r-- 2023-10-10 07:01:28
Edit Download
39.98 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
15.15 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
20.17 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
9.41 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
7.61 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
2.93 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
23.09 KB lrw-r--r-- 2021-11-04 05:10:00
Edit Download
890 B lrw-r--r-- 2021-02-24 06:15:04
Edit Download
423 B lrw-r--r-- 2021-02-24 06:15:04
Edit Download
3.89 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
1.70 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
1.27 KB lrw-r--r-- 2021-02-24 06:15:04
Edit Download
611 B lrw-r--r-- 2022-04-09 05:37:18
Edit Download
3.38 KB lrw-r--r-- 2021-01-22 23:02:04
Edit Download
1.13 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
6.61 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
2.38 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
60.72 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
29.85 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
4.14 KB lrw-r--r-- 2021-01-22 23:02:04
Edit Download
1.10 KB lrw-r--r-- 2021-01-22 23:02:04
Edit Download
1.31 KB lrw-r--r-- 2023-06-24 08:39:30
Edit Download
847 B lrw-r--r-- 2023-06-24 08:39:30
Edit Download
6.92 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
2.35 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
38.68 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
18.40 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
18.49 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
6.60 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
10.67 KB lrw-r--r-- 2024-06-22 03:47:14
Edit Download
5.03 KB lrw-r--r-- 2024-06-22 03:47:14
Edit Download
33.92 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
17.97 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
876 B lrw-r--r-- 2020-07-08 04:25:04
Edit Download
620 B lrw-r--r-- 2020-07-08 04:25:04
Edit Download
13.15 KB lrw-r--r-- 2023-12-29 01:57:16
Edit Download
6.13 KB lrw-r--r-- 2023-12-29 01:57:16
Edit Download
6.10 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
2.20 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
3.20 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
1.53 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
10.88 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
3.00 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
5.64 KB lrw-r--r-- 2024-02-19 08:46:14
Edit Download
2.22 KB lrw-r--r-- 2024-02-19 08:46:14
Edit Download
4.85 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
2.04 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
24.77 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
11.43 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
54.67 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
26.42 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
109.33 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
47.27 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
15.00 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
6.70 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
2.25 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
676 B lrw-r--r-- 2021-03-19 04:31:04
Edit Download
22.56 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
12.31 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
7.52 KB lrw-r--r-- 2020-07-28 09:05:02
Edit Download
1.49 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
740 B lrw-r--r-- 2021-03-19 04:31:04
Edit Download
458 B lrw-r--r-- 2021-03-19 04:31:04
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).