HEX
Server: Apache
System: Linux vps-cdc32557.vps.ovh.ca 5.15.0-156-generic #166-Ubuntu SMP Sat Aug 9 00:02:46 UTC 2025 x86_64
User: hanode (1017)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /home/hanode/public_html/wp-content/plugins/taxonomy-images/js/media-modal.js
// Media Modal Frame
var taxonomy_images_file_frame;

( function( $ ) {

	$( document ).ready( function() {

		// Store the old id (not sure if this is application when editing a term)
		TaxonomyImagesMediaModal.ttID = 0;

		// When the remove icon is clicked...
		$( '.wp-list-table, .form-table' ).on( 'click', '.taxonomy-image-control a.remove', function( event ) {

			event.preventDefault();

			var tt_id = $( this ).data( 'tt-id' );

			$.ajax( {
				url      : ajaxurl,
				type     : 'POST',
				dataType : 'json',
				data     : {
					'action'   : 'taxonomy_image_plugin_remove_association',
					'wp_nonce' : $( this ).data( 'nonce' ),
					'tt_id'    : $( this ).data( 'tt-id' )
				},
				cache     : false,
				success   : function ( response ) {
					if ( 'good' === response.status ) {

						selector = $( '#taxonomy-image-control-' + tt_id );

						/* Update the image on the screen below */
						selector.find( '.taxonomy-image-thumbnail img' ).attr( 'src', TaxonomyImagesMediaModal.default_img_src );

						selector.find( 'a.taxonomy-image-thumbnail' ).data( 'attachment-id', 0 );
						selector.find( 'a.upload' ).data( 'attachment-id', 0 );

						/* Show delete control on the screen below */
						selector.find( '.remove' ).addClass( 'hide' );

					}
					else if ( 'bad' === response.status ) {
						alert( response.why );
					}
				}
			} );

		} );

		// When image or upload icon clicked...
		$( '.wp-list-table, .form-table' ).on( 'click', '.taxonomy-image-control a.upload, .taxonomy-image-control a.taxonomy-image-thumbnail', function( event ) {

			event.preventDefault();

			button = $( this );

			TaxonomyImagesMediaModal.ttID = $( this ).data( 'tt-id' );
			TaxonomyImagesMediaModal.attachment_id = $( this ).data( 'attachment-id' );
			TaxonomyImagesMediaModal.nonce = $( this ).data( 'nonce' );

			// If the media frame already exists, reopen it.
			if ( taxonomy_images_file_frame ) {

				// Set the post ID to the term being edited and open
				taxonomy_images_file_frame.open();
				return;

			} else {

				// Set the wp.media post id so the uploader grabs the term ID being edited
				TaxonomyImagesMediaModal.ttID = $( this ).data( 'tt-id' );

			}

			// Create the media frame.
			taxonomy_images_file_frame = wp.media.frames.taxonomy_images_file_frame = wp.media( {
				title    : TaxonomyImagesMediaModal.uploader_title,
				button   : { text : TaxonomyImagesMediaModal.uploader_button_text },
				library  : { type: 'image' },
				multiple : false
			} );

			// Pre-select selected attachment
			wp.media.frames.taxonomy_images_file_frame.on( 'open', function() {
				var selection = wp.media.frames.taxonomy_images_file_frame.state().get( 'selection' );
				var selected_id = TaxonomyImagesMediaModal.attachment_id;
				if ( selected_id > 0 ) {
					attachment = wp.media.attachment( selected_id );
					attachment.fetch();
					selection.add( attachment ? [ attachment ] : [] );
				}
			} );

			// When an image is selected, run a callback.
			taxonomy_images_file_frame.on( 'select', function() {

				// We set multiple to false so only get one image from the uploader
				attachment = taxonomy_images_file_frame.state().get( 'selection' ).first().toJSON();

				var tt_id = TaxonomyImagesMediaModal.ttID;
				var attachment_id = attachment.id;

				// Do something with attachment.id and/or attachment.url here
				$.ajax( {
					url      : ajaxurl,
					type     : 'POST',
					dataType : 'json',
					data     : {
						'action'        : 'taxonomy_image_create_association',
						'wp_nonce'      : TaxonomyImagesMediaModal.nonce,
						'attachment_id' : attachment.id,
						'tt_id'         : parseInt( TaxonomyImagesMediaModal.ttID )
					},
					success  : function ( response ) {
						if ( 'good' === response.status ) {
							var parent_id = button.parent().attr( 'id' );

							/* Set state of all other buttons. */
							$( '.taxonomy-image-modal-control' ).each( function( i, e ) {
								if ( parent_id == $( e ).attr( 'id' ) ) {
									return true;
								}
								$( e ).find( '.create-association' ).show();
								$( e ).find( '.remove-association' ).hide();
							} );

							selector = $( '#taxonomy-image-control-' + tt_id );

							/* Update the image on the screen below */
							selector.find( '.taxonomy-image-thumbnail img' ).attr( 'src', response.attachment_thumb_src );

							selector.find( 'a.taxonomy-image-thumbnail' ).data( 'attachment-id', attachment_id );
							selector.find( 'a.upload' ).data( 'attachment-id', attachment_id );

							/* Show delete control on the screen below */
							$( selector ).find( '.remove' ).each( function ( i, e ) {
								$( e ).removeClass( 'hide' );
							} );

						}
						else if ( 'bad' === response.status ) {
							alert( response.why );
						}
					}
				} );

			} );

			// Finally, open the modal
			taxonomy_images_file_frame.open();

		} );

	} );

} )( jQuery );