HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux wordpress-ubuntu-s-2vcpu-4gb-fra1-01 5.4.0-169-generic #187-Ubuntu SMP Thu Nov 23 14:52:28 UTC 2023 x86_64
User: root (0)
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: /var/www/hcv/wp-content/plugins/svg-support/js/svgs-inline-vanilla.js
// wait for document to be ready
document.addEventListener("DOMContentLoaded", function(event) {

	let bodhisvgsReplacements = 0;

	function bodhisvgsReplace(img) {

		// must be an image
		if( img.nodeName !== 'IMG' ){
			return;
		}

		var imgID = img.id;
		var imgClass = img.classList;
		var imgURL = img.src;

		// must be svg
		if( !imgURL.endsWith('svg') ){
			return;
		}

		var xmlHttp = new XMLHttpRequest();
		xmlHttp.onreadystatechange = function() {

			if (xmlHttp.readyState == 4 && xmlHttp.status == 200){

				data = xmlHttp.responseText;

				let parser = new DOMParser();
				const doc = parser.parseFromString(data, 'text/html');

				// get svg now
				var svg = doc.getElementsByTagName('svg')[0];

				var svgID = svg.id;

				// Add replaced image's ID to the new SVG if necessary
				if( typeof imgID === 'undefined' ){
					if( typeof svgID === 'undefined' ) {
						imgID = 'svg-replaced-'+bodhisvgsReplacements;
						svg.setAttribute('id', imgID);
					} else {
						imgID = svgID;
					}
				} else {
					svg.setAttribute('id', imgID);
				}

				// Add replaced image's classes to the new SVG
				if(typeof imgClass !== 'undefined') {
					svg.setAttribute('class', imgClass+' replaced-svg svg-replaced-'+bodhisvgsReplacements);
				}

				// Remove any invalid XML tags as per http://validator.w3.org
				svg.removeAttribute('xmlns:a');
        			     
                if(frontSanitizationEnabled == 'on' && svg["outerHTML"] != "") { // Is sanitization enabled?
                    var svg = DOMPurify.sanitize(svg.outerHTML); // Sanitize SVG code via DOMPurify library
                    img.outerHTML = svg; // Replacing img tag with new SVG sanitized content
                }
                else {
    				// Replace image with new SVG
    				img.replaceWith(svg);
                }
                
				bodhisvgsReplacements++;

			}

		}

		xmlHttp.open("GET", imgURL, false);
		xmlHttp.send(null);

	}

	function bodhisvgsIterator(node) {

		if( node.childNodes.length > 0 ){

			for (var i = 0; i < node.childNodes.length; i++) {

				if( node.childNodes[i].nodeName == 'IMG' ){

					// its an image... replace it too
					var img = node.childNodes[i];
					bodhisvgsReplace(img);

				}else{

					// go to another level
					bodhisvgsIterator(node.childNodes[i]);

				}
			}

		}

	}

	// Wrap in IIFE so that it can be called again later as bodhisvgsInlineSupport();
	(bodhisvgsInlineSupport = function() {

		// If force inline SVG option is active then add class
		if ( ForceInlineSVGActive === 'true' ) {

			var allImages = document.getElementsByTagName('img');	// find all images on page

			// loop on images
			for(var i = 0; i < allImages.length ; i++) {

				if( typeof allImages[i].src !== 'undefined' ){

					// check if it has svg
					if( allImages[i].src.match(/\.(svg)/) ){

						// add our class - if not already added
						if( !allImages[i].classList.contains(cssTarget.ForceInlineSVG) ){

							// add class now
							allImages[i].classList.add(cssTarget.ForceInlineSVG);

						}

					}

				}


			}

		}

		// Polyfill to support all ye old browsers
		// delete when not needed in the future
		if (!String.prototype.endsWith) {
			String.prototype.endsWith = function(searchString, position) {
				var subjectString = this.toString();
				if (typeof position !== 'number' || !isFinite(position) || Math.floor(position) !== position || position > subjectString.length) {
					position = subjectString.length;
				}
				position -= searchString.length;
				var lastIndex = subjectString.lastIndexOf(searchString, position);
				return lastIndex !== -1 && lastIndex === position;
			};
		} // end polyfill

		// Another snippet to support IE11
		String.prototype.endsWith = function(pattern) {
			var d = this.length - pattern.length;
			return d >= 0 && this.lastIndexOf(pattern) === d;
		};
		// End snippet to support IE11

		// Check to see if user set alternate class
		if ( ForceInlineSVGActive === 'true' ) {
			var target  = ( cssTarget.Bodhi !== 'img.' ? cssTarget.ForceInlineSVG : 'style-svg' );
		} else {
			var target  = ( cssTarget !== 'img.' ? cssTarget : 'style-svg' );
		}

		// remove .img from class
		target = target.replace("img.","");

		var allImages = document.getElementsByClassName(target);	// find all images with force svg class

		for(var i = 0; i < allImages.length ; i++) {

			if( typeof allImages[i].src == 'undefined'  ){	// not an image

				bodhisvgsIterator(allImages[i]);

			}else{

				var img = allImages[i];
				bodhisvgsReplace(img);

			}

		}

	})(); // Execute immediately

});