HEX
Server: LiteSpeed
System: Linux php-prod-1.spaceapp.ru 5.15.0-157-generic #167-Ubuntu SMP Wed Sep 17 21:35:53 UTC 2025 x86_64
User: sport3497 (1034)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: //proc/thread-self/cwd/wp-content/plugins/wp-smushit/app/assets/js/smush-rd.min.js.map
{"version":3,"file":"js/smush-rd.min.js","mappings":"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","sources":["webpack://wp-smushit/./_src/js/frontend/resize-detection.js"],"sourcesContent":["import '../../scss/resize-detection.scss';\n\n/**\n * Image resize detection (IRD).\n *\n * Show all wrongly scaled images with a highlighted border and resize box.\n *\n * Made in pure JS.\n * DO NOT ADD JQUERY SUPPORT!!!\n *\n * @since 2.9\n */\n( function() {\n\t'use strict';\n\n\tconst SmushIRS = {\n\t\tbar: document.getElementById( 'smush-image-bar' ),\n\t\ttoggle: document.getElementById( 'smush-image-bar-toggle' ),\n\t\timages: {\n\t\t\tbigger: [],\n\t\t\tsmaller: [],\n\t\t},\n\t\tstrings: window.wp_smush_resize_vars,\n\n\t\t/**\n\t\t * Init scripts.\n\t\t */\n\t\tinit() {\n\t\t\t/**\n\t\t\t * Make sure these are set, before we proceed.\n\t\t\t */\n\t\t\tif ( ! this.bar ) {\n\t\t\t\tthis.bar = document.getElementById( 'smush-image-bar' );\n\t\t\t}\n\t\t\tif ( ! this.toggle ) {\n\t\t\t\tthis.toggle = document.getElementById(\n\t\t\t\t\t'smush-image-bar-toggle'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.process();\n\n\t\t\t// Register the event handler after everything is done.\n\t\t\tthis.toggle.addEventListener(\n\t\t\t\t'click',\n\t\t\t\tthis.handleToggleClick.bind( this )\n\t\t\t);\n\n\t\t\tthis.initImageVisibilityObserver();\n\t\t},\n\n\t\t/**\n\t\t * Do image processing.\n\t\t */\n\t\tprocess() {\n\t\t\tconst icon = this.toggle.querySelector( 'i' );\n\n\t\t\ticon.classList.add( 'sui-icon-loader' );\n\t\t\ticon.classList.remove( 'sui-icon-info' );\n\n\t\t\tthis.detectImages();\n\n\t\t\tif ( ! this.images.bigger.length && ! this.images.smaller.length ) {\n\t\t\t\tthis.toggle.classList.add( 'smush-toggle-success' );\n\t\t\t\tdocument.getElementById(\n\t\t\t\t\t'smush-image-bar-notice'\n\t\t\t\t).style.display = 'block';\n\t\t\t\tdocument.getElementById(\n\t\t\t\t\t'smush-image-bar-notice-desc'\n\t\t\t\t).style.display = 'none';\n\t\t\t} else {\n\t\t\t\tthis.toggle.classList.remove( 'smush-toggle-success' );\n\t\t\t\tdocument.getElementById(\n\t\t\t\t\t'smush-image-bar-notice'\n\t\t\t\t).style.display = 'none';\n\t\t\t\tdocument.getElementById(\n\t\t\t\t\t'smush-image-bar-notice-desc'\n\t\t\t\t).style.display = 'block';\n\t\t\t\tthis.generateMarkup( 'bigger' );\n\t\t\t\tthis.generateMarkup( 'smaller' );\n\t\t\t}\n\n\t\t\tthis.toggleDivs();\n\n\t\t\ticon.classList.remove( 'sui-icon-loader' );\n\t\t\ticon.classList.add( 'sui-icon-info' );\n\t\t},\n\n\t\t/**\n\t\t * Various checks to see if the image should be processed.\n\t\t *\n\t\t * @param {Object} image\n\t\t * @return {boolean}  Should skip image or not.\n\t\t */\n\t\tshouldSkipImage( image ) {\n\t\t\tif ( this.isIgnoredImage( image ) ) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\t// Skip 1x1px and 0x0px images.\n\t\t\tif (\n\t\t\t\timage.clientWidth === image.clientHeight &&\n\t\t\t\t( 1 === image.clientWidth || 0 === image.clientWidth )\n\t\t\t) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\t// Skip 1x1px and 0x0px placeholders.\n\t\t\tif ( this.isPlaceholder( image ) ) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\t// If width attribute is not set, do not continue.\n\t\t\treturn null === image.clientWidth || null === image.clientHeight;\n\t\t},\n\n\t\tisIgnoredImage( image ) {\n\t\t\t// Skip avatars.\n\t\t\tif ( image.classList.contains( 'avatar' ) ) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\t// Skip images from Smush CDN with auto-resize feature.\n\t\t\treturn 'string' === typeof image.getAttribute( 'no-resize-detection' );\n\t\t},\n\n\t\tisPlaceholder( image ) {\n\t\t\treturn image.naturalWidth === image.naturalHeight && image.naturalWidth < 32;\n\t\t},\n\n\t\t/**\n\t\t * Get tooltip text.\n\t\t *\n\t\t * @param {Object} props\n\t\t * @return {string}  Tooltip.\n\t\t */\n\t\tgetTooltipText( props ) {\n\t\t\tlet tooltipText = '';\n\n\t\t\tif ( props.bigger_width || props.bigger_height ) {\n\t\t\t\t/** @param {string} strings.large_image */\n\t\t\t\ttooltipText = this.strings.large_image;\n\t\t\t} else if ( props.smaller_width || props.smaller_height ) {\n\t\t\t\t/** @param {string} strings.small_image */\n\t\t\t\ttooltipText = this.strings.small_image;\n\t\t\t}\n\n\t\t\treturn tooltipText\n\t\t\t\t.replace( 'width', props.real_width )\n\t\t\t\t.replace( 'height', props.real_height );\n\t\t},\n\n\t\t/**\n\t\t * Generate markup.\n\t\t *\n\t\t * @param {string} type Accepts: 'bigger' or 'smaller'.\n\t\t */\n\t\tgenerateMarkup( type ) {\n\t\t\tthis.images[ type ].forEach( ( image, index ) => {\n\t\t\t\tconst item = document.createElement( 'div' ),\n\t\t\t\t\ttooltip = this.getTooltipText( image.props );\n\n\t\t\t\titem.setAttribute(\n\t\t\t\t\t'class',\n\t\t\t\t\t'smush-resize-box smush-tooltip smush-tooltip-constrained'\n\t\t\t\t);\n\t\t\t\titem.setAttribute( 'data-tooltip', tooltip );\n\t\t\t\titem.setAttribute( 'data-image', image.class );\n\t\t\t\titem.addEventListener( 'click', ( e ) =>\n\t\t\t\t\tthis.highlightImage( e )\n\t\t\t\t);\n\n\t\t\t\titem.innerHTML = `\n\t\t\t\t\t<div class=\"smush-image-info\">\n\t\t\t\t\t\t<span>${ index + 1 }</span>\n\t\t\t\t\t\t<span class=\"smush-tag\">${ image.props.computed_width } x ${ image.props.computed_height }px</span>\n\t\t\t\t\t\t<i class=\"smush-front-icons smush-front-icon-arrows-in\" aria-hidden=\"true\">&nbsp;</i>\n\t\t\t\t\t\t<span class=\"smush-tag smush-tag-success\">${ image.props.real_width } × ${ image.props.real_height }px</span>\t\t\t\t\t\n\t\t\t\t\t</div>\n\t\t\t\t\t<div class=\"smush-image-description\">${ tooltip }</div>\n\t\t\t\t`;\n\n\t\t\t\tdocument\n\t\t\t\t\t.getElementById( 'smush-image-bar-items-' + type )\n\t\t\t\t\t.appendChild( item );\n\t\t\t} );\n\t\t},\n\n\t\t/**\n\t\t * Show/hide sections based on images.\n\t\t */\n\t\ttoggleDivs() {\n\t\t\tconst types = [ 'bigger', 'smaller' ];\n\t\t\ttypes.forEach( ( type ) => {\n\t\t\t\tconst div = document.getElementById(\n\t\t\t\t\t'smush-image-bar-items-' + type\n\t\t\t\t);\n\t\t\t\tif ( 0 === this.images[ type ].length ) {\n\t\t\t\t\tdiv.style.display = 'none';\n\t\t\t\t} else {\n\t\t\t\t\tdiv.style.display = 'block';\n\t\t\t\t}\n\t\t\t} );\n\t\t},\n\n\t\t/**\n\t\t * Scroll the selected image into view and highlight it.\n\t\t *\n\t\t * @param {Object} e\n\t\t */\n\t\thighlightImage( e ) {\n\t\t\tthis.removeSelection();\n\n\t\t\tconst el = document.getElementsByClassName(\n\t\t\t\te.currentTarget.dataset.image\n\t\t\t);\n\t\t\tif ( 'undefined' !== typeof el[ 0 ] ) {\n\t\t\t\t// Display description box.\n\t\t\t\te.currentTarget.classList.toggle( 'show-description' );\n\n\t\t\t\t// Scroll and flash image.\n\t\t\t\tel[ 0 ].scrollIntoView( {\n\t\t\t\t\tbehavior: 'smooth',\n\t\t\t\t\tblock: 'center',\n\t\t\t\t\tinline: 'nearest',\n\t\t\t\t} );\n\t\t\t\tel[ 0 ].style.opacity = '0.5';\n\t\t\t\tsetTimeout( () => {\n\t\t\t\t\tel[ 0 ].style.opacity = '1';\n\t\t\t\t}, 1000 );\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Handle click on the toggle item.\n\t\t */\n\t\thandleToggleClick() {\n\t\t\tthis.bar.classList.toggle( 'closed' );\n\t\t\tthis.toggle.classList.toggle( 'closed' );\n\t\t\tthis.removeSelection();\n\t\t},\n\n\t\t/**\n\t\t * Remove selected items.\n\t\t */\n\t\tremoveSelection() {\n\t\t\tconst items = document.getElementsByClassName( 'show-description' );\n\t\t\tif ( items.length > 0 ) {\n\t\t\t\tArray.from( items ).forEach( ( div ) =>\n\t\t\t\t\tdiv.classList.remove( 'show-description' )\n\t\t\t\t);\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Function to highlight all scaled images.\n\t\t *\n\t\t * Add yellow border and then show one small box to\n\t\t * resize the images as per the required size, on fly.\n\t\t */\n\t\tdetectImages() {\n\t\t\tconst images = document.getElementsByTagName( 'img' );\n\t\t\tfor ( const image of images ) {\n\t\t\t\tif ( this.shouldSkipImage( image ) ) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Get defined width and height.\n\t\t\t\tconst props = {\n\t\t\t\t\treal_width: image.clientWidth,\n\t\t\t\t\treal_height: image.clientHeight,\n\t\t\t\t\tcomputed_width: image.naturalWidth,\n\t\t\t\t\tcomputed_height: image.naturalHeight,\n\t\t\t\t\tbigger_width: image.clientWidth * 1.5 < image.naturalWidth,\n\t\t\t\t\tbigger_height:\n\t\t\t\t\t\timage.clientHeight * 1.5 < image.naturalHeight,\n\t\t\t\t\tsmaller_width: image.clientWidth > image.naturalWidth,\n\t\t\t\t\tsmaller_height: image.clientHeight > image.naturalHeight,\n\t\t\t\t};\n\n\t\t\t\t// In case image is in correct size, do not continue.\n\t\t\t\tif (\n\t\t\t\t\t! props.bigger_width &&\n\t\t\t\t\t! props.bigger_height &&\n\t\t\t\t\t! props.smaller_width &&\n\t\t\t\t\t! props.smaller_height\n\t\t\t\t) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst imgType =\n\t\t\t\t\t\tprops.bigger_width || props.bigger_height\n\t\t\t\t\t\t\t? 'bigger'\n\t\t\t\t\t\t\t: 'smaller',\n\t\t\t\t    imageClass =\n\t\t\t\t\t    `smush-image-${ imgType }-${ this.images[ imgType ].length + 1 }`;\n\n\t\t\t\t// Fill the images arrays.\n\t\t\t\tthis.images[ imgType ].push( {\n\t\t\t\t\tsrc: image,\n\t\t\t\t\tprops,\n\t\t\t\t\tclass: imageClass,\n\t\t\t\t} );\n\n\t\t\t\t/**\n\t\t\t\t * Add class to original image.\n\t\t\t\t * Can't add two classes in single add(), because no support in IE11.\n\t\t\t\t * image.classList.add('smush-detected-img', imageClass);\n\t\t\t\t */\n\t\t\t\timage.classList.add( 'smush-detected-img' );\n\t\t\t\timage.classList.add( imageClass );\n\t\t\t}\n\t\t}, // End detectImages()\n\n\t\t/**\n\t\t * Allows refreshing the list. A good way is to refresh on lazyload actions.\n\t\t *\n\t\t * @since 3.6.0\n\t\t */\n\t\trefresh() {\n\t\t\t// Clear out classes on DOM.\n\t\t\tfor ( let id in this.images.bigger ) {\n\t\t\t\tif ( this.images.bigger.hasOwnProperty( id ) ) {\n\t\t\t\t\tthis.images.bigger[ id ].src.classList.remove(\n\t\t\t\t\t\t'smush-detected-img'\n\t\t\t\t\t);\n\t\t\t\t\tthis.images.bigger[ id ].src.classList.remove(\n\t\t\t\t\t\t'smush-image-bigger-' + ( ++id )\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfor ( let id in this.images.smaller ) {\n\t\t\t\tif ( this.images.smaller.hasOwnProperty( id ) ) {\n\t\t\t\t\tthis.images.smaller[ id ].src.classList.remove(\n\t\t\t\t\t\t'smush-detected-img'\n\t\t\t\t\t);\n\t\t\t\t\tthis.images.smaller[ id ].src.classList.remove(\n\t\t\t\t\t\t'smush-image-smaller-' + ( ++id )\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.images = {\n\t\t\t\tbigger: [],\n\t\t\t\tsmaller: [],\n\t\t\t};\n\n\t\t\t// This might be overkill - there will probably never be a situation when there are less images than on\n\t\t\t// initial page load.\n\t\t\tconst elements = document.getElementsByClassName(\n\t\t\t\t'smush-resize-box'\n\t\t\t);\n\t\t\twhile ( elements.length > 0 ) {\n\t\t\t\telements[ 0 ].remove();\n\t\t\t}\n\n\t\t\tthis.process();\n\t\t},\n\n\t\t/**\n\t\t * This will monitor all images on the page and detect their sizes once they’ve loaded.\n\t\t *\n\t\t * @since 3.18.0\n\t\t */\n\t\tinitImageVisibilityObserver() {\n\t\t\tlet imagesSelector = 'img:not(.smush-detected-img)';\n\t\t\tconst smushLazyloadEnabled = typeof window.lazySizes !== 'undefined';\n\t\t\tif ( smushLazyloadEnabled ) {\n\t\t\t\tconst lazyLoadClassName = window.lazySizes?.cfg?.lazyClass || 'lazyload';\n\t\t\t\timagesSelector += `:not(.${ lazyLoadClassName } )`;\n\t\t\t}\n\t\t\tconst lazyImages = document.querySelectorAll( imagesSelector );\n\n\t\t\tif ( ! lazyImages.length ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst config = {\n\t\t\t\tthreshold: 0.1\n\t\t\t};\n\n\t\t\tlet refreshTimeout = null;\n\n\t\t\tconst debouncedRefresh = () => {\n\t\t\t\tif ( refreshTimeout ) {\n\t\t\t\t\tclearTimeout( refreshTimeout );\n\t\t\t\t}\n\t\t\t\trefreshTimeout = setTimeout( () => {\n\t\t\t\t\tthis.refresh();\n\t\t\t\t\trefreshTimeout = null;\n\t\t\t\t}, 500 );\n\t\t\t};\n\n\t\t\tconst imageObserver = new IntersectionObserver( ( entries ) => {\n\t\t\t\tentries.forEach( ( entry ) => {\n\t\t\t\t\tif ( entry.isIntersecting ) {\n\t\t\t\t\t\tconst img = entry.target;\n\n\t\t\t\t\t\tif ( ! img.classList.contains( 'smush-detected-img' ) ) {\n\t\t\t\t\t\t\tif ( img.complete && ! this.isPlaceholder( img ) ) {\n\t\t\t\t\t\t\t\tdebouncedRefresh();\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\timg.addEventListener( 'load', () => {\n\t\t\t\t\t\t\t\t\tdebouncedRefresh();\n\t\t\t\t\t\t\t\t}, { once: true } );\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\timageObserver.unobserve( img );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t}, config );\n\n\t\t\tlazyImages.forEach( ( img ) => {\n\t\t\t\tif ( this.isIgnoredImage( img ) ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\timageObserver.observe( img );\n\t\t\t} );\n\t\t},\n\n\t}; // End WP_Smush_IRS\n\n\t/**\n\t * After page load, initialize toggle event.\n\t */\n\twindow.addEventListener( 'DOMContentLoaded', () => SmushIRS.init() );\n\twindow.addEventListener( 'lazyloaded', ( event ) => {\n\t\tif ( 'IMG' !== event?.target?.tagName ) {\n\t\t\treturn;\n\t\t}\n\n\t\tSmushIRS.refresh();\n\t} );\n}() );\n"],"names":["SmushIRS","bar","document","getElementById","toggle","images","bigger","smaller","strings","window","wp_smush_resize_vars","init","this","process","addEventListener","handleToggleClick","bind","initImageVisibilityObserver","icon","querySelector","classList","add","remove","detectImages","length","style","display","generateMarkup","toggleDivs","shouldSkipImage","image","isIgnoredImage","clientWidth","clientHeight","isPlaceholder","contains","getAttribute","naturalWidth","naturalHeight","getTooltipText","props","tooltipText","bigger_width","bigger_height","large_image","smaller_width","smaller_height","small_image","replace","real_width","real_height","type","_this","forEach","index","item","createElement","tooltip","setAttribute","class","e","highlightImage","innerHTML","concat","computed_width","computed_height","appendChild","_this2","div","removeSelection","el","getElementsByClassName","currentTarget","dataset","scrollIntoView","behavior","block","inline","opacity","setTimeout","items","Array","from","_step","_iterator","_createForOfIteratorHelper","getElementsByTagName","s","n","done","value","imgType","imageClass","push","src","err","f","refresh","id","hasOwnProperty","elements","_this3","imagesSelector","lazySizes","_window$lazySizes","lazyLoadClassName","cfg","lazyClass","lazyImages","querySelectorAll","refreshTimeout","debouncedRefresh","clearTimeout","imageObserver","IntersectionObserver","entries","entry","isIntersecting","img","target","complete","once","unobserve","threshold","observe","event","_event$target","tagName"],"sourceRoot":""}