Корзина 0 позиций
на сумму 0 ₽
+7 991 416 82 91
Время работы:
Пн-Вс 10-19

Анимированные блоки. Скрипт для любого сайта

Здесь предоставлена возможность анимировать блоки на любом сайте без привязки к сиситеме управления сайтом. Сайт может быть любым: хоть на Битрикс, хоть на Вордпресс, хоть на "чистом" html или на конструкторе сайтов.
Значения не имеет. Скрипт бесплатный. Пользуйтесь!

Способ совершенно безопасный и после перезагрузки страницы все изменения на странице пропадают. Так как все действия происходят на стороне браузера и никак не касаются хостинга. А для сохранения результата требуется доступ владельца сайта на хостинг (ниже описано).
 
Как пользоваться?
Пояснять буду на примере браузера гугл-хром

  • Скопировать текст скрипта в буфер обмена
  • Перейти на страницу Вашего сайта
  • Открыть инструменты разработчика (в хроме F12)
  • Открыть  вкладку "Консоль"
  • Вставить тест скрипта в поле "Консоли"
  • Далее появится окошко справа
  • Нажать шестеренку
  • Наведением "мыши" добиться появления маркера, который указывает, какой блок будет анимирован
  • Подобрать желаемый эффект
  • Если нужно анимировать несколько блоков нажмите "Escape" и повторите процедуру наведения "мыши", отметки следующего блока и выбора эффекта.
  • Когда всё будет готово и Вас удовлетворяет полученный результат, перейдите на вкладку "Элементы" и с помощью поиска ctrl-F найдите текст "ss-0001". Это и есть элемент анимации на стилях CSS 
  • Скопируйте эти стили любым доступным Вам способом либо в файл CSS Вашего сайта, либо в раздел <header><style type="text/css" rel="ss-0001">.... тут будут стили...</style>.......тут уже что то было ранее...</header>
И конечно, есть нюансы... и их много. Вот некоторые замеченные:
  • Возможен конфликт версий jQuery с той, что на сайте
  • Может не найти уникальный CSS селектор блока. Сильно зависит от html разметки на сайте. Устойчиво работает при наличии классов в разметке
  • На некоторых сайтах скрипт не работает по причине наличия защиты. Например на странице Гугла и Яндекса скрипт выдает ошибку. Причем на каждом поисковике ошибка своя (разные способы защиты)

Скачать ява скрипт

Либо скопировать из теста ниже:

//if (typeof window.jQuery == 'undefined') {
        !function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.6.0",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),j=function(e,t){return e===t&&(l=!0),0},D={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},j=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&D.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(j),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(j).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var D,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||D,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,D=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^([^.]*)(?:\.(.+)|)/;function we(){return!0}function Te(){return!1}function Ce(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function Ee(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)Ee(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Te;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Se(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n&&n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,we)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=be.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=be.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click",we),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?we:Te,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Te,isPropagationStopped:Te,isImmediatePropagationStopped:Te,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=we,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=we,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=we,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:!0},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Se(this,e,Ce),!1},trigger:function(){return Se(this,e),!0},_default:function(){return!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return Ee(this,e,t,n,r)},one:function(e,t,n,r){return Ee(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Te),this.each(function(){S.event.remove(this,e,n,t)})}});var ke=/<script|<style|<link/i,Ae=/checked\s*(?:[^=]|=\s*.checked.)/i,Ne=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function je(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function De(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function qe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Le(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function He(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&Ae.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),He(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),De)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,qe),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(Ne,""),u,l))}return n}function Oe(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Le(o[r],a[r]);else Le(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Oe(this,e,!0)},remove:function(e){return Oe(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return He(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||je(this,e).appendChild(e)})},prepend:function(){return He(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=je(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!ke.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return He(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Pe=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Re=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},Me=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Ie=new RegExp(ne.join("|"),"i");function We(e,t,n){var r,i,o,a,s=e.style;return(n=n||Re(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Pe.test(a)&&Ie.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function Fe(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px;border-collapse:separate",t.style.cssText="border:1px solid",t.style.height="1px",n.style.height="9px",n.style.display="block",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=parseInt(r.height,10)+parseInt(r.borderTopWidth,10)+parseInt(r.borderBottomWidth,10)===t.offsetHeight,re.removeChild(e)),a}}))}();var Be=["Webkit","Moz","ms"],$e=E.createElement("div").style,_e={};function ze(e){var t=S.cssProps[e]||_e[e];return t||(e in $e?e:_e[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=Be.length;while(n--)if((e=Be[n]+t)in $e)return e}(e)||e)}var Ue=/^(none|table(?!-c[ea]).+)/,Xe=/^--/,Ve={position:"absolute",visibility:"hidden",display:"block"},Ge={letterSpacing:"0",fontWeight:"400"};function Ye(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Qe(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Je(e,t,n){var r=Re(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=We(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Pe.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Qe(e,t,n||(i?"border":"content"),o,r,a)+"px"}function Ke(e,t,n,r,i){return new Ke.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=We(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Xe.test(t),l=e.style;if(u||(t=ze(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Xe.test(t)||(t=ze(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=We(e,t,r)),"normal"===i&&t in Ge&&(i=Ge[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ue.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Je(e,u,n):Me(e,Ve,function(){return Je(e,u,n)})},set:function(e,t,n){var r,i=Re(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Qe(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Qe(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Ye(0,t,s)}}}),S.cssHooks.marginLeft=Fe(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(We(e,"marginLeft"))||e.getBoundingClientRect().left-Me(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Ye)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Re(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=Ke).prototype={constructor:Ke,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=Ke.propHooks[this.prop];return e&&e.get?e.get(this):Ke.propHooks._default.get(this)},run:function(e){var t,n=Ke.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):Ke.propHooks._default.set(this),this}}).init.prototype=Ke.prototype,(Ke.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[ze(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=Ke.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=Ke.prototype.init,S.fx.step={};var Ze,et,tt,nt,rt=/^(?:toggle|show|hide)$/,it=/queueHooks$/;function ot(){et&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(ot):C.setTimeout(ot,S.fx.interval),S.fx.tick())}function at(){return C.setTimeout(function(){Ze=void 0}),Ze=Date.now()}function st(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ut(e,t,n){for(var r,i=(lt.tweeners[t]||[]).concat(lt.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function lt(o,e,t){var n,a,r=0,i=lt.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=Ze||at(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:Ze||at(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=lt.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ut,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(lt,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],lt.tweeners[n]=lt.tweeners[n]||[],lt.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],rt.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ut(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?lt.prefilters.unshift(e):lt.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=lt(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&it.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(st(r,!0),e,t,n)}}),S.each({slideDown:st("show"),slideUp:st("hide"),slideToggle:st("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(Ze=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),Ze=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){et||(et=!0,ot())},S.fx.stop=function(){et=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},tt=E.createElement("input"),nt=E.createElement("select").appendChild(E.createElement("option")),tt.type="checkbox",y.checkOn=""!==tt.value,y.optSelected=nt.selected,(tt=E.createElement("input")).value="t",tt.type="radio",y.radioValue="t"===tt.value;var ct,ft=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?ct:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),ct={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=ft[t]||S.find.attr;ft[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=ft[o],ft[o]=r,r=null!=a(e,t,n)?o:null,ft[o]=i),r}});var pt=/^(?:input|select|textarea|button)$/i,dt=/^(?:a|area)$/i;function ht(e){return(e.match(P)||[]).join(" ")}function gt(e){return e.getAttribute&&e.getAttribute("class")||""}function vt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):pt.test(e.nodeName)||dt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,gt(this)))});if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,gt(this)))});if(!arguments.length)return this.attr("class","");if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,gt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=vt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=gt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+ht(gt(n))+" ").indexOf(t))return!0;return!1}});var yt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(yt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:ht(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var mt=/^(?:focusinfocus|focusoutblur)$/,xt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!mt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,mt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,xt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,xt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var bt=C.location,wt={guid:Date.now()},Tt=/\?/;S.parseXML=function(e){var t,n;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){}return n=t&&t.getElementsByTagName("parsererror")[0],t&&!n||S.error("Invalid XML: "+(n?S.map(n.childNodes,function(e){return e.textContent}).join("\n"):e)),t};var Ct=/\[\]$/,Et=/\r?\n/g,St=/^(?:submit|button|image|reset|file)$/i,kt=/^(?:input|select|textarea|keygen)/i;function At(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||Ct.test(n)?i(n,t):At(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)At(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)At(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&kt.test(this.nodeName)&&!St.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(Et,"\r\n")}}):{name:t.name,value:n.replace(Et,"\r\n")}}).get()}});var Nt=/%20/g,jt=/#.*$/,Dt=/([?&])_=[^&]*/,qt=/^(.*?):[ \t]*([^\r\n]*)$/gm,Lt=/^(?:GET|HEAD)$/,Ht=/^\/\//,Ot={},Pt={},Rt="*/".concat("*"),Mt=E.createElement("a");function It(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Wt(t,i,o,a){var s={},u=t===Pt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function Ft(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Mt.href=bt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:bt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(bt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Rt,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Ft(Ft(e,S.ajaxSettings),t):Ft(S.ajaxSettings,e)},ajaxPrefilter:It(Ot),ajaxTransport:It(Pt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=qt.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||bt.href)+"").replace(Ht,bt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Mt.protocol+"//"+Mt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Wt(Ot,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Lt.test(v.type),f=v.url.replace(jt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(Nt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Tt.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Dt,"$1"),o=(Tt.test(f)?"&":"?")+"_="+wt.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+Rt+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Wt(Pt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&S.inArray("json",v.dataTypes)<0&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var Bt={0:200,1223:204},$t=S.ajaxSettings.xhr();y.cors=!!$t&&"withCredentials"in $t,y.ajax=$t=!!$t,S.ajaxTransport(function(i){var o,a;if(y.cors||$t&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(Bt[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var _t,zt=[],Ut=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=zt.pop()||S.expando+"_"+wt.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Ut.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Ut.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Ut,"$1"+r):!1!==e.jsonp&&(e.url+=(Tt.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,zt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((_t=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===_t.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=ht(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=Fe(y.pixelPosition,function(e,t){if(t)return t=We(e,n),Pe.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Xt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Xt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Vt=C.jQuery,Gt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Gt),e&&C.jQuery===S&&(C.jQuery=Vt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S});
//}
//if (typeof jQuery().draggable == 'undefined') {
        !function(t){"use strict";"function"==typeof define&&define.amd?define(["jquery"],t):t(jQuery)}(function(b){"use strict";b.ui=b.ui||{};b.ui.version="1.13.3";var o,s=0,r=Array.prototype.hasOwnProperty,a=Array.prototype.slice,n=(b.cleanData=(o=b.cleanData,function(t){for(var e,s,i=0;null!=(s=t[i]);i++)(e=b._data(s,"events"))&&e.remove&&b(s).triggerHandler("remove");o(t)}),b.widget=function(t,s,e){var i,o,n,r={},a=t.split(".")[0],l=a+"-"+(t=t.split(".")[1]);return e||(e=s,s=b.Widget),Array.isArray(e)&&(e=b.extend.apply(null,[{}].concat(e))),b.expr.pseudos[l.toLowerCase()]=function(t){return!!b.data(t,l)},b[a]=b[a]||{},i=b[a][t],o=b[a][t]=function(t,e){if(!this||!this._createWidget)return new o(t,e);arguments.length&&this._createWidget(t,e)},b.extend(o,i,{version:e.version,_proto:b.extend({},e),_childConstructors:[]}),(n=new s).options=b.widget.extend({},n.options),b.each(e,function(e,i){function o(){return s.prototype[e].apply(this,arguments)}function n(t){return s.prototype[e].apply(this,t)}r[e]="function"!=typeof i?i:function(){var t,e=this._super,s=this._superApply;return this._super=o,this._superApply=n,t=i.apply(this,arguments),this._super=e,this._superApply=s,t}}),o.prototype=b.widget.extend(n,{widgetEventPrefix:i&&n.widgetEventPrefix||t},r,{constructor:o,namespace:a,widgetName:t,widgetFullName:l}),i?(b.each(i._childConstructors,function(t,e){var s=e.prototype;b.widget(s.namespace+"."+s.widgetName,o,e._proto)}),delete i._childConstructors):s._childConstructors.push(o),b.widget.bridge(t,o),o},b.widget.extend=function(t){for(var e,s,i=a.call(arguments,1),o=0,n=i.length;o<n;o++)for(e in i[o])s=i[o][e],r.call(i[o],e)&&void 0!==s&&(b.isPlainObject(s)?t[e]=b.isPlainObject(t[e])?b.widget.extend({},t[e],s):b.widget.extend({},s):t[e]=s);return t},b.widget.bridge=function(n,e){var r=e.prototype.widgetFullName||n;b.fn[n]=function(s){var t="string"==typeof s,i=a.call(arguments,1),o=this;return t?this.length||"instance"!==s?this.each(function(){var t,e=b.data(this,r);return"instance"===s?(o=e,!1):e?"function"!=typeof e[s]||"_"===s.charAt(0)?b.error("no such method '"+s+"' for "+n+" widget instance"):(t=e[s].apply(e,i))!==e&&void 0!==t?(o=t&&t.jquery?o.pushStack(t.get()):t,!1):void 0:b.error("cannot call methods on "+n+" prior to initialization; attempted to call method '"+s+"'")}):o=void 0:(i.length&&(s=b.widget.extend.apply(null,[s].concat(i))),this.each(function(){var t=b.data(this,r);t?(t.option(s||{}),t._init&&t._init()):b.data(this,r,new e(s,this))})),o}},b.Widget=function(){},b.Widget._childConstructors=[],b.Widget.prototype={widgetName:"widget",widgetEventPrefix:"",defaultElement:"<div>",options:{classes:{},disabled:!1,create:null},_createWidget:function(t,e){e=b(e||this.defaultElement||this)[0],this.element=b(e),this.uuid=s++,this.eventNamespace="."+this.widgetName+this.uuid,this.bindings=b(),this.hoverable=b(),this.focusable=b(),this.classesElementLookup={},e!==this&&(b.data(e,this.widgetFullName,this),this._on(!0,this.element,{remove:function(t){t.target===e&&this.destroy()}}),this.document=b(e.style?e.ownerDocument:e.document||e),this.window=b(this.document[0].defaultView||this.document[0].parentWindow)),this.options=b.widget.extend({},this.options,this._getCreateOptions(),t),this._create(),this.options.disabled&&this._setOptionDisabled(this.options.disabled),this._trigger("create",null,this._getCreateEventData()),this._init()},_getCreateOptions:function(){return{}},_getCreateEventData:b.noop,_create:b.noop,_init:b.noop,destroy:function(){var s=this;this._destroy(),b.each(this.classesElementLookup,function(t,e){s._removeClass(e,t)}),this.element.off(this.eventNamespace).removeData(this.widgetFullName),this.widget().off(this.eventNamespace).removeAttr("aria-disabled"),this.bindings.off(this.eventNamespace)},_destroy:b.noop,widget:function(){return this.element},option:function(t,e){var s,i,o,n=t;if(0===arguments.length)return b.widget.extend({},this.options);if("string"==typeof t)if(n={},t=(s=t.split(".")).shift(),s.length){for(i=n[t]=b.widget.extend({},this.options[t]),o=0;o<s.length-1;o++)i[s[o]]=i[s[o]]||{},i=i[s[o]];if(t=s.pop(),1===arguments.length)return void 0===i[t]?null:i[t];i[t]=e}else{if(1===arguments.length)return void 0===this.options[t]?null:this.options[t];n[t]=e}return this._setOptions(n),this},_setOptions:function(t){for(var e in t)this._setOption(e,t[e]);return this},_setOption:function(t,e){return"classes"===t&&this._setOptionClasses(e),this.options[t]=e,"disabled"===t&&this._setOptionDisabled(e),this},_setOptionClasses:function(t){var e,s,i;for(e in t)i=this.classesElementLookup[e],t[e]!==this.options.classes[e]&&i&&i.length&&(s=b(i.get()),this._removeClass(i,e),s.addClass(this._classes({element:s,keys:e,classes:t,add:!0})))},_setOptionDisabled:function(t){this._toggleClass(this.widget(),this.widgetFullName+"-disabled",null,!!t),t&&(this._removeClass(this.hoverable,null,"ui-state-hover"),this._removeClass(this.focusable,null,"ui-state-focus"))},enable:function(){return this._setOptions({disabled:!1})},disable:function(){return this._setOptions({disabled:!0})},_classes:function(o){var n=[],r=this;function t(t,e){for(var s,i=0;i<t.length;i++)s=r.classesElementLookup[t[i]]||b(),s=o.add?(function(){var s=[];o.element.each(function(t,e){b.map(r.classesElementLookup,function(t){return t}).some(function(t){return t.is(e)})||s.push(e)}),r._on(b(s),{remove:"_untrackClassesElement"})}(),b(b.uniqueSort(s.get().concat(o.element.get())))):b(s.not(o.element).get()),r.classesElementLookup[t[i]]=s,n.push(t[i]),e&&o.classes[t[i]]&&n.push(o.classes[t[i]])}return(o=b.extend({element:this.element,classes:this.options.classes||{}},o)).keys&&t(o.keys.match(/\S+/g)||[],!0),o.extra&&t(o.extra.match(/\S+/g)||[]),n.join(" ")},_untrackClassesElement:function(s){var i=this;b.each(i.classesElementLookup,function(t,e){-1!==b.inArray(s.target,e)&&(i.classesElementLookup[t]=b(e.not(s.target).get()))}),this._off(b(s.target))},_removeClass:function(t,e,s){return this._toggleClass(t,e,s,!1)},_addClass:function(t,e,s){return this._toggleClass(t,e,s,!0)},_toggleClass:function(t,e,s,i){var o="string"==typeof t||null===t,e={extra:o?e:s,keys:o?t:e,element:o?this.element:t,add:i="boolean"==typeof i?i:s};return e.element.toggleClass(this._classes(e),i),this},_on:function(o,n,t){var r,a=this;"boolean"!=typeof o&&(t=n,n=o,o=!1),t?(n=r=b(n),this.bindings=this.bindings.add(n)):(t=n,n=this.element,r=this.widget()),b.each(t,function(t,e){function s(){if(o||!0!==a.options.disabled&&!b(this).hasClass("ui-state-disabled"))return("string"==typeof e?a[e]:e).apply(a,arguments)}"string"!=typeof e&&(s.guid=e.guid=e.guid||s.guid||b.guid++);var t=t.match(/^([\w:-]*)\s*(.*)$/),i=t[1]+a.eventNamespace,t=t[2];t?r.on(i,t,s):n.on(i,s)})},_off:function(t,e){e=(e||"").split(" ").join(this.eventNamespace+" ")+this.eventNamespace,t.off(e),this.bindings=b(this.bindings.not(t).get()),this.focusable=b(this.focusable.not(t).get()),this.hoverable=b(this.hoverable.not(t).get())},_delay:function(t,e){var s=this;return setTimeout(function(){return("string"==typeof t?s[t]:t).apply(s,arguments)},e||0)},_hoverable:function(t){this.hoverable=this.hoverable.add(t),this._on(t,{mouseenter:function(t){this._addClass(b(t.currentTarget),null,"ui-state-hover")},mouseleave:function(t){this._removeClass(b(t.currentTarget),null,"ui-state-hover")}})},_focusable:function(t){this.focusable=this.focusable.add(t),this._on(t,{focusin:function(t){this._addClass(b(t.currentTarget),null,"ui-state-focus")},focusout:function(t){this._removeClass(b(t.currentTarget),null,"ui-state-focus")}})},_trigger:function(t,e,s){var i,o,n=this.options[t];if(s=s||{},(e=b.Event(e)).type=(t===this.widgetEventPrefix?t:this.widgetEventPrefix+t).toLowerCase(),e.target=this.element[0],o=e.originalEvent)for(i in o)i in e||(e[i]=o[i]);return this.element.trigger(e,s),!("function"==typeof n&&!1===n.apply(this.element[0],[e].concat(s))||e.isDefaultPrevented())}},b.each({show:"fadeIn",hide:"fadeOut"},function(n,r){b.Widget.prototype["_"+n]=function(e,t,s){var i,o=(t="string"==typeof t?{effect:t}:t)?!0!==t&&"number"!=typeof t&&t.effect||r:n;"number"==typeof(t=t||{})?t={duration:t}:!0===t&&(t={}),i=!b.isEmptyObject(t),t.complete=s,t.delay&&e.delay(t.delay),i&&b.effects&&b.effects.effect[o]?e[n](t):o!==n&&e[o]?e[o](t.duration,t.easing,s):e.queue(function(t){b(this)[n](),s&&s.call(e[0]),t()})}}),b.widget,b.extend(b.expr.pseudos,{data:b.expr.createPseudo?b.expr.createPseudo(function(e){return function(t){return!!b.data(t,e)}}):function(t,e,s){return!!b.data(t,s[3])}}),b.fn.scrollParent=function(t){var e=this.css("position"),s="absolute"===e,i=t?/(auto|scroll|hidden)/:/(auto|scroll)/,t=this.parents().filter(function(){var t=b(this);return(!s||"static"!==t.css("position"))&&i.test(t.css("overflow")+t.css("overflow-y")+t.css("overflow-x"))}).eq(0);return"fixed"!==e&&t.length?t:b(this[0].ownerDocument||document)},b.ui.ie=!!/msie [\w.]+/.exec(navigator.userAgent.toLowerCase()),!1);b(document).on("mouseup",function(){n=!1}),b.widget("ui.mouse",{version:"1.13.3",options:{cancel:"input, textarea, button, select, option",distance:1,delay:0},_mouseInit:function(){var e=this;this.element.on("mousedown."+this.widgetName,function(t){return e._mouseDown(t)}).on("click."+this.widgetName,function(t){if(!0===b.data(t.target,e.widgetName+".preventClickEvent"))return b.removeData(t.target,e.widgetName+".preventClickEvent"),t.stopImmediatePropagation(),!1}),this.started=!1},_mouseDestroy:function(){this.element.off("."+this.widgetName),this._mouseMoveDelegate&&this.document.off("mousemove."+this.widgetName,this._mouseMoveDelegate).off("mouseup."+this.widgetName,this._mouseUpDelegate)},_mouseDown:function(t){var e,s,i;if(!n)return this._mouseMoved=!1,this._mouseStarted&&this._mouseUp(t),s=1===(this._mouseDownEvent=t).which,i=!("string"!=typeof(e=this).options.cancel||!t.target.nodeName)&&b(t.target).closest(this.options.cancel).length,s&&!i&&this._mouseCapture(t)&&(this.mouseDelayMet=!this.options.delay,this.mouseDelayMet||(this._mouseDelayTimer=setTimeout(function(){e.mouseDelayMet=!0},this.options.delay)),this._mouseDistanceMet(t)&&this._mouseDelayMet(t)&&(this._mouseStarted=!1!==this._mouseStart(t),!this._mouseStarted)?t.preventDefault():(!0===b.data(t.target,this.widgetName+".preventClickEvent")&&b.removeData(t.target,this.widgetName+".preventClickEvent"),this._mouseMoveDelegate=function(t){return e._mouseMove(t)},this._mouseUpDelegate=function(t){return e._mouseUp(t)},this.document.on("mousemove."+this.widgetName,this._mouseMoveDelegate).on("mouseup."+this.widgetName,this._mouseUpDelegate),t.preventDefault(),n=!0)),!0},_mouseMove:function(t){if(this._mouseMoved){if(b.ui.ie&&(!document.documentMode||document.documentMode<9)&&!t.button)return this._mouseUp(t);if(!t.which)if(t.originalEvent.altKey||t.originalEvent.ctrlKey||t.originalEvent.metaKey||t.originalEvent.shiftKey)this.ignoreMissingWhich=!0;else if(!this.ignoreMissingWhich)return this._mouseUp(t)}return(t.which||t.button)&&(this._mouseMoved=!0),this._mouseStarted?(this._mouseDrag(t),t.preventDefault()):(this._mouseDistanceMet(t)&&this._mouseDelayMet(t)&&(this._mouseStarted=!1!==this._mouseStart(this._mouseDownEvent,t),this._mouseStarted?this._mouseDrag(t):this._mouseUp(t)),!this._mouseStarted)},_mouseUp:function(t){this.document.off("mousemove."+this.widgetName,this._mouseMoveDelegate).off("mouseup."+this.widgetName,this._mouseUpDelegate),this._mouseStarted&&(this._mouseStarted=!1,t.target===this._mouseDownEvent.target&&b.data(t.target,this.widgetName+".preventClickEvent",!0),this._mouseStop(t)),this._mouseDelayTimer&&(clearTimeout(this._mouseDelayTimer),delete this._mouseDelayTimer),this.ignoreMissingWhich=!1,n=!1,t.preventDefault()},_mouseDistanceMet:function(t){return Math.max(Math.abs(this._mouseDownEvent.pageX-t.pageX),Math.abs(this._mouseDownEvent.pageY-t.pageY))>=this.options.distance},_mouseDelayMet:function(){return this.mouseDelayMet},_mouseStart:function(){},_mouseDrag:function(){},_mouseStop:function(){},_mouseCapture:function(){return!0}}),b.ui.plugin={add:function(t,e,s){var i,o=b.ui[t].prototype;for(i in s)o.plugins[i]=o.plugins[i]||[],o.plugins[i].push([e,s[i]])},call:function(t,e,s,i){var o,n=t.plugins[e];if(n&&(i||t.element[0].parentNode&&11!==t.element[0].parentNode.nodeType))for(o=0;o<n.length;o++)t.options[n[o][0]]&&n[o][1].apply(t.element,s)}},b.ui.safeActiveElement=function(e){var s;try{s=e.activeElement}catch(t){s=e.body}return s=(s=s||e.body).nodeName?s:e.body},b.ui.safeBlur=function(t){t&&"body"!==t.nodeName.toLowerCase()&&b(t).trigger("blur")},b.widget("ui.draggable",b.ui.mouse,{version:"1.13.3",widgetEventPrefix:"drag",options:{addClasses:!0,appendTo:"parent",axis:!1,connectToSortable:!1,containment:!1,cursor:"auto",cursorAt:!1,grid:!1,handle:!1,helper:"original",iframeFix:!1,opacity:!1,refreshPositions:!1,revert:!1,revertDuration:500,scope:"default",scroll:!0,scrollSensitivity:20,scrollSpeed:20,snap:!1,snapMode:"both",snapTolerance:20,stack:!1,zIndex:!1,drag:null,start:null,stop:null},_create:function(){"original"===this.options.helper&&this._setPositionRelative(),this.options.addClasses&&this._addClass("ui-draggable"),this._setHandleClassName(),this._mouseInit()},_setOption:function(t,e){this._super(t,e),"handle"===t&&(this._removeHandleClassName(),this._setHandleClassName())},_destroy:function(){(this.helper||this.element).is(".ui-draggable-dragging")?this.destroyOnClear=!0:(this._removeHandleClassName(),this._mouseDestroy())},_mouseCapture:function(t){var e=this.options;return!(this.helper||e.disabled||0<b(t.target).closest(".ui-resizable-handle").length||(this.handle=this._getHandle(t),!this.handle)||(this._blurActiveElement(t),this._blockFrames(!0===e.iframeFix?"iframe":e.iframeFix),0))},_blockFrames:function(t){this.iframeBlocks=this.document.find(t).map(function(){var t=b(this);return b("<div>").css("position","absolute").appendTo(t.parent()).outerWidth(t.outerWidth()).outerHeight(t.outerHeight()).offset(t.offset())[0]})},_unblockFrames:function(){this.iframeBlocks&&(this.iframeBlocks.remove(),delete this.iframeBlocks)},_blurActiveElement:function(t){var e=b.ui.safeActiveElement(this.document[0]);b(t.target).closest(e).length||b.ui.safeBlur(e)},_mouseStart:function(t){var e=this.options;return this.helper=this._createHelper(t),this._addClass(this.helper,"ui-draggable-dragging"),this._cacheHelperProportions(),b.ui.ddmanager&&(b.ui.ddmanager.current=this),this._cacheMargins(),this.cssPosition=this.helper.css("position"),this.scrollParent=this.helper.scrollParent(!0),this.offsetParent=this.helper.offsetParent(),this.hasFixedAncestor=0<this.helper.parents().filter(function(){return"fixed"===b(this).css("position")}).length,this.positionAbs=this.element.offset(),this._refreshOffsets(t),this.originalPosition=this.position=this._generatePosition(t,!1),this.originalPageX=t.pageX,this.originalPageY=t.pageY,e.cursorAt&&this._adjustOffsetFromHelper(e.cursorAt),this._setContainment(),!1===this._trigger("start",t)?(this._clear(),!1):(this._cacheHelperProportions(),b.ui.ddmanager&&!e.dropBehaviour&&b.ui.ddmanager.prepareOffsets(this,t),this._mouseDrag(t,!0),b.ui.ddmanager&&b.ui.ddmanager.dragStart(this,t),!0)},_refreshOffsets:function(t){this.offset={top:this.positionAbs.top-this.margins.top,left:this.positionAbs.left-this.margins.left,scroll:!1,parent:this._getParentOffset(),relative:this._getRelativeOffset()},this.offset.click={left:t.pageX-this.offset.left,top:t.pageY-this.offset.top}},_mouseDrag:function(t,e){if(this.hasFixedAncestor&&(this.offset.parent=this._getParentOffset()),this.position=this._generatePosition(t,!0),this.positionAbs=this._convertPositionTo("absolute"),!e){e=this._uiHash();if(!1===this._trigger("drag",t,e))return this._mouseUp(new b.Event("mouseup",t)),!1;this.position=e.position}return this.helper[0].style.left=this.position.left+"px",this.helper[0].style.top=this.position.top+"px",b.ui.ddmanager&&b.ui.ddmanager.drag(this,t),!1},_mouseStop:function(t){var e=this,s=!1;return b.ui.ddmanager&&!this.options.dropBehaviour&&(s=b.ui.ddmanager.drop(this,t)),this.dropped&&(s=this.dropped,this.dropped=!1),"invalid"===this.options.revert&&!s||"valid"===this.options.revert&&s||!0===this.options.revert||"function"==typeof this.options.revert&&this.options.revert.call(this.element,s)?b(this.helper).animate(this.originalPosition,parseInt(this.options.revertDuration,10),function(){!1!==e._trigger("stop",t)&&e._clear()}):!1!==this._trigger("stop",t)&&this._clear(),!1},_mouseUp:function(t){return this._unblockFrames(),b.ui.ddmanager&&b.ui.ddmanager.dragStop(this,t),this.handleElement.is(t.target)&&this.element.trigger("focus"),b.ui.mouse.prototype._mouseUp.call(this,t)},cancel:function(){return this.helper.is(".ui-draggable-dragging")?this._mouseUp(new b.Event("mouseup",{target:this.element[0]})):this._clear(),this},_getHandle:function(t){return!this.options.handle||!!b(t.target).closest(this.element.find(this.options.handle)).length},_setHandleClassName:function(){this.handleElement=this.options.handle?this.element.find(this.options.handle):this.element,this._addClass(this.handleElement,"ui-draggable-handle")},_removeHandleClassName:function(){this._removeClass(this.handleElement,"ui-draggable-handle")},_createHelper:function(t){var e=this.options,s="function"==typeof e.helper,t=s?b(e.helper.apply(this.element[0],[t])):"clone"===e.helper?this.element.clone().removeAttr("id"):this.element;return t.parents("body").length||t.appendTo("parent"===e.appendTo?this.element[0].parentNode:e.appendTo),s&&t[0]===this.element[0]&&this._setPositionRelative(),t[0]===this.element[0]||/(fixed|absolute)/.test(t.css("position"))||t.css("position","absolute"),t},_setPositionRelative:function(){/^(?:r|a|f)/.test(this.element.css("position"))||(this.element[0].style.position="relative")},_adjustOffsetFromHelper:function(t){"string"==typeof t&&(t=t.split(" ")),"left"in(t=Array.isArray(t)?{left:+t[0],top:+t[1]||0}:t)&&(this.offset.click.left=t.left+this.margins.left),"right"in t&&(this.offset.click.left=this.helperProportions.width-t.right+this.margins.left),"top"in t&&(this.offset.click.top=t.top+this.margins.top),"bottom"in t&&(this.offset.click.top=this.helperProportions.height-t.bottom+this.margins.top)},_isRootNode:function(t){return/(html|body)/i.test(t.tagName)||t===this.document[0]},_getParentOffset:function(){var t=this.offsetParent.offset(),e=this.document[0];return"absolute"===this.cssPosition&&this.scrollParent[0]!==e&&b.contains(this.scrollParent[0],this.offsetParent[0])&&(t.left+=this.scrollParent.scrollLeft(),t.top+=this.scrollParent.scrollTop()),{top:(t=this._isRootNode(this.offsetParent[0])?{top:0,left:0}:t).top+(parseInt(this.offsetParent.css("borderTopWidth"),10)||0),left:t.left+(parseInt(this.offsetParent.css("borderLeftWidth"),10)||0)}},_getRelativeOffset:function(){var t,e;return"relative"!==this.cssPosition?{top:0,left:0}:(t=this.element.position(),e=this._isRootNode(this.scrollParent[0]),{top:t.top-(parseInt(this.helper.css("top"),10)||0)+(e?0:this.scrollParent.scrollTop()),left:t.left-(parseInt(this.helper.css("left"),10)||0)+(e?0:this.scrollParent.scrollLeft())})},_cacheMargins:function(){this.margins={left:parseInt(this.element.css("marginLeft"),10)||0,top:parseInt(this.element.css("marginTop"),10)||0,right:parseInt(this.element.css("marginRight"),10)||0,bottom:parseInt(this.element.css("marginBottom"),10)||0}},_cacheHelperProportions:function(){this.helperProportions={width:this.helper.outerWidth(),height:this.helper.outerHeight()}},_setContainment:function(){var t,e=this.options,s=this.document[0];this.relativeContainer=null,e.containment?"window"===e.containment?this.containment=[b(window).scrollLeft()-this.offset.relative.left-this.offset.parent.left,b(window).scrollTop()-this.offset.relative.top-this.offset.parent.top,b(window).scrollLeft()+b(window).width()-this.helperProportions.width-this.margins.left,b(window).scrollTop()+(b(window).height()||s.body.parentNode.scrollHeight)-this.helperProportions.height-this.margins.top]:"document"===e.containment?this.containment=[0,0,b(s).width()-this.helperProportions.width-this.margins.left,(b(s).height()||s.body.parentNode.scrollHeight)-this.helperProportions.height-this.margins.top]:e.containment.constructor===Array?this.containment=e.containment:("parent"===e.containment&&(e.containment=this.helper[0].parentNode),(e=(s=b(e.containment))[0])&&(t=/(scroll|auto)/.test(s.css("overflow")),this.containment=[(parseInt(s.css("borderLeftWidth"),10)||0)+(parseInt(s.css("paddingLeft"),10)||0),(parseInt(s.css("borderTopWidth"),10)||0)+(parseInt(s.css("paddingTop"),10)||0),(t?Math.max(e.scrollWidth,e.offsetWidth):e.offsetWidth)-(parseInt(s.css("borderRightWidth"),10)||0)-(parseInt(s.css("paddingRight"),10)||0)-this.helperProportions.width-this.margins.left-this.margins.right,(t?Math.max(e.scrollHeight,e.offsetHeight):e.offsetHeight)-(parseInt(s.css("borderBottomWidth"),10)||0)-(parseInt(s.css("paddingBottom"),10)||0)-this.helperProportions.height-this.margins.top-this.margins.bottom],this.relativeContainer=s)):this.containment=null},_convertPositionTo:function(t,e){e=e||this.position;var t="absolute"===t?1:-1,s=this._isRootNode(this.scrollParent[0]);return{top:e.top+this.offset.relative.top*t+this.offset.parent.top*t-("fixed"===this.cssPosition?-this.offset.scroll.top:s?0:this.offset.scroll.top)*t,left:e.left+this.offset.relative.left*t+this.offset.parent.left*t-("fixed"===this.cssPosition?-this.offset.scroll.left:s?0:this.offset.scroll.left)*t}},_generatePosition:function(t,e){var s,i=this.options,o=this._isRootNode(this.scrollParent[0]),n=t.pageX,r=t.pageY;return o&&this.offset.scroll||(this.offset.scroll={top:this.scrollParent.scrollTop(),left:this.scrollParent.scrollLeft()}),{top:(r=e&&(this.containment&&(s=this.relativeContainer?(e=this.relativeContainer.offset(),[this.containment[0]+e.left,this.containment[1]+e.top,this.containment[2]+e.left,this.containment[3]+e.top]):this.containment,t.pageX-this.offset.click.left<s[0]&&(n=s[0]+this.offset.click.left),t.pageY-this.offset.click.top<s[1]&&(r=s[1]+this.offset.click.top),t.pageX-this.offset.click.left>s[2]&&(n=s[2]+this.offset.click.left),t.pageY-this.offset.click.top>s[3])&&(r=s[3]+this.offset.click.top),i.grid&&(e=i.grid[1]?this.originalPageY+Math.round((r-this.originalPageY)/i.grid[1])*i.grid[1]:this.originalPageY,r=!s||e-this.offset.click.top>=s[1]||e-this.offset.click.top>s[3]?e:e-this.offset.click.top>=s[1]?e-i.grid[1]:e+i.grid[1],t=i.grid[0]?this.originalPageX+Math.round((n-this.originalPageX)/i.grid[0])*i.grid[0]:this.originalPageX,n=!s||t-this.offset.click.left>=s[0]||t-this.offset.click.left>s[2]?t:t-this.offset.click.left>=s[0]?t-i.grid[0]:t+i.grid[0]),"y"===i.axis&&(n=this.originalPageX),"x"===i.axis)?this.originalPageY:r)-this.offset.click.top-this.offset.relative.top-this.offset.parent.top+("fixed"===this.cssPosition?-this.offset.scroll.top:o?0:this.offset.scroll.top),left:n-this.offset.click.left-this.offset.relative.left-this.offset.parent.left+("fixed"===this.cssPosition?-this.offset.scroll.left:o?0:this.offset.scroll.left)}},_clear:function(){this._removeClass(this.helper,"ui-draggable-dragging"),this.helper[0]===this.element[0]||this.cancelHelperRemoval||this.helper.remove(),this.helper=null,this.cancelHelperRemoval=!1,this.destroyOnClear&&this.destroy()},_trigger:function(t,e,s){return s=s||this._uiHash(),b.ui.plugin.call(this,t,[e,s,this],!0),/^(drag|start|stop)/.test(t)&&(this.positionAbs=this._convertPositionTo("absolute"),s.offset=this.positionAbs),b.Widget.prototype._trigger.call(this,t,e,s)},plugins:{},_uiHash:function(){return{helper:this.helper,position:this.position,originalPosition:this.originalPosition,offset:this.positionAbs}}}),b.ui.plugin.add("draggable","connectToSortable",{start:function(e,t,s){var i=b.extend({},t,{item:s.element});s.sortables=[],b(s.options.connectToSortable).each(function(){var t=b(this).sortable("instance");t&&!t.options.disabled&&(s.sortables.push(t),t.refreshPositions(),t._trigger("activate",e,i))})},stop:function(e,t,s){var i=b.extend({},t,{item:s.element});s.cancelHelperRemoval=!1,b.each(s.sortables,function(){var t=this;t.isOver?(t.isOver=0,s.cancelHelperRemoval=!0,t.cancelHelperRemoval=!1,t._storedCSS={position:t.placeholder.css("position"),top:t.placeholder.css("top"),left:t.placeholder.css("left")},t._mouseStop(e),t.options.helper=t.options._helper):(t.cancelHelperRemoval=!0,t._trigger("deactivate",e,i))})},drag:function(s,i,o){b.each(o.sortables,function(){var t=!1,e=this;e.positionAbs=o.positionAbs,e.helperProportions=o.helperProportions,e.offset.click=o.offset.click,e._intersectsWith(e.containerCache)&&(t=!0,b.each(o.sortables,function(){return this.positionAbs=o.positionAbs,this.helperProportions=o.helperProportions,this.offset.click=o.offset.click,t=this!==e&&this._intersectsWith(this.containerCache)&&b.contains(e.element[0],this.element[0])?!1:t})),t?(e.isOver||(e.isOver=1,o._parent=i.helper.parent(),e.currentItem=i.helper.appendTo(e.element).data("ui-sortable-item",!0),e.options._helper=e.options.helper,e.options.helper=function(){return i.helper[0]},s.target=e.currentItem[0],e._mouseCapture(s,!0),e._mouseStart(s,!0,!0),e.offset.click.top=o.offset.click.top,e.offset.click.left=o.offset.click.left,e.offset.parent.left-=o.offset.parent.left-e.offset.parent.left,e.offset.parent.top-=o.offset.parent.top-e.offset.parent.top,o._trigger("toSortable",s),o.dropped=e.element,b.each(o.sortables,function(){this.refreshPositions()}),o.currentItem=o.element,e.fromOutside=o),e.currentItem&&(e._mouseDrag(s),i.position=e.position)):e.isOver&&(e.isOver=0,e.cancelHelperRemoval=!0,e.options._revert=e.options.revert,e.options.revert=!1,e._trigger("out",s,e._uiHash(e)),e._mouseStop(s,!0),e.options.revert=e.options._revert,e.options.helper=e.options._helper,e.placeholder&&e.placeholder.remove(),i.helper.appendTo(o._parent),o._refreshOffsets(s),i.position=o._generatePosition(s,!0),o._trigger("fromSortable",s),o.dropped=!1,b.each(o.sortables,function(){this.refreshPositions()}))})}}),b.ui.plugin.add("draggable","cursor",{start:function(t,e,s){var i=b("body"),s=s.options;i.css("cursor")&&(s._cursor=i.css("cursor")),i.css("cursor",s.cursor)},stop:function(t,e,s){s=s.options;s._cursor&&b("body").css("cursor",s._cursor)}}),b.ui.plugin.add("draggable","opacity",{start:function(t,e,s){e=b(e.helper),s=s.options;e.css("opacity")&&(s._opacity=e.css("opacity")),e.css("opacity",s.opacity)},stop:function(t,e,s){s=s.options;s._opacity&&b(e.helper).css("opacity",s._opacity)}}),b.ui.plugin.add("draggable","scroll",{start:function(t,e,s){s.scrollParentNotHidden||(s.scrollParentNotHidden=s.helper.scrollParent(!1)),s.scrollParentNotHidden[0]!==s.document[0]&&"HTML"!==s.scrollParentNotHidden[0].tagName&&(s.overflowOffset=s.scrollParentNotHidden.offset())},drag:function(t,e,s){var i=s.options,o=!1,n=s.scrollParentNotHidden[0],r=s.document[0];n!==r&&"HTML"!==n.tagName?(i.axis&&"x"===i.axis||(s.overflowOffset.top+n.offsetHeight-t.pageY<i.scrollSensitivity?n.scrollTop=o=n.scrollTop+i.scrollSpeed:t.pageY-s.overflowOffset.top<i.scrollSensitivity&&(n.scrollTop=o=n.scrollTop-i.scrollSpeed)),i.axis&&"y"===i.axis||(s.overflowOffset.left+n.offsetWidth-t.pageX<i.scrollSensitivity?n.scrollLeft=o=n.scrollLeft+i.scrollSpeed:t.pageX-s.overflowOffset.left<i.scrollSensitivity&&(n.scrollLeft=o=n.scrollLeft-i.scrollSpeed))):(i.axis&&"x"===i.axis||(t.pageY-b(r).scrollTop()<i.scrollSensitivity?o=b(r).scrollTop(b(r).scrollTop()-i.scrollSpeed):b(window).height()-(t.pageY-b(r).scrollTop())<i.scrollSensitivity&&(o=b(r).scrollTop(b(r).scrollTop()+i.scrollSpeed))),i.axis&&"y"===i.axis||(t.pageX-b(r).scrollLeft()<i.scrollSensitivity?o=b(r).scrollLeft(b(r).scrollLeft()-i.scrollSpeed):b(window).width()-(t.pageX-b(r).scrollLeft())<i.scrollSensitivity&&(o=b(r).scrollLeft(b(r).scrollLeft()+i.scrollSpeed)))),!1!==o&&b.ui.ddmanager&&!i.dropBehaviour&&b.ui.ddmanager.prepareOffsets(s,t)}}),b.ui.plugin.add("draggable","snap",{start:function(t,e,s){var i=s.options;s.snapElements=[],b(i.snap.constructor!==String?i.snap.items||":data(ui-draggable)":i.snap).each(function(){var t=b(this),e=t.offset();this!==s.element[0]&&s.snapElements.push({item:this,width:t.outerWidth(),height:t.outerHeight(),top:e.top,left:e.left})})},drag:function(t,e,s){for(var i,o,n,r,a,l,h,p,c,f=s.options,u=f.snapTolerance,d=e.offset.left,g=d+s.helperProportions.width,m=e.offset.top,_=m+s.helperProportions.height,v=s.snapElements.length-1;0<=v;v--)l=(a=s.snapElements[v].left-s.margins.left)+s.snapElements[v].width,p=(h=s.snapElements[v].top-s.margins.top)+s.snapElements[v].height,g<a-u||l+u<d||_<h-u||p+u<m||!b.contains(s.snapElements[v].item.ownerDocument,s.snapElements[v].item)?(s.snapElements[v].snapping&&s.options.snap.release&&s.options.snap.release.call(s.element,t,b.extend(s._uiHash(),{snapItem:s.snapElements[v].item})),s.snapElements[v].snapping=!1):("inner"!==f.snapMode&&(i=Math.abs(h-_)<=u,o=Math.abs(p-m)<=u,n=Math.abs(a-g)<=u,r=Math.abs(l-d)<=u,i&&(e.position.top=s._convertPositionTo("relative",{top:h-s.helperProportions.height,left:0}).top),o&&(e.position.top=s._convertPositionTo("relative",{top:p,left:0}).top),n&&(e.position.left=s._convertPositionTo("relative",{top:0,left:a-s.helperProportions.width}).left),r)&&(e.position.left=s._convertPositionTo("relative",{top:0,left:l}).left),c=i||o||n||r,"outer"!==f.snapMode&&(i=Math.abs(h-m)<=u,o=Math.abs(p-_)<=u,n=Math.abs(a-d)<=u,r=Math.abs(l-g)<=u,i&&(e.position.top=s._convertPositionTo("relative",{top:h,left:0}).top),o&&(e.position.top=s._convertPositionTo("relative",{top:p-s.helperProportions.height,left:0}).top),n&&(e.position.left=s._convertPositionTo("relative",{top:0,left:a}).left),r)&&(e.position.left=s._convertPositionTo("relative",{top:0,left:l-s.helperProportions.width}).left),!s.snapElements[v].snapping&&(i||o||n||r||c)&&s.options.snap.snap&&s.options.snap.snap.call(s.element,t,b.extend(s._uiHash(),{snapItem:s.snapElements[v].item})),s.snapElements[v].snapping=i||o||n||r||c)}}),b.ui.plugin.add("draggable","stack",{start:function(t,e,s){var i,s=s.options,s=b.makeArray(b(s.stack)).sort(function(t,e){return(parseInt(b(t).css("zIndex"),10)||0)-(parseInt(b(e).css("zIndex"),10)||0)});s.length&&(i=parseInt(b(s[0]).css("zIndex"),10)||0,b(s).each(function(t){b(this).css("zIndex",i+t)}),this.css("zIndex",i+s.length))}}),b.ui.plugin.add("draggable","zIndex",{start:function(t,e,s){e=b(e.helper),s=s.options;e.css("zIndex")&&(s._zIndex=e.css("zIndex")),e.css("zIndex",s.zIndex)},stop:function(t,e,s){s=s.options;s._zIndex&&b(e.helper).css("zIndex",s._zIndex)}}),b.ui.draggable});
//}
var htmlMain = '<div class="wrap-popupocinstuctor">\
\
        <div class="polosa"></div>\
        <div class="s-speed">\
            <span class="s-speed-1">Скорость сек.</span>\
            <span class="s-speed-2">\
                  <input min="0.1" onchange="return change_speed(this);" type="number" value="3" class="s_speed" name="s_speed">\
            </span>\
        </div>\
		<div class="s-speed s-disketa s-sbros" title="Очистить всю анимацию-Сбросить" onclick="return sbros(this);">🧹</div>\
			\
        <div class="main-popup">\
\
            <div class="wr-shesterenka">\
                <div class="shesterenka" onclick="shest_set_pos(this);">⚙</div>\
                <div class="wr-shesterenka-text">\
                    <span class="shesterenka-text">Настроить</span>\
                    <span class="shesterenka-text">Aнимацию</span>\
                </div>\
            </div>\
            <div class="main-content">\
                <form class="eff-full">\
                    <div class="wr-js-all">\
                        <div class="jcol-1">\
                                                                                                <div class="wr-input delimiter"><b>Базовые эффекты</b></div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="circle_left" onchange="return setClassEffect(this, \'circle_left\');" type="checkbox" value="circle_left" class="eff-link eff-yes-groupp" id="circle_left">\
                                        <label title="Вращение против часовой стрелки" for="circle_left" class="eff-label">Вращение против часовой стрелки</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="circle_right" onchange="return setClassEffect(this, \'circle_right\');" type="checkbox" value="circle_right" class="eff-link eff-yes-groupp" id="circle_right">\
                                        <label title="Вращение по часовой стрелке" for="circle_right" class="eff-label">Вращение по часовой стрелке</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="opacity_up" onchange="return setClassEffect(this, \'opacity_up\');" type="checkbox" value="opacity_up" class="eff-link eff-yes-groupp" id="opacity_up">\
                                        <label title="Прозрачность 0%-100%(появление, однократно)" for="opacity_up" class="eff-label">Прозрачность 0%-100%(появление, однократно)</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="opacity_down" onchange="return setClassEffect(this, \'opacity_down\');" type="checkbox" value="opacity_down" class="eff-link eff-yes-groupp" id="opacity_down">\
                                        <label title="Прозрачность 100%-0%(исчезновение, однократно)" for="opacity_down" class="eff-label">Прозрачность 100%-0%(исчезновение, однократно)</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotate_x" onchange="return setClassEffect(this, \'rotate_x\');" type="checkbox" value="rotate_x" class="eff-link eff-yes-groupp" id="rotate_x">\
                                        <label title="Вращение по X" for="rotate_x" class="eff-label">Вращение по X</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotate_y" onchange="return setClassEffect(this, \'rotate_y\');" type="checkbox" value="rotate_y" class="eff-link eff-yes-groupp" id="rotate_y">\
                                        <label title="Вращение по Y" for="rotate_y" class="eff-label">Вращение по Y</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="opacity_up_mnogo" onchange="return setClassEffect(this, \'opacity_up_mnogo\');" type="checkbox" value="opacity_up_mnogo" class="eff-link eff-yes-groupp" id="opacity_up_mnogo">\
                                        <label title="Прозрачность 0%-100%-0%, несколько раз" for="opacity_up_mnogo" class="eff-label">Прозрачность 0%-100%-0%, несколько раз</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="opacity_down_mnogo" onchange="return setClassEffect(this, \'opacity_down_mnogo\');" type="checkbox" value="opacity_down_mnogo" class="eff-link eff-yes-groupp" id="opacity_down_mnogo">\
                                        <label title="Прозрачность 100%-0%-100%, несколько раз" for="opacity_down_mnogo" class="eff-label">Прозрачность 100%-0%-100%, несколько раз</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotate_repspective_x_1" onchange="return setClassEffect(this, \'rotate_repspective_x_1\');" type="checkbox" value="rotate_repspective_x_1" class="eff-link eff-yes-groupp" id="rotate_repspective_x_1">\
                                        <label title="Перспектива, вращение по X низ К себе" for="rotate_repspective_x_1" class="eff-label">Перспектива, вращение по X низ К себе</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotate_repspective_x_2" onchange="return setClassEffect(this, \'rotate_repspective_x_2\');" type="checkbox" value="rotate_repspective_x_2" class="eff-link eff-yes-groupp" id="rotate_repspective_x_2">\
                                        <label title="Перспектива, вращение по X низ ОТ себе" for="rotate_repspective_x_2" class="eff-label">Перспектива, вращение по X низ ОТ себе</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotate_repspective_y_1" onchange="return setClassEffect(this, \'rotate_repspective_y_1\');" type="checkbox" value="rotate_repspective_y_1" class="eff-link eff-yes-groupp" id="rotate_repspective_y_1">\
                                        <label title="Перспектива, вращение по Y левая грань К себе" for="rotate_repspective_y_1" class="eff-label">Перспектива, вращение по Y левая грань К себе</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotate_repspective_y_2" onchange="return setClassEffect(this, \'rotate_repspective_y_2\');" type="checkbox" value="rotate_repspective_y_2" class="eff-link eff-yes-groupp" id="rotate_repspective_y_2">\
                                        <label title="Перспектива, вращение по Y левая грань ОТ себя" for="rotate_repspective_y_2" class="eff-label">Перспектива, вращение по Y левая грань ОТ себя</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="from_small_to_big" onchange="return setClassEffect(this, \'from_small_to_big\');" type="checkbox" value="from_small_to_big" class="eff-link eff-yes-groupp" id="from_small_to_big">\
                                        <label title="Увеличение 0%-100%-0%" for="from_small_to_big" class="eff-label">Увеличение 0%-100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="from_big_to_small" onchange="return setClassEffect(this, \'from_big_to_small\');" type="checkbox" value="from_big_to_small" class="eff-link eff-yes-groupp" id="from_big_to_small">\
                                        <label title="Уменьшение 100%-0%-100%" for="from_big_to_small" class="eff-label">Уменьшение 100%-0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="wolna_eff" onchange="return setClassEffect(this, \'wolna_eff\');" type="checkbox" value="wolna_eff" class="eff-link eff-yes-groupp" id="wolna_eff">\
                                        <label title="Расходящиеся волны(брошенный в воду камень)" for="wolna_eff" class="eff-label">Расходящиеся волны(брошенный в воду камень)</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="telefon" onchange="return setClassEffect(this, \'telefon\');" type="checkbox" value="telefon" class="eff-link eff-yes-groupp" id="telefon">\
                                        <label title="Дрожащая трубка(звонит телефон)" for="telefon" class="eff-label">Дрожащая трубка(звонит телефон)</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bg_left" onchange="return setClassEffect(this, \'bg_left\');" type="checkbox" value="bg_left" class="eff-link eff-yes-groupp" id="bg_left">\
                                        <label title="Сдвиг фона влево" for="bg_left" class="eff-label">Сдвиг фона влево</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bg_right" onchange="return setClassEffect(this, \'bg_right\');" type="checkbox" value="bg_right" class="eff-link eff-yes-groupp" id="bg_right">\
                                        <label title="Сдвиг фона вправо" for="bg_right" class="eff-label">Сдвиг фона вправо</label>\
                                    </div>\
                                                                                                                                <div class="wr-input delimiter"><b>Одиночные эффекты.</b></div>\
                                                                                                                                <div class="wr-input delimiter"><b>Группа эффектов - привлечение внимания:</b></div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="flip1" onchange="return setClassEffect(this, \'flip1\');" type="checkbox" value="flip1" class="eff-link eff-no-groupp" id="flip1">\
                                        <label title="Перелистывание" for="flip1" class="eff-label">Перелистывание</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rubber" onchange="return setClassEffect(this, \'rubber\');" type="checkbox" value="rubber" class="eff-link eff-no-groupp" id="rubber">\
                                        <label title="Резиновый мячик" for="rubber" class="eff-label">Резиновый мячик</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bounce" onchange="return setClassEffect(this, \'bounce\');" type="checkbox" value="bounce" class="eff-link eff-no-groupp" id="bounce">\
                                        <label title="Подпрыгивание на месте" for="bounce" class="eff-label">Подпрыгивание на месте</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bounceballbottom" onchange="return setClassEffect(this, \'bounceballbottom\');" type="checkbox" value="bounceballbottom" class="eff-link eff-no-groupp" id="bounceballbottom">\
                                        <label title="Мячик прыгает на полу" for="bounceballbottom" class="eff-label">Мячик прыгает на полу</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="flash" onchange="return setClassEffect(this, \'flash\');" type="checkbox" value="flash" class="eff-link eff-no-groupp" id="flash">\
                                        <label title="Мелькание" for="flash" class="eff-label">Мелькание</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="pulse" onchange="return setClassEffect(this, \'pulse\');" type="checkbox" value="pulse" class="eff-link eff-no-groupp" id="pulse">\
                                        <label title="Пульс" for="pulse" class="eff-label">Пульс</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="shake" onchange="return setClassEffect(this, \'shake\');" type="checkbox" value="shake" class="eff-link eff-no-groupp" id="shake">\
                                        <label title="Тряска" for="shake" class="eff-label">Тряска</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swing" onchange="return setClassEffect(this, \'swing\');" type="checkbox" value="swing" class="eff-link eff-no-groupp" id="swing">\
                                        <label title="Маятник" for="swing" class="eff-label">Маятник</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="tada" onchange="return setClassEffect(this, \'tada\');" type="checkbox" value="tada" class="eff-link eff-no-groupp" id="tada">\
                                        <label title="Эмоция: вот он я" for="tada" class="eff-label">Эмоция: вот он я</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="wobble" onchange="return setClassEffect(this, \'wobble\');" type="checkbox" value="wobble" class="eff-link eff-no-groupp" id="wobble">\
                                        <label title="Колебания по X" for="wobble" class="eff-label">Колебания по X</label>\
                                    </div>\
                                                                                                                                <div class="wr-input delimiter"><b>Группа эффектов - появление:</b></div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="flipinx" onchange="return setClassEffect(this, \'flipinx\');" type="checkbox" value="flipinx" class="eff-link eff-no-groupp" id="flipinx">\
                                        <label title="Перелистывание по X и прозрачность 0%-100%" for="flipinx" class="eff-label">Перелистывание по X и прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="flipiny" onchange="return setClassEffect(this, \'flipiny\');" type="checkbox" value="flipiny" class="eff-link eff-no-groupp" id="flipiny">\
                                        <label title="Перелистывание по Y и прозрачность 0%-100%" for="flipiny" class="eff-label">Перелистывание по Y и прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="speedin" onchange="return setClassEffect(this, \'speedin\');" type="checkbox" value="speedin" class="eff-link eff-no-groupp" id="speedin">\
                                        <label title="Стремительный влёт" for="speedin" class="eff-label">Стремительный влёт</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="slideindown" onchange="return setClassEffect(this, \'slideindown\');" type="checkbox" value="slideindown" class="eff-link eff-no-groupp" id="slideindown">\
                                        <label title="Вскальзывание(slide) сверху-вниз" for="slideindown" class="eff-label">Вскальзывание(slide) сверху-вниз</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="slideinleft" onchange="return setClassEffect(this, \'slideinleft\');" type="checkbox" value="slideinleft" class="eff-link eff-no-groupp" id="slideinleft">\
                                        <label title="Вскальзывание(slide) слева-направо" for="slideinleft" class="eff-label">Вскальзывание(slide) слева-направо</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="slideinright" onchange="return setClassEffect(this, \'slideinright\');" type="checkbox" value="slideinright" class="eff-link eff-no-groupp" id="slideinright">\
                                        <label title="Вскальзывание(slide) справа-налево" for="slideinright" class="eff-label">Вскальзывание(slide) справа-налево</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="slideinup" onchange="return setClassEffect(this, \'slideinup\');" type="checkbox" value="slideinup" class="eff-link eff-no-groupp" id="slideinup">\
                                        <label title="Вскальзывание(slide) снизу-вверх" for="slideinup" class="eff-label">Вскальзывание(slide) снизу-вверх</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeindown" onchange="return setClassEffect(this, \'fadeindown\');" type="checkbox" value="fadeindown" class="eff-link eff-no-groupp" id="fadeindown">\
                                        <label title="Вскальзывание(slide) сверху + прозрачность 0%-100%" for="fadeindown" class="eff-label">Вскальзывание(slide) сверху + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeindownbig" onchange="return setClassEffect(this, \'fadeindownbig\');" type="checkbox" value="fadeindownbig" class="eff-link eff-no-groupp" id="fadeindownbig">\
                                        <label title="Вскальзывание(slide) сверху издалека + прозрачность 0%-100%" for="fadeindownbig" class="eff-label">Вскальзывание(slide) сверху издалека + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeinleft" onchange="return setClassEffect(this, \'fadeinleft\');" type="checkbox" value="fadeinleft" class="eff-link eff-no-groupp" id="fadeinleft">\
                                        <label title="Вскальзывание(slide) слева + прозрачность 0%-100%" for="fadeinleft" class="eff-label">Вскальзывание(slide) слева + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeinleftbig" onchange="return setClassEffect(this, \'fadeinleftbig\');" type="checkbox" value="fadeinleftbig" class="eff-link eff-no-groupp" id="fadeinleftbig">\
                                        <label title="Вскальзывание(slide) слева издалека + прозрачность 0%-100%" for="fadeinleftbig" class="eff-label">Вскальзывание(slide) слева издалека + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeinright" onchange="return setClassEffect(this, \'fadeinright\');" type="checkbox" value="fadeinright" class="eff-link eff-no-groupp" id="fadeinright">\
                                        <label title="Вскальзывание(slide) справа + прозрачность 0%-100%" for="fadeinright" class="eff-label">Вскальзывание(slide) справа + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeinrightbig" onchange="return setClassEffect(this, \'fadeinrightbig\');" type="checkbox" value="fadeinrightbig" class="eff-link eff-no-groupp" id="fadeinrightbig">\
                                        <label title="Вскальзывание(slide) справа издалека + прозрачность 0%-100%" for="fadeinrightbig" class="eff-label">Вскальзывание(slide) справа издалека + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeinup" onchange="return setClassEffect(this, \'fadeinup\');" type="checkbox" value="fadeinup" class="eff-link eff-no-groupp" id="fadeinup">\
                                        <label title="Вскальзывание(slide) снизу-вверх + прозрачность 0%-100%" for="fadeinup" class="eff-label">Вскальзывание(slide) снизу-вверх + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeinupbig" onchange="return setClassEffect(this, \'fadeinupbig\');" type="checkbox" value="fadeinupbig" class="eff-link eff-no-groupp" id="fadeinupbig">\
                                        <label title="Вскальзывание(slide) снизу-вверх издалека + прозрачность 0%-100%" for="fadeinupbig" class="eff-label">Вскальзывание(slide) снизу-вверх издалека + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="zoomin" onchange="return setClassEffect(this, \'zoomin\');" type="checkbox" value="zoomin" class="eff-link eff-no-groupp" id="zoomin">\
                                        <label title="Увеличение + прозрачность 0%-100%" for="zoomin" class="eff-label">Увеличение + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="zoomindown" onchange="return setClassEffect(this, \'zoomindown\');" type="checkbox" value="zoomindown" class="eff-link eff-no-groupp" id="zoomindown">\
                                        <label title="Увеличение-влёт + прозрачность 0%-100% сверху" for="zoomindown" class="eff-label">Увеличение-влёт + прозрачность 0%-100% сверху</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="zoominleft" onchange="return setClassEffect(this, \'zoominleft\');" type="checkbox" value="zoominleft" class="eff-link eff-no-groupp" id="zoominleft">\
                                        <label title="Увеличение-влёт + прозрачность 0%-100% слева" for="zoominleft" class="eff-label">Увеличение-влёт + прозрачность 0%-100% слева</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="zoominright" onchange="return setClassEffect(this, \'zoominright\');" type="checkbox" value="zoominright" class="eff-link eff-no-groupp" id="zoominright">\
                                        <label title="Увеличение-влёт + прозрачность 0%-100% справа" for="zoominright" class="eff-label">Увеличение-влёт + прозрачность 0%-100% справа</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="zoominup" onchange="return setClassEffect(this, \'zoominup\');" type="checkbox" value="zoominup" class="eff-link eff-no-groupp" id="zoominup">\
                                        <label title="Увеличение-влёт + прозрачность 0%-100% снизу-вверх" for="zoominup" class="eff-label">Увеличение-влёт + прозрачность 0%-100% снизу-вверх</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bouncein" onchange="return setClassEffect(this, \'bouncein\');" type="checkbox" value="bouncein" class="eff-link eff-no-groupp" id="bouncein">\
                                        <label title="Подпрыгивание вперед-назад" for="bouncein" class="eff-label">Подпрыгивание вперед-назад</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bounceindown" onchange="return setClassEffect(this, \'bounceindown\');" type="checkbox" value="bounceindown" class="eff-link eff-no-groupp" id="bounceindown">\
                                        <label title="Впрыгивание сверху" for="bounceindown" class="eff-label">Впрыгивание сверху</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bounceinleft" onchange="return setClassEffect(this, \'bounceinleft\');" type="checkbox" value="bounceinleft" class="eff-link eff-no-groupp" id="bounceinleft">\
                                        <label title="Впрыгивание слева" for="bounceinleft" class="eff-label">Впрыгивание слева</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bounceinright" onchange="return setClassEffect(this, \'bounceinright\');" type="checkbox" value="bounceinright" class="eff-link eff-no-groupp" id="bounceinright">\
                                        <label title="Впрыгивание справа" for="bounceinright" class="eff-label">Впрыгивание справа</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bounceinup" onchange="return setClassEffect(this, \'bounceinup\');" type="checkbox" value="bounceinup" class="eff-link eff-no-groupp" id="bounceinup">\
                                        <label title="Впрыгивание снизу-вверх" for="bounceinup" class="eff-label">Впрыгивание снизу-вверх</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotatein" onchange="return setClassEffect(this, \'rotatein\');" type="checkbox" value="rotatein" class="eff-link eff-no-groupp" id="rotatein">\
                                        <label title="Поворот по часовой + прозрачность 0%-100%" for="rotatein" class="eff-label">Поворот по часовой + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotateindownleft" onchange="return setClassEffect(this, \'rotateindownleft\');" type="checkbox" value="rotateindownleft" class="eff-link eff-no-groupp" id="rotateindownleft">\
                                        <label title="Выпал слева сверху-вниз + прозрачность 0%-100%" for="rotateindownleft" class="eff-label">Выпал слева сверху-вниз + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotateindownright" onchange="return setClassEffect(this, \'rotateindownright\');" type="checkbox" value="rotateindownright" class="eff-link eff-no-groupp" id="rotateindownright">\
                                        <label title="Выпал справа сверху-вниз + прозрачность 0%-100%" for="rotateindownright" class="eff-label">Выпал справа сверху-вниз + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotateinupleft" onchange="return setClassEffect(this, \'rotateinupleft\');" type="checkbox" value="rotateinupleft" class="eff-link eff-no-groupp" id="rotateinupleft">\
                                        <label title="Выпал слева снизу-вверх + прозрачность 0%-100%" for="rotateinupleft" class="eff-label">Выпал слева снизу-вверх + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotateinupright" onchange="return setClassEffect(this, \'rotateinupright\');" type="checkbox" value="rotateinupright" class="eff-link eff-no-groupp" id="rotateinupright">\
                                        <label title="Выпал справа снизу-вверх + прозрачность 0%-100%" for="rotateinupright" class="eff-label">Выпал справа снизу-вверх + прозрачность 0%-100%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirlinfwd" onchange="return setClassEffect(this, \'swirlinfwd\');" type="checkbox" value="swirlinfwd" class="eff-link eff-no-groupp" id="swirlinfwd">\
                                        <label title="Воронка появление вперед снизу" for="swirlinfwd" class="eff-label">Воронка появление вперед снизу</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirlinfwdcenter" onchange="return setClassEffect(this, \'swirlinfwdcenter\');" type="checkbox" value="swirlinfwdcenter" class="eff-link eff-no-groupp" id="swirlinfwdcenter">\
                                        <label title="Воронка появление вперед по центру" for="swirlinfwdcenter" class="eff-label">Воронка появление вперед по центру</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirlinfwdleft" onchange="return setClassEffect(this, \'swirlinfwdleft\');" type="checkbox" value="swirlinfwdleft" class="eff-link eff-no-groupp" id="swirlinfwdleft">\
                                        <label title="Воронка появление вперед слева" for="swirlinfwdleft" class="eff-label">Воронка появление вперед слева</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirlinfwdright" onchange="return setClassEffect(this, \'swirlinfwdright\');" type="checkbox" value="swirlinfwdright" class="eff-link eff-no-groupp" id="swirlinfwdright">\
                                        <label title="Воронка появление вперед справа" for="swirlinfwdright" class="eff-label">Воронка появление вперед справа</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirlinfwdtop" onchange="return setClassEffect(this, \'swirlinfwdtop\');" type="checkbox" value="swirlinfwdtop" class="eff-link eff-no-groupp" id="swirlinfwdtop">\
                                        <label title="Воронка появление вперед сверху" for="swirlinfwdtop" class="eff-label">Воронка появление вперед сверху</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirlinbckbottom" onchange="return setClassEffect(this, \'swirlinbckbottom\');" type="checkbox" value="swirlinbckbottom" class="eff-link eff-no-groupp" id="swirlinbckbottom">\
                                        <label title="Воронка появление назад снизу" for="swirlinbckbottom" class="eff-label">Воронка появление назад снизу</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirlinbckcenter" onchange="return setClassEffect(this, \'swirlinbckcenter\');" type="checkbox" value="swirlinbckcenter" class="eff-link eff-no-groupp" id="swirlinbckcenter">\
                                        <label title="Воронка появление назад по центру" for="swirlinbckcenter" class="eff-label">Воронка появление назад по центру</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirlinbckleft" onchange="return setClassEffect(this, \'swirlinbckleft\');" type="checkbox" value="swirlinbckleft" class="eff-link eff-no-groupp" id="swirlinbckleft">\
                                        <label title="Воронка появление назад слева" for="swirlinbckleft" class="eff-label">Воронка появление назад слева</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirlinbckright" onchange="return setClassEffect(this, \'swirlinbckright\');" type="checkbox" value="swirlinbckright" class="eff-link eff-no-groupp" id="swirlinbckright">\
                                        <label title="Воронка появление назад справа" for="swirlinbckright" class="eff-label">Воронка появление назад справа</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirlinbcktop" onchange="return setClassEffect(this, \'swirlinbcktop\');" type="checkbox" value="swirlinbcktop" class="eff-link eff-no-groupp" id="swirlinbcktop">\
                                        <label title="Воронка появление назад сверху" for="swirlinbcktop" class="eff-label">Воронка появление назад сверху</label>\
                                    </div>\
                                                                                                                                <div class="wr-input delimiter"><b>Группа эффектов - исчезновение:</b></div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="flipoutx" onchange="return setClassEffect(this, \'flipoutx\');" type="checkbox" value="flipoutx" class="eff-link eff-no-groupp" id="flipoutx">\
                                        <label title="Перелистывание по X и прозрачность 100%-0%" for="flipoutx" class="eff-label">Перелистывание по X и прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="flipouty" onchange="return setClassEffect(this, \'flipouty\');" type="checkbox" value="flipouty" class="eff-link eff-no-groupp" id="flipouty">\
                                        <label title="Перелистывание по Y и прозрачность 100%-0%" for="flipouty" class="eff-label">Перелистывание по Y и прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="lightspeedout" onchange="return setClassEffect(this, \'lightspeedout\');" type="checkbox" value="lightspeedout" class="eff-link eff-no-groupp" id="lightspeedout">\
                                        <label title="Стремительный улёт вправо" for="lightspeedout" class="eff-label">Стремительный улёт вправо</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="slideoutdown" onchange="return setClassEffect(this, \'slideoutdown\');" type="checkbox" value="slideoutdown" class="eff-link eff-no-groupp" id="slideoutdown">\
                                        <label title="Ускользание(slide) вниз" for="slideoutdown" class="eff-label">Ускользание(slide) вниз</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="slideoutleft" onchange="return setClassEffect(this, \'slideoutleft\');" type="checkbox" value="slideoutleft" class="eff-link eff-no-groupp" id="slideoutleft">\
                                        <label title="Ускользание(slide) налево" for="slideoutleft" class="eff-label">Ускользание(slide) налево</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="slideoutright" onchange="return setClassEffect(this, \'slideoutright\');" type="checkbox" value="slideoutright" class="eff-link eff-no-groupp" id="slideoutright">\
                                        <label title="Ускользание(slide) направо" for="slideoutright" class="eff-label">Ускользание(slide) направо</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="slideoutup" onchange="return setClassEffect(this, \'slideoutup\');" type="checkbox" value="slideoutup" class="eff-link eff-no-groupp" id="slideoutup">\
                                        <label title="Ускользание(slide) наверх" for="slideoutup" class="eff-label">Ускользание(slide) наверх</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeoutdown" onchange="return setClassEffect(this, \'fadeoutdown\');" type="checkbox" value="fadeoutdown" class="eff-link eff-no-groupp" id="fadeoutdown">\
                                        <label title="Ускользание(slide) вниз + прозрачность 100%-0%" for="fadeoutdown" class="eff-label">Ускользание(slide) вниз + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeoutdownbig" onchange="return setClassEffect(this, \'fadeoutdownbig\');" type="checkbox" value="fadeoutdownbig" class="eff-link eff-no-groupp" id="fadeoutdownbig">\
                                        <label title="Ускользание(slide) вниз далеко + прозрачность 100%-0%" for="fadeoutdownbig" class="eff-label">Ускользание(slide) вниз далеко + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeoutleft" onchange="return setClassEffect(this, \'fadeoutleft\');" type="checkbox" value="fadeoutleft" class="eff-link eff-no-groupp" id="fadeoutleft">\
                                        <label title="Ускользание(slide) налево + прозрачность 100%-0%" for="fadeoutleft" class="eff-label">Ускользание(slide) налево + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeoutleftbig" onchange="return setClassEffect(this, \'fadeoutleftbig\');" type="checkbox" value="fadeoutleftbig" class="eff-link eff-no-groupp" id="fadeoutleftbig">\
                                        <label title="Ускользание(slide) налево далеко + прозрачность 100%-0%" for="fadeoutleftbig" class="eff-label">Ускользание(slide) налево далеко + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeoutright" onchange="return setClassEffect(this, \'fadeoutright\');" type="checkbox" value="fadeoutright" class="eff-link eff-no-groupp" id="fadeoutright">\
                                        <label title="Ускользание(slide) направо + прозрачность 100%-0%" for="fadeoutright" class="eff-label">Ускользание(slide) направо + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeoutrightbig" onchange="return setClassEffect(this, \'fadeoutrightbig\');" type="checkbox" value="fadeoutrightbig" class="eff-link eff-no-groupp" id="fadeoutrightbig">\
                                        <label title="Ускользание(slide) направо далеко + прозрачность 100%-0%" for="fadeoutrightbig" class="eff-label">Ускользание(slide) направо далеко + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeoutup" onchange="return setClassEffect(this, \'fadeoutup\');" type="checkbox" value="fadeoutup" class="eff-link eff-no-groupp" id="fadeoutup">\
                                        <label title="Ускользание(slide) наверх + прозрачность 100%-0%" for="fadeoutup" class="eff-label">Ускользание(slide) наверх + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="fadeoutupbig" onchange="return setClassEffect(this, \'fadeoutupbig\');" type="checkbox" value="fadeoutupbig" class="eff-link eff-no-groupp" id="fadeoutupbig">\
                                        <label title="Ускользание(slide) наверх далеко + прозрачность 100%-0%" for="fadeoutupbig" class="eff-label">Ускользание(slide) наверх далеко + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="zoomoutdown" onchange="return setClassEffect(this, \'zoomoutdown\');" type="checkbox" value="zoomoutdown" class="eff-link eff-no-groupp" id="zoomoutdown">\
                                        <label title="Уменьшение + прозрачность 100%-0% улетает вниз" for="zoomoutdown" class="eff-label">Уменьшение + прозрачность 100%-0% улетает вниз</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="zoomoutleft" onchange="return setClassEffect(this, \'zoomoutleft\');" type="checkbox" value="zoomoutleft" class="eff-link eff-no-groupp" id="zoomoutleft">\
                                        <label title="Уменьшение + прозрачность 100%-0% улетает вниз" for="zoomoutleft" class="eff-label">Уменьшение + прозрачность 100%-0% улетает вниз</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="zoomoutright" onchange="return setClassEffect(this, \'zoomoutright\');" type="checkbox" value="zoomoutright" class="eff-link eff-no-groupp" id="zoomoutright">\
                                        <label title="Уменьшение + прозрачность 100%-0% улетает направо" for="zoomoutright" class="eff-label">Уменьшение + прозрачность 100%-0% улетает направо</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="zoomoutup" onchange="return setClassEffect(this, \'zoomoutup\');" type="checkbox" value="zoomoutup" class="eff-link eff-no-groupp" id="zoomoutup">\
                                        <label title="Уменьшение + прозрачность 100%-0% улетает наверх" for="zoomoutup" class="eff-label">Уменьшение + прозрачность 100%-0% улетает наверх</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bounceout" onchange="return setClassEffect(this, \'bounceout\');" type="checkbox" value="bounceout" class="eff-link eff-no-groupp" id="bounceout">\
                                        <label title="Упрыгивание вдаль" for="bounceout" class="eff-label">Упрыгивание вдаль</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bounceoutdown" onchange="return setClassEffect(this, \'bounceoutdown\');" type="checkbox" value="bounceoutdown" class="eff-link eff-no-groupp" id="bounceoutdown">\
                                        <label title="Упрыгивание вниз" for="bounceoutdown" class="eff-label">Упрыгивание вниз</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bounceoutleft" onchange="return setClassEffect(this, \'bounceoutleft\');" type="checkbox" value="bounceoutleft" class="eff-link eff-no-groupp" id="bounceoutleft">\
                                        <label title="Упрыгивание налево" for="bounceoutleft" class="eff-label">Упрыгивание налево</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bounceoutright" onchange="return setClassEffect(this, \'bounceoutright\');" type="checkbox" value="bounceoutright" class="eff-link eff-no-groupp" id="bounceoutright">\
                                        <label title="Упрыгивание направо" for="bounceoutright" class="eff-label">Упрыгивание направо</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="bounceoutup" onchange="return setClassEffect(this, \'bounceoutup\');" type="checkbox" value="bounceoutup" class="eff-link eff-no-groupp" id="bounceoutup">\
                                        <label title="Упрыгивание наверх" for="bounceoutup" class="eff-label">Упрыгивание наверх</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotateout" onchange="return setClassEffect(this, \'rotateout\');" type="checkbox" value="rotateout" class="eff-link eff-no-groupp" id="rotateout">\
                                        <label title="Поворот по часовой + прозрачность 100%-0%" for="rotateout" class="eff-label">Поворот по часовой + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotateoutdownleft" onchange="return setClassEffect(this, \'rotateoutdownleft\');" type="checkbox" value="rotateoutdownleft" class="eff-link eff-no-groupp" id="rotateoutdownleft">\
                                        <label title="Выпал налево-вниз + прозрачность 100%-0%" for="rotateoutdownleft" class="eff-label">Выпал налево-вниз + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotateoutdownright" onchange="return setClassEffect(this, \'rotateoutdownright\');" type="checkbox" value="rotateoutdownright" class="eff-link eff-no-groupp" id="rotateoutdownright">\
                                        <label title="Выпал направо-вниз + прозрачность 100%-0%" for="rotateoutdownright" class="eff-label">Выпал направо-вниз + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotateoutupleft" onchange="return setClassEffect(this, \'rotateoutupleft\');" type="checkbox" value="rotateoutupleft" class="eff-link eff-no-groupp" id="rotateoutupleft">\
                                        <label title="Выпал налево-вверх + прозрачность 100%-0%" for="rotateoutupleft" class="eff-label">Выпал налево-вверх + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="rotateoutupright" onchange="return setClassEffect(this, \'rotateoutupright\');" type="checkbox" value="rotateoutupright" class="eff-link eff-no-groupp" id="rotateoutupright">\
                                        <label title="Выпал направо-вверх + прозрачность 100%-0%" for="rotateoutupright" class="eff-label">Выпал направо-вверх + прозрачность 100%-0%</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirloutfwd" onchange="return setClassEffect(this, \'swirloutfwd\');" type="checkbox" value="swirloutfwd" class="eff-link eff-no-groupp" id="swirloutfwd">\
                                        <label title="Воронка исчезновение вперед снизу" for="swirloutfwd" class="eff-label">Воронка исчезновение вперед снизу</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirloutfwdcenter" onchange="return setClassEffect(this, \'swirloutfwdcenter\');" type="checkbox" value="swirloutfwdcenter" class="eff-link eff-no-groupp" id="swirloutfwdcenter">\
                                        <label title="Воронка исчезновение вперед по центру" for="swirloutfwdcenter" class="eff-label">Воронка исчезновение вперед по центру</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirloutfwdleft" onchange="return setClassEffect(this, \'swirloutfwdleft\');" type="checkbox" value="swirloutfwdleft" class="eff-link eff-no-groupp" id="swirloutfwdleft">\
                                        <label title="Воронка исчезновение вперед слева" for="swirloutfwdleft" class="eff-label">Воронка исчезновение вперед слева</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirloutfwdright" onchange="return setClassEffect(this, \'swirloutfwdright\');" type="checkbox" value="swirloutfwdright" class="eff-link eff-no-groupp" id="swirloutfwdright">\
                                        <label title="Воронка исчезновение вперед справа" for="swirloutfwdright" class="eff-label">Воронка исчезновение вперед справа</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirloutfwdtop" onchange="return setClassEffect(this, \'swirloutfwdtop\');" type="checkbox" value="swirloutfwdtop" class="eff-link eff-no-groupp" id="swirloutfwdtop">\
                                        <label title="Воронка исчезновение вперед сверху" for="swirloutfwdtop" class="eff-label">Воронка исчезновение вперед сверху</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirloutbckbottom" onchange="return setClassEffect(this, \'swirloutbckbottom\');" type="checkbox" value="swirloutbckbottom" class="eff-link eff-no-groupp" id="swirloutbckbottom">\
                                        <label title="Воронка исчезновение назад снизу" for="swirloutbckbottom" class="eff-label">Воронка исчезновение назад снизу</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirloutbckcenter" onchange="return setClassEffect(this, \'swirloutbckcenter\');" type="checkbox" value="swirloutbckcenter" class="eff-link eff-no-groupp" id="swirloutbckcenter">\
                                        <label title="Воронка исчезновение назад по центру" for="swirloutbckcenter" class="eff-label">Воронка исчезновение назад по центру</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirloutbckleft" onchange="return setClassEffect(this, \'swirloutbckleft\');" type="checkbox" value="swirloutbckleft" class="eff-link eff-no-groupp" id="swirloutbckleft">\
                                        <label title="Воронка исчезновение назад слева" for="swirloutbckleft" class="eff-label">Воронка исчезновение назад слева</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirloutbckright" onchange="return setClassEffect(this, \'swirloutbckright\');" type="checkbox" value="swirloutbckright" class="eff-link eff-no-groupp" id="swirloutbckright">\
                                        <label title="Воронка исчезновение назад справа" for="swirloutbckright" class="eff-label">Воронка исчезновение назад справа</label>\
                                    </div>\
                                                                                                                                <div class="wr-input" rel="i-0001">\
                                        <input name="swirloutbcktop" onchange="return setClassEffect(this, \'swirloutbcktop\');" type="checkbox" value="swirloutbcktop" class="eff-link eff-no-groupp" id="swirloutbcktop">\
                                        <label title="Воронка исчезновение назад сверху" for="swirloutbcktop" class="eff-label">Воронка исчезновение назад сверху</label>\
                                    </div>\
                                                                                    </div>\
                    </div>\
                    <div class="wrap-button">\
                        <input onclick="return shest_set_pos(this);" class="but-input" type="button" value="Закрыть">\
                    </div>\
                </form>\
            </div>\
        </div>\
    </div>';
var styleMain = '<style type="text/css">\
.wrap-popupocinstuctor {\
    position: fixed;\
    top: 30%;\
    right: -425px;\
    z-index: 1370;\
    background-color: #e3f4ff;\
    width: 463px;\
    border-bottom-left-radius: 7px;\
    border-bottom-right-radius: 7px;\
}\
.shesterenka {\
    font-size: 3em;\
    padding: 10px;\
    padding-top: 0px;\
    padding-bottom: 0px;\
    border-radius: 50%;\
\
    position: absolute;\
    top: -14px;\
    left: -8px;\
    text-shadow: 1px 1px 1px black, 1px 1px 1px black;\
    cursor: pointer;\
}\
.pop-drag {\
\
}\
.main-popup {\
    display: flex;\
    flex-direction: row;\
    margin-top: 4px;\
    padding-top: 1px;\
}\
.main-content {\
    position: relative;\
    top: 0px;\
    left: 0px;\
    width: 400px;\
    background-color: white;\
    border: 1px solid #f7f2f2;\
    height: 400px;\
    margin-bottom: 7px;\
    border-radius: 8px;\
    overflow: auto;\
    padding-left: 5px;\
}\
.polosa {\
    width: 100%;\
    height: 39px;\
    background-color: #e2ebee;\
    cursor: move;\
}\
.shesterenka-text {\
    font-size: 12px;\
    display: inline-block;\
    width: 13px;\
    word-wrap: break-word;\
    white-space: normal;\
    letter-spacing: 1px;\
\
    color: #ed0101;\
    font-weight: bold;\
}\
.wr-shesterenka {\
    display: flex;\
    flex-direction: column;\
    justify-content: start;\
    align-items: center;\
    margin-left: 6px;\
}\
.wr-shesterenka-text {\
    padding-left: 5px;\
    display: flex;\
    flex-direction: row;\
    justify-content: start;\
}\
.polosa {\
    width: 100%;\
    height: 39px;\
    background-color: #e2ebee;\
    cursor: move;\
    box-shadow: 0px 3px 2px 0px rgba(0,0,0,0.5);\
}\
.eff-full .wr-input {\
    font-size: 12px;\
}\
.eff-full .but-input {\
    font-size: 11px;\
}\
.eff-full .wr-input:hover {\
    background-color: antiquewhite;\
}\
.eff-full .wr-input input {\
    position: relative;\
    top: 0px;\
}\
.eff-full .wr-input label {\
    text-overflow: ellipsis;\
    overflow: hidden;\
    width: 351px;\
    white-space: nowrap;\
    position: relative;\
    top: 3px;\
}\
.wrap-button {\
    margin-left: 1px;\
    margin-bottom: 8px;\
    text-align: center;\
    margin-top: 5px\
}\
.hidd {\
    display: none !important;\
}\
\
.cls-add-effect:hover {\
    outline: 2px dashed rgb(16 1 255 / 62%);\
    box-shadow:2px 2px 4px 3px rgba(0,0,0,0.5);\
}\
\
.s-speed {\
    width: 45px;\
    position: absolute;\
    z-index: 10;\
    top: 56px;\
    right: 57px;\
    box-shadow: 0px 0px 3px 1px rgba(0, 0, 0, 0.3);\
}\
.s-speed input {\
    width: 45px;\
    border-radius: 3px;\
    border: 1px solid #a5a5a5;\
}\
.s-speed-2 {\
\
}\
.s-speed-1 {\
    font-size: 10px;\
    line-height: 8px;\
    display: inline-block;\
}\
.mark-arr {\
    position: absolute;\
    color: red;\
    font-size: 70px;\
    text-shadow: 1px 0px rgba(0, 0, 0, 0.5);\
    line-height: 37px;\
    width: 42px;\
    padding: 0;\
    margin: 0;\
    z-index: 2400;\
}\
body {\
    position: relative;\
}\
.s-speed.s-disketa {\
    top: 140px;\
    text-align: center;\
    width: 20px;\
    right: 68px;\
    cursor: pointer;\
}\
.s-speed.s-disketa.s-sbros {\
	top: 190px;\
    border-radius: 100%;\
    width: 31px;\
    padding: 3px;\
    right: 61px;\
}\
.adm-btn-save.no-press{\
	opacity: 0.2 !important;\
    pointer-events: none;\
}\
.help-html{\
	position: fixed;\
    bottom: 0px;\
    right: 0px;\
    z-index: 2000;\
    font-size: 12px;\
    line-height: 15px;\
    background-color: antiquewhite;\
    padding: 4px;\
    padding-left: 8px;\
    padding-right: 10px;\
	overflow: auto;\
}\
.help-html-2{\
	background-color: white;\
    padding: 5px;\
    border-radius: 2px;\
}\
</style>\
';	
jQuery("body").append(htmlMain + styleMain);
var prevElement;
    var nextElement;
    var minTime = 500;
    var lastTime = 0;
    var stopSelet = 0;
    var lastClick = 0;
    var globalSelector = "";
    var flStopChange = 0;
    var paramForFirstSave = {};
	var currentBlock = 0;
	function sbros(eto) {
		for (var key in paramForFirstSave){
			delete paramForFirstSave[key];
		}
		jQuery(".eff-link:checked").each(function() {
			 jQuery(this).prop("checked", false);
		});
		setClassEffect("", "");
		return true;
	}
    function save_first(eto) {
        togle_construktor();
        un_mark_block();
		var secret = "dirw72r2";
		var prifix = "<?=$arParams['PREFIX_CLASS'];?>";
		$.ajax({
                url: "/bitrix/components/burcomp/animatedgraphicsfull.grafika.list/templates/demo/all_ajax.php?dd=" + (new Date).getTime(),
                type: "post",
                async: true,
                data: {"secret":secret, "style":jQuery("[rel='ss-0001']").text(), "prifix":prifix},
                success: function (responseData, textStatus, jqXHR) {
                    window.location = window.location.pathname;

                },
                error: function (responseData, textStatus, errorThrown) {
                }
            });
        return false;
    }
	function set_unicue_selector(){
		var helpHtml = '<div class="help-html"><div class="help-html-1">Выбранный селектор:</div><div class="help-html-2">' + globalSelector + '</div></div>';
		jQuery('.help-html').remove();
		jQuery('body').append(helpHtml);
	}
    function mark_block() {
        var html = '<div class="mark-arr">&#x2798;</div>';
        jQuery('body').append(html);
        var top = jQuery('.cls-add-effect').offset().top-40;
        var left = jQuery('.cls-add-effect').offset().left-45;
        jQuery('.mark-arr').css("top", top + "px");
        jQuery('.mark-arr').css("left", left + "px");
    }
    function un_mark_block() {
        jQuery('.mark-arr').remove();
		jQuery('.help-html').remove();
    }
    function change_speed(eto) {
        if(jQuery("input.eff-no-groupp:checked").length>0) {	
            setClassEffect(jQuery("input.eff-no-groupp:checked:first"), jQuery("input.eff-no-groupp:checked:first").val());
        }else {
            if(jQuery("input.eff-yes-groupp:checked").length>0) {
                setClassEffect(jQuery("input.eff-yes-groupp:checked:first"), jQuery("input.eff-yes-groupp:checked:first").val());
            }
        }
        return true;
    }
	function removeMsIfEmptyChecked(){
		if( globalSelector.length>0){
			var isChecked = 0;
			jQuery(".wrap-popupocinstuctor .eff-link:checked").each(function() {
				isChecked = 1;
			});
			if(isChecked === 0){
				if(paramForFirstSave.hasOwnProperty('ALL_BLOK')){
					var iz = 0;
					var izRemove = 0;
					for (var key in paramForFirstSave){
						iz++;
						if(paramForFirstSave['CLASS_OR_ID' + iz] == globalSelector){
							izRemove = iz;
							break;   
						}
					}
					
					if(izRemove>0){
						var deleteOk = 0;
						for (var key in paramForFirstSave){
							if(key == 'ALL_BLOK'){
							}else{
								var cifra = parseInt(key.replace(/\D/ig,""));
								if(cifra == izRemove){
									delete paramForFirstSave[key];
									deleteOk = 1;
								}
							}
						}
						if(deleteOk === 1){
							newCurrent = parseInt(paramForFirstSave['ALL_BLOK'])-1;
							paramForFirstSave['ALL_BLOK'] = newCurrent;
							oldCurrent = currentBlock;
							currentBlock = newCurrent;
							/* Сдвигаю стек */
							for(var iz = 1; iz<=newCurrent;iz++){
								 if(paramForFirstSave.hasOwnProperty('CLASS_OR_ID' + iz) === false){
									for (var key in paramForFirstSave){
										cifra = parseInt(key.replace(/\D/ig,""));
										if(cifra == (iz+1)){
											bukva = key.replace(/\d/ig,"");
											paramForFirstSave[bukva + iz] = paramForFirstSave[bukva + (iz+1)];
											delete paramForFirstSave[bukva + (iz+1)];
										}
									}
								 }
							}
						}
					}
				}
			}
		}
		return true;
	}
    function setClassEffect(eto, vval) {
        if(flStopChange === 1) {
            return true;
        }
        var eff = [];
        jQuery("[rel='ss-0001']").remove();
        var single = 0;
        if(jQuery(eto).hasClass("eff-no-groupp") && jQuery(eto).prop("checked") === true) {
            single = 1;
            jQuery(eto).addClass("eff-no-groupp-2");
            jQuery(".eff-no-groupp:checked").each(function() {
                if(jQuery(this).hasClass("eff-no-groupp-2")) {
                }else {
                    jQuery(this).prop("checked", false);
                }
            });
            jQuery(eto).removeClass("eff-no-groupp-2");
        }
        jQuery(".wrap-popupocinstuctor .eff-link:checked").each(function() {
            eff.push(jQuery(this).val());
        });
		removeMsIfEmptyChecked();
        flStopChange = 0;
        if( (globalSelector.length>0 && jQuery(".cls-add-effect").length>0) || (single === 1 && jQuery(".cls-add-effect").length>0)) {
			/* Здесь остановился надо с пустыми чеками убирать из массива и не удалять ss-0001*/
            var firstParent = "";
			//jQuery(globalSelector).parents(":first").addClass("cls-add-effect-parent");
            var unicueParent = get_check_unicue(jQuery(globalSelector).parents(":first"));
            if(single === 0) {
                var singleSend = "N";
            }else {
                var singleSend = "Y";
            }
            if(unicueParent[1].length>0) {
                firstParent = unicueParent[1];
            }
			if( eff.length === 0) {
            
			}else{
				var noAdd = 0;
				for (var key in paramForFirstSave){
					if(/CLASS_OR_ID/ig.test(key) === true){
						if(paramForFirstSave[key] == globalSelector){
							var noAdd = 1;
							$imax = key.replace(/CLASS_OR_ID/ig, ""); 
						}
					}
				}
				if(noAdd === 0){
					currentBlock++;
					$imax = currentBlock;
				}
				var sendParamMs = {};
				sendParamMs.ALL_BLOK = $imax;
				sendParamMs['CLASS_OR_ID' + $imax] = globalSelector;
				sendParamMs['COLOR_ID' + $imax] = "#4494d7";
				sendParamMs['COL_SCR' + $imax] = 1;
				var dopStyle = "";
				if(typeof jQuery(globalSelector).css('display') != "undefined"){
					if(jQuery(globalSelector).css('display') == "inline"){
						dopStyle = "display:inline-block";
					}
				}
				sendParamMs['DOP_STYLE' + $imax] = dopStyle;
				sendParamMs['DSPIC' + $imax] = "Авто-заполнение №" + $imax;
				sendParamMs['PARENT_ID' + $imax] = firstParent;

				sendParamMs['SINGLE_EFFECT_CH' + $imax] = singleSend; // Для вторых эффектов
				if(single === 1) {
					//sendParamMs['EFFECT' + $imax] = "";
					sendParamMs['SINGLE_EFFECT_LIST' + $imax] = vval; // Для вторых эффектов
					sendParamMs['SINGLE_EFFECT_GRUPP' + $imax] = "allgrupp";
				}else {
					sendParamMs['EFFECT' + $imax] = eff;
				}
				sendParamMs['SPEED' + $imax] = jQuery(".s_speed").val();
				sendParamMs['START_ZADERJKA' + $imax] = "0";
				sendParamMs['STOP_COUNT' + $imax] = "";
				sendParamMs['VOLNA_OPASITY_CH' + $imax] = "Y";
				sendParamMs['ZADERJKA_ZW' + $imax] = "0";
				sendParamMs['PREFIX_CLASS'] = "xyz_";

				for (var key in sendParamMs){
					paramForFirstSave[key] = sendParamMs[key];
				}
			}
			var secret = "dirw72r";
			var style = "";
			style = style + '<style type="text/css" rel="ss-0001">';
			style = style + AnimatedGraphics.getStyleStart(paramForFirstSave,".default", 0);
			style = style + '</style>';
			jQuery("body").append(style);
			
        }else {
            jQuery("input.eff-link").prop("checked", false);
            alert("!Ошибка. Блок для анимации не выбран или не удалось подобрать уникальный селектор. Попробуйте назначить блоку уникальный класс.");
        }
        return true;
    }

	
    function shest_set_pos(eto){
        togle_construktor();
    }
    function togle_construktor() {
        if(lastClick === 0) {
            lastClick = 1;
            jQuery('.wrap-popupocinstuctor').removeClass("ui-draggable").removeAttr("style").css("right", "0px");
        }else {
            lastClick = 0;
            jQuery('.wrap-popupocinstuctor').removeClass("ui-draggable").removeAttr("style").css("right", "-425px");
        }
    }
    setTimeout(function(){
        set_all_events();
    }, 500);
   function set_all_events() {
       jQuery( function() {
           jQuery(".wrap-popupocinstuctor" ).draggable({
               cancel: ".shesterenka",
               handle: ".polosa"
           });
       } );
       /**/
       jQuery(document).keydown(function(e){
           // 13 Enter 16 shift 27 Escape
           if(e.which == 13 || e.which == 16) {
               stopSelet = 1;
           }
           if(e.which == 27) {
               stopSelet = 0;
           }
       });
       /**/
       jQuery("div,span,a,b,table,td,tr,th, h1, h2, h3, h4, h5, h6, video, img, input, select, textarea, frame,font").hover(function (e) {
           //e.preventDefault();
           var panelBox = 0;
           if (typeof jQuery(this).attr("id") != "undefined") {
               if (jQuery(this).attr("id").indexOf("bx_incl_area") != -1) {
                   panelBox = 1;
               }
           }
           var flTime = 0;
           var tmpTime = (new Date).getTime();
           var raznost = tmpTime - lastTime;
           if (raznost > minTime) {
               flTime = 1;
           }
           if (lastClick === 1 && stopSelet === 0 && jQuery(this).parents("#panel").length === 0 && jQuery(this).parents(".wrap-popupocinstuctor").length === 0 && panelBox === 0 && jQuery(this).hasClass("wrap-popupocinstuctor") === false && flTime === 1) {
               lastTime = tmpTime;
               if (typeof prevElement != "undefined") {
                   //prevElement.removeClass("cls-add-effect").removeAttr("title").parents(":first").removeClass("cls-add-effect-parent");
				   prevElement.removeClass("cls-add-effect").removeAttr("title");
                   un_mark_block();
               }
               jQuery(this).addClass("cls-add-effect").attr("title", 'Нажмите клавишу SHIFT (или Enter) выбора фиксации выбора блока, который будете анимировать. Для снятия фиксации выделения нажмите Escape.');
               mark_block();
               prevElement = jQuery(this);
               checkUnicue = get_check_unicue(this);
               globalSelector = checkUnicue[1];
			   set_unicue_selector();
               
           }

       }, function (e) {
           var panelBox = 0;
           if (typeof jQuery(this).attr("id") != "undefined") {
               if (jQuery(this).attr("id").indexOf("bx_incl_area") != -1) {
                   /*panelBox = 1;*/
               }
           }
           //if(lastClick === 1 && jQuery(this).parents("#panel").length === 0 && jQuery(this).parents(".wrap-popupocinstuctor").length === 0  && panelBox === 0) {
           if (lastClick === 1) {
               if (stopSelet === 0) {
                   jQuery(this).removeClass("cls-add-effect");
                   un_mark_block();
               }
           }

       });
   }


    function inArray(needle, haystack) {
        var length = haystack.length;
        for(var i = 0; i < length; i++) {
            if(haystack[i] == needle) return true;
        }
        return false;
    }
    function get_nomer_child(elem) {
       var nomer = jQuery(elem).children().length;
       return nomer;
    }

    function get_check_unicue(eto) {
        var imax = 10;
        var cls = jQuery(eto).attr("class");
        var id = jQuery(eto).attr("id");
        var tagIma = jQuery(eto)[0].tagName.toLowerCase();
        if(typeof cls != 'undefined') {
            cls = cls.replace(/\.cls-add-effect/ig," ");
            cls = cls.replace(/cls-add-effect/ig," ");
			cls = cls.replace(/hover/ig," ");
			cls = cls.replace(/selected/ig," ");
			cls = cls.replace(/active/ig," ");
            cls = cls.replace(/\s\s\s/ig," ");
            cls = cls.replace(/\s\s/ig," ");
			cls = cls.replace(/\s\s/ig," ");
			cls = cls.replace(/\s\s/ig," ");
            cls = cls.trim();
            if(cls.length>0) {
                cls = "." + cls.replace(/\s/ig, ".");
            }
        }
        if(typeof id != 'undefined') {
            id = "#" + id.replace(/\s/ig,"");
            if(
			id.indexOf("#bx_incl_area") !=-1 ||  
			id.indexOf("#menu-item") !=-1 ||  
			/bx_[\d]{1,4}/ig.test(id) === true
			) {
                id = "";
            }
            //
        }

        /* Или по классу или по ИД */
        if(typeof cls != 'undefined') {
            if(cls == ".cls-add-effect") {
                cls = "";
            }else {
                if (jQuery(cls).length === 1) {
                    return [1, cls];
                }
            }
        }
        if(typeof id != 'undefined') {
            if(id.length > 0) {
                if (jQuery(id).length === 1) {
                    return [1, id];
                }
            }
        }
        if(typeof cls != 'undefined' && typeof id != 'undefined') {
            if(id.length > 0 && cls.length > 0) {
                if (jQuery(id + cls).length === 1) {
                    return [1, (id + cls)];
                }
            }
        }
        /* Вверх по классу и ИД */
        if(typeof cls != 'undefined') {
            if (cls.length > 0) {
                var iz = 0;
                var strSelector = "";
                var clsTmp = "";
                for (iz = 0; iz < imax; iz++) {
                    /*ИД*/
                    var flStopParent = 0;
                    clsTmp = jQuery(eto).parents().eq(iz).attr("id");
                    if(typeof clsTmp != 'undefined') {
                        if (
						/bx_incl_area/ig.test(clsTmp) === false && 
						/menu-item/ig.test(clsTmp) === false 
						/*&& /bx_[\d]{1,4}/ig.test(clsTmp) === false*/
						) {

                            if (jQuery(eto).parents().eq(iz).hasClass("cls-add-effect") === false) {
                                var nomer_child = get_nomer_child(jQuery(eto).parents().eq(iz));
								clsTmp = "#" + clsTmp.replace(/\s/ig, "");
                                var nth = "";
                                if(nomer_child>1){
                                    jQuery(eto).parents().eq(iz).children().each(function( index ) {
                                        if(
										jQuery(this).find(eto).length > 0 || 
										jQuery(this).hasClass("cls-add-effect") || 
										jQuery(this).find(".cls-add-effect").length > 0
										) {
                                            nth = ":nth-child(" + (index+1) + ")";
                                        }
                                    });
                                    if(/\s/i.test(strSelector) === true) {
                                        strSelector = strSelector.replace(/\s/i, nth + " ");
                                    }else {
                                        //strSelector = strSelector + nth;
										strSelector = clsTmp + " " + cls + nth;
                                    }
                                }else{
									if (strSelector.length === 0) {
										strSelector = clsTmp + " " + cls;
									} else {
										strSelector = clsTmp + " " + strSelector;
									}
								}
                                flStopParent = 1;
                                if (jQuery(strSelector).length === 1) {
                                    return [1, strSelector];
                                }

                            }
                        }
                    }
                    /**/
                    /* Класс*/
                    clsTmp = jQuery(eto).parents().eq(iz).attr("class");
                    if(typeof clsTmp != 'undefined' && flStopParent === 0) {
                        if (/hover/ig.test(clsTmp) === false && /active/ig.test(clsTmp) === false) {
                            if (
                                jQuery(eto).parents().eq(iz).hasClass("cls-add-effect") === false &&
                                /selected/ig.test(clsTmp) === false
                            ) {

                                var nomer_child = get_nomer_child(jQuery(eto).parents().eq(iz));
                                clsTmp = clsTmp.replace(/\s\s/ig, " ");
                                clsTmp = "." + clsTmp.replace(/\s/ig, ".");
								var nth = "";
                                if(nomer_child>1){
                                    jQuery(eto).parents().eq(iz).children().each(function( index ) {
                                        if(
										jQuery(this).find(eto).length > 0 || 
										jQuery(this).hasClass("cls-add-effect") || 
										jQuery(this).find(".cls-add-effect").length > 0
										) {
                                            nth = ":nth-child(" + (index+1) + ")";
                                        }
                                    });
                                    if(/\s/i.test(strSelector) === true) {
                                        strSelector = strSelector.replace(/\s/i, nth + " ");
										//strSelector = strSelector + nth;
                                    }else {
										strSelector = clsTmp + " " + cls + nth;
                                        
                                    }
                                }else{
									if (strSelector.length === 0) {
										strSelector = clsTmp + " " + cls;
									} else {
										strSelector = clsTmp + " " + strSelector;
									}
								}
                                flStopParent = 1;
                                if (jQuery(strSelector).length === 1) {
                                    return [1, strSelector];
                                }
                            }
                        }
                    }
                    if(jQuery(eto).parents().eq(iz).length>0 && flStopParent === 0) {
                        clsTmp = jQuery(eto).parents().eq(iz)[0].tagName.toLowerCase();
                        if (strSelector.length === 0) {
                            strSelector = clsTmp + " " + cls;
                        } else {
                            strSelector = clsTmp + " " + strSelector;
                        }
                    }
                    /**/
                }
            }
        }
        /* Если ничего не вышло то первый селектор по тегу а дальше по Классу ... */
        if(jQuery(tagIma).length == 1) { /* Невероятная ситуация */
            return [1, tagIma];
        }
        if(jQuery(tagIma).length > 1) {
            var iz = 0;
            var strSelector = "";
            var clsTmp = "";
            for (iz = 0; iz < imax; iz++) {
                clsTmp = jQuery(eto).parents().eq(iz).attr("class");
                if (typeof clsTmp != 'undefined') {/* По классу */
                    if(
						jQuery(eto).parents().eq(iz).hasClass("cls-add-effect") === false && 
						/hover/ig.test(clsTmp) === false &&
						/active/ig.test(clsTmp) === false &&
                        /selected/ig.test(clsTmp) === false && 
						clsTmp.length > 0
					) {
						var nomer_child = get_nomer_child(jQuery(eto).parents().eq(iz));
						clsTmp = clsTmp.replace(/\s\s/ig, " ");
                        clsTmp = "." + clsTmp.replace(/\s/ig, ".");
						var nth = "";
                        if(nomer_child>1){
                             jQuery(eto).parents().eq(iz).children().each(function( index ) {
                                 if(
								 jQuery(this).find(eto).length > 0 || 
								 jQuery(this).hasClass("cls-add-effect")
								 ) {
                                     nth = ":nth-child(" + (index+1) + ")";
                                 }
                             });
                             if(/\s/i.test(strSelector) === true) {
                                 strSelector = strSelector.replace(/\s/i, nth + " ");
                             }else {
                                 //strSelector = strSelector + ">" + nth;
                                 strSelector = clsTmp + " " + tagIma + nth;
                             }

                        }else {
                            if (strSelector.length === 0) {
                                strSelector = clsTmp + " " + tagIma;
                            } else {
                                strSelector = clsTmp + " " + strSelector;
                            }
                        }
                        if (jQuery(strSelector).length === 1) {
                            return [1, strSelector];
                        }
                    }
                }else { /* Если не вышло то по тегу */
                    if(jQuery(eto).parents().eq(iz).length>0) {
                        clsTmp = jQuery(eto).parents().eq(iz)[0].tagName.toLowerCase();
                        if (typeof clsTmp != 'undefined') {
							/**/
							var nomer_child = get_nomer_child(jQuery(eto).parents().eq(iz));
							var nth = "";
							if(nomer_child>1){
								 jQuery(eto).parents().eq(iz).children().each(function( index ) {
									 if(
									 jQuery(this).find(eto).length > 0 || 
									 jQuery(this).hasClass("cls-add-effect")
									 ) {
										 nth = ":nth-child(" + (index+1) + ")";
									 }
								 });
								 if(/\s/i.test(strSelector) === true) {
									 strSelector = strSelector.replace(/\s/i, nth + " ");
								 }else {
									 strSelector = strSelector + ">" + nth;
								 }
							}
							/**/
                            if (strSelector.length === 0) {
                                strSelector = clsTmp + " " + tagIma;
                            } else {
                                strSelector = clsTmp + " " + strSelector;
                            }
                            if (jQuery(strSelector).length === 1) {
                                return [1, strSelector];
                            }
                        }
                    }
                }
            }
        }
        return [0,""];
    }
const moduleId = "aburyak.animatedgraphicsfull";
var stop_once_anim_force_forwards = "Y";
class AnimatedGraphics {
    static getStyleStart(param, tpl, flCss = 0) {
        let msIz = [];
        if (!param.hasOwnProperty('ALL_BLOK')) {
            param['ALL_BLOK'] = "";
        }
        param['ALL_BLOK'] = this.getAllblokForTpl(param['ALL_BLOK'], param, tpl);
        if (flCss === 1) {
            msIz[0] = this.generateHelpCss();
        } else {
            msIz = this.prepareMs(param);
        }
        let out = "";
        let totalCo = 0;
        let iPic = 0;
        let strPersp = "";
        let flDopStyle = 0;
        for (const [className, val] of Object.entries(msIz[0])) {
            let classDecoded = this.decodeHtmlEntities(className);
            iPic++;
            out += classDecoded + "{\r\n";
            flDopStyle = 0;
            if (flDopStyle === 0) {
                for (const vdop of val) {
					if (typeof vdop !== 'undefined'){
						if (vdop.hasOwnProperty('DOP_STYLE') && vdop['DOP_STYLE'].length > 0) {
							out += vdop['DOP_STYLE'] + ";\r\n";
							flDopStyle = 1;
							break;
						}
					 }
                }
            }
            out += "transform-origin: 50% 50%;\r\n-webkit-transform-origin: 50% 50%;\r\n-moz-transform-origin: 50% 50%;\r\n-o-transform-origin: 50% 50%;\r\n-ms-transform-origin: 50% 50%;";
            let str1 = "";
            let str2 = "";
            let str3 = "";
            let str4 = "";
            let str5 = "";
            let fr1 = "";
            let fr2 = "";
            let fr3 = "";
            let fr4 = "";
            let fr5 = "";
            let iAnim = 0;
            let iFr = 0;
            let opacityItog = "";
            for (const val2 of val) {
			 if(typeof val2 !== 'undefined'){	
                let sposob = 'linear';
                let flOnceEff = 0;
				if(typeof val2 !== 'undefined'){
					if (val2.hasOwnProperty('SINGLE_EFFECT_CH') && val2['SINGLE_EFFECT_CH'] === "Y") {
						flOnceEff = 1;
					}
				}
				if (typeof val2 !== 'undefined'){
					if (val2.hasOwnProperty('EFFECT') && flOnceEff === 0) {
						if (['rotate_repspective_x_1', 'rotate_repspective_x_2', 'rotate_repspective_y_1', 'rotate_repspective_y_2'].includes(val2['EFFECT'])) {
							if (val2['PARENT_ID'].length > 0) {
								strPersp += val2['PARENT_ID'] + "{-webkit-perspective-origin: 50% 50%;perspective-origin: 50% 50%;-webkit-transform-style: preserve-3d;transform-style: preserve-3d;-webkit-perspective: 500px;perspective: 500px;background: none;}";
							}
						}
					}
				}
                totalCo++;
                iFr++;
                iAnim++;
                let infinite = this.getInfinite(val2['STOP_COUNT'], val2['EFFECT'], val2);
                let zad = this.getZad(val2['START_ZADERJKA']);
                let speed = this.getSpeed(val2['SPEED']);
				
                let opacity = this.getOpacity(val2['EFFECT']);
                if (opacity.length > 0 && flOnceEff === 0) {
                    opacityItog = opacity;
                }
                if (flOnceEff === 1) {
                    let msOnce = this.getOpacityOnceEffect(val2['SINGLE_EFFECT_LIST'], infinite);
                    opacityItog = msOnce['opa'];
                    sposob = msOnce['sposob'];
                    infinite = msOnce['infinite'];
                }
                if (str1.length === 0) {
                    str1 = "\r\nanimation: " + param['PREFIX_CLASS'] + "Frame_" + iFr + "_pic_" + iPic + "_Ani" + iAnim + " " + sposob + " " + speed + "s " + zad + "s " + infinite;
                } else {
                    str1 += ", " + param['PREFIX_CLASS'] + "Frame_" + iFr + "_pic_" + iPic + "_Ani" + iAnim + " " + sposob + " " + speed + "s " + zad + "s " + infinite;
                }
                fr1 += this.getFrameEffectBr1(param['PREFIX_CLASS'] + "Frame_" + iFr + "_pic_" + iPic + "_Ani" + iAnim, val2['EFFECT'], val2);
                iAnim++;
                if (str2.length === 0) {
                    str2 = "\r\n-webkit-animation: " + param['PREFIX_CLASS'] + "Frame_" + iFr + "_pic_" + iPic + "_Ani" + iAnim + " " + sposob + " " + speed + "s " + zad + "s " + infinite;
                } else {
                    str2 += ", " + param['PREFIX_CLASS'] + "Frame_" + iFr + "_pic_" + iPic + "_Ani" + iAnim + " " + sposob + " " + speed + "s " + zad + "s " + infinite;
                }
                fr2 += this.getFrameEffectBr2(param['PREFIX_CLASS'] + "Frame_" + iFr + "_pic_" + iPic + "_Ani" + iAnim, val2['EFFECT'], val2);
                iAnim++;
                if (str3.length === 0) {
                    str3 = "\r\n-moz-animation: " + param['PREFIX_CLASS'] + "Frame_" + iFr + "_pic_" + iPic + "_Ani" + iAnim + " " + sposob + " " + speed + "s " + zad + "s " + infinite;
                } else {
                    str3 += ", " + param['PREFIX_CLASS'] + "Frame_" + iFr + "_pic_" + iPic + "_Ani" + iAnim + " " + sposob + " " + speed + "s " + zad + "s " + infinite;
                }
                fr3 += this.getFrameEffectBr3(param['PREFIX_CLASS'] + "Frame_" + iFr + "_pic_" + iPic + "_Ani" + iAnim, val2['EFFECT'], val2);
                /*iAnim++;
                if (str4.length === 0) {
                    str4 = "\r\n-o-animation: " + param['PREFIX_CLASS'] + "Frame_" + iFr + "_pic_" + iPic + "_Ani" + iAnim + " " + sposob + " " + speed + "s " + zad + "s " + infinite;
                } else {
                    str4 += ", " + param['PREFIX_CLASS'] + "Frame_" + iFr + "_pic_" + iPic + "_Ani" + iAnim + " " + sposob + " " + speed + "s " + zad + "s " + infinite;
                }*/
             }
			}
            str1 += ";\r\n";
            str2 += ";\r\n";
            str3 += ";\r\n";
            str4 += ";\r\n";
            if (opacityItog.length > 0) {
                str4 += "\r\n" + opacityItog + "\r\n";
            }
            str5 += ";\r\n}\r\n";
            out += str1 + str2 + str3 + str4 + str5 + fr1 + fr2 + fr3 + fr4 + fr5;
        }
        out = strPersp + out;
        return out;
    }

    // Helper functions would need to be implemented here
    static getAllblokForTpl(col, param, tpl) {
    let fl_dbl = 0;
    if (param.hasOwnProperty('COMPONENT_TEMPLATE')) {
      if (param['COMPONENT_TEMPLATE'].length > 0) {
        if (param['COMPONENT_TEMPLATE'] === "koleso") {
          fl_dbl = 1;
          let fl_5 = 0;
          if (col) {
            if (col.length > 0) {
              fl_5 = 1;
              let zz = parseInt(col, 10);
              if (zz < 7) {
                col = 7;
              }
            }
          }
          if (fl_5 === 0) {
            col = 7;
          }
        }
      }
    }
    if (tpl && fl_dbl === 0) {
      if (tpl.length > 0) {
        if (tpl === "koleso") {
          fl_dbl = 1;
          let fl_5 = 0;
          if (col) {
            if (col.length > 0) {
              fl_5 = 1;
              let zz = parseInt(col, 10);
              if (zz < 7) {
                col = 7;
              }
            }
          }
          if (fl_5 === 0) {
            col = 7;
          }
        }
      }
    }
    return col;
  }

    static generateHelpCss() {
        // Implementation needed -не нужно
    }

    static prepareMs(arParams_0) {
    let arParams = [];
    let out = [];
    let ms_iz = [];
    let ms_dbl = [];
    let imax = 1;

    if (arParams_0.hasOwnProperty("ALL_BLOK")) {
      let rr = (arParams_0["ALL_BLOK"]).toString().trim();
      if (rr.length > 0) {
        rr = rr.replace(/\D/g, "");
        rr = parseInt(rr, 10);
        if (rr > 0) {
          imax = rr;
        }
      }
    }

    let iz = 1;
    let iz_2 = 1;
    let iz_new = 0;

    if (iz > 0) {
      for (iz = 1; iz <= imax; iz++) {
        let fl_grupp = 0;
        let fl_len = 0;
        if (arParams_0.hasOwnProperty("CLASS_OR_ID" + iz)) {
          let str = arParams_0["CLASS_OR_ID" + iz].trim();
          if (str.length > 0) {
            fl_len = 1;
            let ms_class = arParams_0["CLASS_OR_ID" + iz].split(",");
            if (ms_class.length > 1) {
              fl_grupp = 1;
            }
          }
        }
        if (fl_len === 1 && fl_grupp === 0) {
          iz_new++;
          arParams = this.selectorParamPlosk(iz, arParams, arParams_0, iz_new);
        }
        if (fl_len === 1 && fl_grupp === 1) {
          iz_new++;
          let msP = this.selectorParamGrupp(iz, arParams, arParams_0, iz_new);
          arParams = msP[0];
          iz_new = msP[1];
        }
      }

      arParams_0["ALL_BLOK"] = iz_new;
      imax = iz_new;
      iz = 1;
      iz_2 = 1;

      for (iz = 1; iz <= imax; iz++) {
        let selector = "";
        let fl_stop = 1;
        let fl_gruppa = 0;
        if (arParams.hasOwnProperty('CLASS_OR_ID' + iz)) {
          selector = arParams['CLASS_OR_ID' + iz].trim();
          if (selector.length > 0) {
            fl_stop = 0;
          }
        }
        if (fl_stop === 1) {
          continue;
        }
        if (ms_dbl.includes(iz)) {
          continue;
        }
        let msEff = this.selectorParam(iz, arParams);
        for (let eff_all of msEff) {
          if (!ms_iz[selector]) ms_iz[selector] = [];
          ms_iz[selector].push(eff_all);
        }
        let inext = iz + 1;
        iz_2 = inext;
        for (iz_2 = inext; iz_2 <= imax; iz_2++) {
          let fl_stop_2 = 1;
          let selector_2 = "";
          if (arParams.hasOwnProperty('CLASS_OR_ID' + iz_2)) {
            selector_2 = arParams['CLASS_OR_ID' + iz_2].trim();
            if (selector_2.length > 0) {
              fl_stop_2 = 0;
            }
          }
          if (fl_stop_2 === 1) {
            continue;
          }
          if (selector === selector_2) {
            ms_dbl.push(iz_2);
            let msEff = this.selectorParam(iz_2, arParams);
            for (let eff_all of msEff) {
              ms_iz[selector].push(eff_all);
            }
          }
        }
      }
    }

    ms_iz = this.inplodeTrasform(ms_iz);
    ms_iz = this.checkForvard(ms_iz);
    out = [ms_iz, arParams];
    return out;
  }

    static decodeHtmlEntities(text) {
        const textArea = document.createElement('textarea');
        textArea.innerHTML = text;
        return textArea.value;
    }

    static getInfinite(str, up_down, ms) {
    if (ms.hasOwnProperty('FORWARD')) {
      if (ms['FORWARD'] === 0) {
        return "1";
      }
    }
    let infinite = "infinite";
    if (up_down === 'opacity_up' || up_down === 'opacity_down') {
      infinite = "1 forwards";
    } else {
      if (str) {
        let inf = str.trim();
        if (inf.length > 0) {
          inf = parseInt(inf, 10);
          if (inf > 0) {
            infinite = inf;
          }
        }
      }
    }
    return infinite;
  }

    static getZad(str) {
    let zad = 0;
    if (str) {
      let inf = str.trim();
      if (inf.length > 0) {
        inf = parseFloat(inf);
        if (inf > 0) {
          zad = inf;
        }
      }
    }
    return zad;
  }

    static getSpeed(str) {
    let speed = 1;
    if (str) {
      let inf = str.trim();
      if (inf.length > 0) {
        inf = parseFloat(inf);
        if (inf > 0) {
          speed = inf;
        }
      }
    }
    return speed;
  }

    static getOpacity(str) {
        var opa = "";
        if(typeof str !== 'undefined') {
            var inf = str.trim();
            if(inf.length>0) {
                if(inf == 'opacity_up') {
                    opa = "opacity:0;";
                }
                if(inf == 'opacity_down') {
                    opa = "opacity:1;";
                }
            }
        }
        return opa;
    }
	static getOpacityOnceEffect(str, infinite) {
    let out = {
      opa: "",
      sposob: 'linear',
      infinite: infinite
    };
    if (str === 'speedin') {
      out['sposob'] = 'ease-out';
    }
    if (str === 'flip1') {
      out['opa'] = "opacity:1;";
    }
    let msForwards = this.getGruppEffect();
    if ((msForwards["entrance"]["CODE_EFF"].includes(str) || msForwards["exit"]["CODE_EFF"].includes(str)) && stop_once_anim_force_forwards == "Y") {
      out['infinite'] = "1 forwards";
    }
    return out;
  }

    

    static getFrameEffectBr1(frName, eff, fullMs) {
    if (fullMs.hasOwnProperty('SINGLE_EFFECT_CH')) {
      if (fullMs['SINGLE_EFFECT_CH'] === "Y") {
        let out = `\r\n@keyframes ${frName}{\r\n`;
        out += this.getOnceEffectLib(fullMs, 1);
        out += `\r\n}\r\n`;
        return out;
      }
    }

    let out = `\r\n@keyframes ${frName}{\r\n`;
    if (eff === 'opacity_up') {
      out += '0% {opacity:0;} 100% {opacity:1;}';
    } else if (eff === 'opacity_down') {
      out += '0% {opacity:1;} 100% {opacity:0;}';
    } else if (eff === 'bg_left') {
      out += '0% {background-position-x: 0%;} 100% {background-position-x: 200%;}';
    } else if (eff === 'bg_right') {
      out += '0% {background-position-: 0%;} 100% {background-position-x: -100%;}';
    } else if (eff === 'telefon') {
      out += this.getOneTelefonEffect('transform');
    } else if (eff !== 'telefon' && eff.indexOf('telefon') !== -1) {
      out += this.getComplexEffectTranform('transform', eff);
    } else {
      const ms_s = this.get_implodeEffect();
      let iz = 0;
      let str1 = "";
      let str2 = "";
      let str3 = "";
      for (const key in ms_s) {
        if (eff.indexOf(key) !== -1) {
          iz++;
          str1 += " " + ms_s[key][0] + ms_s[key][1];
          str2 += " " + ms_s[key][0] + ms_s[key][3];
          str3 += " " + ms_s[key][0] + ms_s[key][2];
        }
      }
      if (iz > 0) {
        out += `0% {transform: ${str1};} 50% {transform: ${str2};} 100% {transform: ${str3};}`;
      }
    }

    if (eff === 'opacity_up_mnogo') {
      out += '0% {opacity:0;} 50% {opacity:1;} 100% {opacity:0;}';
    } else if (eff === 'opacity_down_mnogo') {
      out += '0% {opacity:1;} 50% {opacity:0;} 100% {opacity:1;}';
    } else if (eff === 'wolna_eff') {
      const rgb = this.hexToRgb(fullMs['COLOR_ID']);
      let fl_volna = 0;
      if (fullMs.hasOwnProperty('VOLNA_OPASITY_CH')) {
        if (fullMs['VOLNA_OPASITY_CH'] === "Y") {
          fl_volna = 1; /* Высокая прозрачность волны */
        }
      }
      if (fl_volna === 1) {
        out += `0% {box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.3),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.2),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.2);}box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.3),0 0 0 15px rgba(${rgb.r},${rgb.g},${rgb.b},0.2),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.2);}80% {box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.3),0 0 0 30px rgba(${rgb.r},${rgb.g},${rgb.b},0),0 0 0 26.7px rgba(${rgb.r},${rgb.g},${rgb.b},0.067);}100% {box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.3),0 0 0 30px rgba(${rgb.r},${rgb.g},${rgb.b},0),0 0 0 40px rgba(${rgb.r},${rgb.g},${rgb.b},0.0);}`;
      } else {
        out += `0% {box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.98),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.7),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.7);}40% {box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.98),0 0 0 15px rgba(${rgb.r},${rgb.g},${rgb.b},0.7),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.7);}80% {box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.98),0 0 0 30px rgba(${rgb.r},${rgb.g},${rgb.b},0),0 0 0 26.7px rgba(${rgb.r},${rgb.g},${rgb.b},0.3);} 100% {box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.98),0 0 0 30px rgba(${rgb.r},${rgb.g},${rgb.b},0),0 0 0 40px rgba(${rgb.r},${rgb.g},${rgb.b},0.0);}`;
      }
    }

    out += `\r\n}\r\n`;
    return out;
  }

  static getFrameEffectBr2(frName, eff, fullMs) {
    if (fullMs['SINGLE_EFFECT_CH']) {
      if (fullMs['SINGLE_EFFECT_CH'] === "Y") {
        let out = `\r\n@keyframes ${frName}{\r\n`;
        out += this.getOnceEffectLib(fullMs, 2);
        out += "\r\n}\r\n";
        return out;
      }
    }
    let out = `\r\n@-webkit-keyframes ${frName}{\r\n`;
    if (eff === 'opacity_up') {
      out += '0% {opacity:0;} 100% {opacity:1;}';
    }
    if (eff === 'opacity_down') {
      out += '0% {opacity:1;} 100% {opacity:0;}';
    }
    if (eff === 'bg_left') {
      out += '0% {background-position-x: 0%;} 100% {background-position-x: 200%;}';
    }
    if (eff === 'bg_right') {
      out += '0% {background-position-x: 0%;} 100% {background-position-x: -100%;}';
    }
    if (eff === 'telefon') {
      out += this.getOneTelefonEffect('-webkit-transform');
    }
    if (eff !== 'telefon' && eff.includes('telefon')) {
      out += this.getComplexEffectTranform('-webkit-transform', eff);
    } else {
      const ms_s = this.get_implodeEffect();
      let iz = 0;
      let str1 = "";
      let str2 = "";
      let str3 = "";
      for (const [key, val] of Object.entries(ms_s)) {
        if (eff.includes(key)) {
          iz++;
          str1 += ` ${val[0]}${val[1]}`;
          str2 += ` ${val[0]}${val[3]}`;
          str3 += ` ${val[0]}${val[2]}`;
        }
      }

      if (iz > 0) {
        out += `0% {-webkit-transform: ${str1};} 50% {-webkit-transform:  ${str2};} 100% {-webkit-transform:  ${str3};}`;
      }
      if (eff === 'opacity_up_mnogo') {
        out += '0% {opacity:0;} 50% {opacity:1;} 100% {opacity:0;}';
      }
      if (eff === 'opacity_down_mnogo') {
        out += '0% {opacity:1;} 50% {opacity:0;} 100% {opacity:1;}';
      }
      if (eff === 'wolna_eff') {
        const rgb = this.hexToRgb(fullMs['COLOR_ID']);
        let fl_volna = 0;
        if (fullMs['VOLNA_OPASITY_CH']) {
          if (fullMs['VOLNA_OPASITY_CH'] === "Y") {
            fl_volna = 1; /* Высокая прозрачность волны */
          }
        }
        if (fl_volna === 1) {
          out += `0% {-webkit-box-shadow:0 8px 10px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.3),0 0 0 0 rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.2),0 0 0 0 rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.2);} 40% {-webkit-box-shadow:0 8px 10px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.3),0 0 0 15px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.2),0 0 0 0 rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.2);} 80% {-webkit-box-shadow:0 8px 10px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.3),0 0 0 30px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0),0 0 0 26.7px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.067);} 100% {-webkit-box-shadow:0 8px 10px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.3),0 0 0 30px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0),0 0 0 40px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.0);}`;
        } else {
          out += `0% {-webkit-box-shadow:0 0px 10px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.98),0 0 0 0 rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.7),0 0 0 0 rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.7);} 40% {-webkit-box-shadow:0 0px 10px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.98),0 0 0 15px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.7),0 0 0 0 rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.7);} 80% {-webkit-box-shadow:0 0px 10px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.98),0 0 0 30px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0),0 0 0 26.7px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.3);} 100% {-webkit-box-shadow:0 0px 10px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.98),0 0 0 30px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0),0 0 0 40px rgba(${rgb['r']},${rgb['g']},${rgb['b']},0.0);}`;
        }
      }
      out += "\r\n}\r\n";
    }
    return out;
  }

  static getFrameEffectBr3(frName, eff, fullMs) {
    let out = "";
    
    if (fullMs.SINGLE_EFFECT_CH) {
      if (fullMs.SINGLE_EFFECT_CH === "Y") {
        out = `\r\n@keyframes ${frName}{\r\n`;
        out += AnimatedGraphics.getOnceEffectLib(fullMs, 3);
        out += "\r\n}\r\n";
        return out;
      }
    }
    
    out = `\r\n@-moz-keyframes ${frName}{\r\n`;
    
    if (eff === 'opacity_up') {
      out += '0% {opacity:0;} 100% {opacity:1;}';
    }
    
    if (eff === 'opacity_down') {
      out += '0% {opacity:1;} 100% {opacity:0;}';
    }
    
    if (eff === 'bg_left') {
      out += '0% {background-position-x: 0%;} 100% {background-position-x: 200%;}';
    }
    
    if (eff === 'bg_right') {
      out += '0% {background-position-x: 0%;} 100% {background-position-x: -100%;}';
    }
    
    if (eff === 'telefon') {
      out += AnimatedGraphics.getOneTelefonEffect('-moz-transform');
    }
    
    if (eff !== 'telefon' && eff.includes('telefon')) {
      out += AnimatedGraphics.getComplexEffectTranform('-moz-transform', eff);
    } else {
      const ms_s = AnimatedGraphics.get_implodeEffect();
      let iz = 0;
      let str1 = "";
      let str2 = "";
      let str3 = "";
      
      for (const [key, val] of Object.entries(ms_s)) {
        if (eff.includes(key)) {
          iz++;
          str1 += ` ${val[0]}${val[1]}`;
          str2 += ` ${val[0]}${val[3]}`;
          str3 += ` ${val[0]}${val[2]}`;
        }
      }
      
      if (iz > 0) {
        out += `0% {-moz-transform: ${str1};} 50% {-moz-transform: ${str2};} 100% {-moz-transform: ${str3};}`;
      }
    }
    
    if (eff === 'opacity_up_mnogo') {
      out += '0% {opacity:0;} 50% {opacity:1;} 100% {opacity:0;}';
    }
    
    if (eff === 'opacity_down_mnogo') {
      out += '0% {opacity:1;} 50% {opacity:0;} 100% {opacity:1;}';
    }
    
    if (eff === 'wolna_eff') {
      const rgb = AnimatedGraphics.hexToRgb(fullMs.COLOR_ID);
      let fl_volna = 0;
      
      if (fullMs.VOLNA_OPASITY_CH === "Y") {
        fl_volna = 1;
      }
      
      if (fl_volna === 1) {
        out += `0% {-moz-box-shadow:0 8px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.3),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.2),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.2);} 40% {-moz-box-shadow:0 8px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.3),0 0 0 15px rgba(${rgb.r},${rgb.g},${rgb.b},0.2),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.2);} 80% {-moz-box-shadow:0 8px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.3),0 0 0 30px rgba(${rgb.r},${rgb.g},${rgb.b},0),0 0 0 26.7px rgba(${rgb.r},${rgb.g},${rgb.b},0.067);} 100% {-moz-box-shadow:0 8px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.3),0 0 0 30px rgba(${rgb.r},${rgb.g},${rgb.b},0),0 0 0 40px rgba(${rgb.r},${rgb.g},${rgb.b},0.0)};`;
      } else {
        out += `0% {-moz-box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.98),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.7),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.7);} 40% {-moz-box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.98),0 0 0 15px rgba(${rgb.r},${rgb.g},${rgb.b},0.7),0 0 0 0 rgba(${rgb.r},${rgb.g},${rgb.b},0.7);} 80% {-moz-box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.98),0 0 0 30px rgba(${rgb.r},${rgb.g},${rgb.b},0),0 0 0 26.7px rgba(${rgb.r},${rgb.g},${rgb.b},0.3);} 100% {-moz-box-shadow:0 0px 10px rgba(${rgb.r},${rgb.g},${rgb.b},0.98),0 0 0 30px rgba(${rgb.r},${rgb.g},${rgb.b},0),0 0 0 40px rgba(${rgb.r},${rgb.g},${rgb.b},0.0)};`;
      }
    }
    
    out += "\r\n}\r\n";
    return out;
  }
  static prepareMs(arParams_0) {
    let arParams = [];
    let out = [];
    let ms_iz = [];
    let ms_dbl = [];
    let imax = 1;

    if (arParams_0.hasOwnProperty("ALL_BLOK")) {
      let rr = (arParams_0["ALL_BLOK"]).toString().trim();
      if (rr.length > 0) {
        rr = rr.replace(/\D/g, "");
        rr = parseInt(rr, 10);
        if (rr > 0) {
          imax = rr;
        }
      }
    }

    let iz = 1;
    let iz_2 = 1;
    let iz_new = 0;

    if (iz > 0) {
      for (iz = 1; iz <= imax; iz++) {
        let fl_grupp = 0;
        let fl_len = 0;
        if (arParams_0.hasOwnProperty("CLASS_OR_ID" + iz)) {
          let str = arParams_0["CLASS_OR_ID" + iz].trim();
          if (str.length > 0) {
            fl_len = 1;
            let ms_class = arParams_0["CLASS_OR_ID" + iz].split(",");
            if (ms_class.length > 1) {
              fl_grupp = 1;
            }
          }
        }
        if (fl_len === 1 && fl_grupp === 0) {
          iz_new++;
          arParams = this.selectorParamPlosk(iz, arParams, arParams_0, iz_new);
        }
        if (fl_len === 1 && fl_grupp === 1) {
          iz_new++;
          let msP = this.selectorParamGrupp(iz, arParams, arParams_0, iz_new);
          arParams = msP[0];
          iz_new = msP[1];
        }
      }

      arParams_0["ALL_BLOK"] = iz_new;
      imax = iz_new;
      iz = 1;
      iz_2 = 1;

      for (iz = 1; iz <= imax; iz++) {
        let selector = "";
        let fl_stop = 1;
        let fl_gruppa = 0;
        if (arParams.hasOwnProperty('CLASS_OR_ID' + iz)) {
          selector = arParams['CLASS_OR_ID' + iz].trim();
          if (selector.length > 0) {
            fl_stop = 0;
          }
        }
        if (fl_stop === 1) {
          continue;
        }
        if (ms_dbl.includes(iz)) {
          continue;
        }
        let msEff = this.selectorParam(iz, arParams);
        for (let eff_all of msEff) {
          if (!ms_iz[selector]) ms_iz[selector] = [];
          ms_iz[selector].push(eff_all);
        }
        let inext = iz + 1;
        iz_2 = inext;
        for (iz_2 = inext; iz_2 <= imax; iz_2++) {
          let fl_stop_2 = 1;
          let selector_2 = "";
          if (arParams.hasOwnProperty('CLASS_OR_ID' + iz_2)) {
            selector_2 = arParams['CLASS_OR_ID' + iz_2].trim();
            if (selector_2.length > 0) {
              fl_stop_2 = 0;
            }
          }
          if (fl_stop_2 === 1) {
            continue;
          }
          if (selector === selector_2) {
            ms_dbl.push(iz_2);
            let msEff = this.selectorParam(iz_2, arParams);
            for (let eff_all of msEff) {
              ms_iz[selector].push(eff_all);
            }
          }
        }
      }
    }
    ms_iz = this.inplodeTrasform(ms_iz);
    ms_iz = this.checkForvard(ms_iz);
    out = [ms_iz, arParams];
    return out;
  }
  static selectorParamPlosk(iz, arParams, arParams_0, iz_new) {
    const out = {};
	for (var keyOut in arParams){
		out[keyOut] = arParams[keyOut];
	}
    for (const [key, val] of Object.entries(arParams_0)) {
      const first = key.substr(0, 1);
      if (first === "~") {
        continue;
      }
      let rr = key.trim();
      rr = rr.replace(/^[\D]+/ig, "");
      rr = rr.trim();
      if (rr.length > 0) {
        rr = parseInt(rr);
        if (rr === iz) {
          const newKey = key.replace(/\d/ig, "");
          out[`${newKey.trim()}${iz_new}`] = val;
		  
        }
      }
    }
    return out;
  }
  static selectorParamGrupp(iz, arParams, arParams_0, iz_new) {
    let out = {};
    let iz_out = iz_new;
    let i_col = 0;
    let iMnojitel = 0;
    const ms_class = arParams_0["CLASS_OR_ID" + iz].split(",");
    for (const val of ms_class) {
      if (i_col > 0) {
        iz_out++;
      }
      const cls = val.trim();
      if (cls.length > 0) {
        for (const key in arParams_0) {
          const first = key.charAt(0);
          if (first === "~") {
            continue;
          }
          const rr = key.replace(/^\D+/, "").trim();
          if (rr.length > 0) {
            const rrNum = parseInt(rr);
            if (rrNum === iz) {
              const newKey = key.replace(/\d/, "").trim();
              out[`${newKey}${iz_out}`] = arParams_0[key];
              if (newKey === 'START_ZADERJKA') {
                const z = parseFloat(arParams_0["ZADERJKA_ZW" + iz]);
                const z2 = parseFloat(arParams_0["START_ZADERJKA" + iz]);
                const rzZaderjkaGrupp = z2 + iMnojitel * z;
                out["START_ZADERJKA" + iz_out] = rzZaderjkaGrupp;
                iMnojitel++;
              }
              out["CLASS_OR_ID" + iz_out] = cls;
              i_col++;
            }
          }
        }
      }
    }
    return [out, iz_out];
  }
  static selectorParam(iz, arParams) {
    //const out = Array(20).fill({});
	const out = [];
    let ms_effect = [];
    
    for (const [key, val] of Object.entries(arParams)) {
      const first = key.charAt(0);
      
      if (first === "~") {
        continue;
      }
      
      let rr = key.trim().replace(/^[\D]+/, "");
      let newKey = key.replace(/\d/g, "").trim();
      
      if (rr.length > 0) {
        rr = parseInt(rr);
        
        if (rr === iz) {
          if (newKey === 'EFFECT') {
            ms_effect = val;
          }
        }
      }
    }
    
    if (!arParams['EFFECT' + iz]) {
      if (arParams['SINGLE_EFFECT_CH' + iz] === "Y") {
        arParams['EFFECT' + iz] = ["noeffect" + iz];
        ms_effect = ["noeffect" + iz];
      }
    }
    
    let i_eff = 0;
    
    for (const eff of ms_effect) {
      for (const [key, val] of Object.entries(arParams)) {
        const first = key.charAt(0);
        
        if (first === "~") {
          continue;
        }
        
        let rr = key.trim().replace(/^[\D]+/, "");
        let newKey = key.replace(/\d/g, "").trim();
        
        if (rr.length > 0) {
          rr = parseInt(rr);
          
          if (rr === iz) {
			if(typeof out[i_eff] == 'undefined'){
				out.lenth = (i_eff+1);
				out[i_eff] = {};
			}
            if (newKey === 'EFFECT') {
              ms_effect = val;
              out[i_eff][newKey] = eff;
              out[i_eff][key.trim()] = val;
            } else {
              out[i_eff][newKey] = val;
              out[i_eff][key.trim()] = val;
            }
          }
        }
      }
      i_eff++;
    }
    
    return out;
  }
  static getGruppEffect() {
    const out = {
      attention: {
        NAME: "ANIMATEDGRAPHICSFULL_GRUPP_ATTENTION",
        NAME2: "ANIMATEDGRAPHICSFULL_GRUPP_ATTENTION2",
        CODE_EFF: ["flip1", "rubber", "bounce", "bounceballbottom", "flash", "pulse", "shake", "swing", "tada", "wobble"]
      },
      entrance: {
        NAME: "ANIMATEDGRAPHICSFULL_GRUPP_ENTRANCE",
        NAME2: "ANIMATEDGRAPHICSFULL_GRUPP_ENTRANCE2",
        CODE_EFF: ["flipinx", "flipiny", "speedin", "slideindown", "slideinleft", "slideinright", "slideinup", "fadeindown", "fadeindownbig", "fadeinleft", "fadeinleftbig", "fadeinright", "fadeinrightbig", "fadeinup", "fadeinupbig", "zoomin", "zoomindown", "zoominleft", "zoominright", "zoominup", "bouncein", "bounceindown", "bounceinleft", "bounceinright", "bounceinup", "rotatein", "rotateindownleft", "rotateindownright", "rotateinupleft", "rotateinupright", "swirlinfwd", "swirlinfwdcenter", "swirlinfwdleft", "swirlinfwdright", "swirlinfwdtop", "swirlinbckbottom", "swirlinbckcenter", "swirlinbckleft", "swirlinbckright", "swirlinbcktop"]
      },
      exit: {
        NAME: "ANIMATEDGRAPHICSFULL_GRUPP_EXIT",
        NAME2: "ANIMATEDGRAPHICSFULL_GRUPP_EXIT2",
        CODE_EFF: ["flipoutx", "flipouty", "lightspeedout", "slideoutdown", "slideoutleft", "slideoutright", "slideoutup", "fadeoutdown", "fadeoutdownbig", "fadeoutleft", "fadeoutleftbig", "fadeoutright", "fadeoutrightbig", "fadeoutup", "fadeoutupbig", "zoomoutdown", "zoomoutleft", "zoomoutright", "zoomoutup", "bounceout", "bounceoutdown", "bounceoutleft", "bounceoutright", "bounceoutup", "rotateout", "rotateoutdownleft", "rotateoutdownright", "rotateoutupleft", "rotateoutupright", "swirloutfwd", "swirloutfwdcenter", "swirloutfwdleft", "swirloutfwdright", "swirloutfwdtop", "swirloutbckbottom", "swirloutbckcenter", "swirloutbckleft", "swirloutbckright", "swirloutbcktop"]
      },
      drugie: {
        NAME: "ANIMATEDGRAPHICSFULL_GRUPP_DRUGIE",
        NAME2: "ANIMATEDGRAPHICSFULL_GRUPP_DRUGIE2",
        CODE_EFF: []
      }
    };
    return out;
  }

  static inplodeTrasform(ms_iz) {
    const out = {};
	//const out = Array(40).fill( Array(40).fill('') );
    let idd2 = 0;
    let idd3 = 0;
    for (const [key2, val2] of Object.entries(ms_iz)) {
      const ms_complex = {};
      let iz = -1;
      const ms_compare = [];
      for (const val3 of val2) {
        iz++;
        if (ms_compare.includes(iz)) {
          continue;
        }
        if ((val3.EFFECT === 'circle_left' || val3.EFFECT === 'circle_right' || val3.EFFECT === 'rotate_x' || val3.EFFECT === 'rotate_y' || val3.EFFECT === 'from_small_to_big' || val3.EFFECT === 'from_big_to_small' || val3.EFFECT === 'telefon' || val3.EFFECT === 'rotate_repspective_x_1' || val3.EFFECT === 'rotate_repspective_x_2' || val3.EFFECT === 'rotate_repspective_y_1' || val3.EFFECT === 'rotate_repspective_y_2') && (val3.STOP_COUNT === "" || val3.STOP_COUNT === "0") && val3.SINGLE_EFFECT_CH !== "Y") {
          let fl_comlex = 0;
          let effect_comlex = "";
          let iw = -1;
          for (const val4 of val2) {
            iw++;
            if (iw <= iz) {
              continue;
            }
            if ((val4.EFFECT === 'circle_left' || val4.EFFECT === 'circle_right' || val4.EFFECT === 'rotate_x' || val4.EFFECT === 'rotate_y' || val4.EFFECT === 'from_small_to_big' || val4.EFFECT === 'from_big_to_small' || val4.EFFECT === 'telefon' || val4.EFFECT === 'rotate_repspective_x_1' || val4.EFFECT === 'rotate_repspective_x_2' || val4.EFFECT === 'rotate_repspective_y_1' || val4.EFFECT === 'rotate_repspective_y_2') && (val4.STOP_COUNT === "" || val4.STOP_COUNT === "0") && val4.SINGLE_EFFECT_CH !== "Y") {
              ms_compare.push(iw);
              fl_comlex = 1;
              if (effect_comlex.length === 0) {
                effect_comlex = val3.EFFECT + "_" + val4.EFFECT;
              } else {
                effect_comlex = effect_comlex + "_" + val4.EFFECT;
              }
            }
          }
		  if(typeof out[key2] == "undefined"){
			  out[key2] = [];
			  out[key2].length = (idd3+1);
		  }
		  if(typeof out[key2][idd3] == "undefined"){
			  out[key2].length = (idd3+1);
		  }
          if (fl_comlex === 1) {
			for (var key in val3){
					ms_complex[key] = val3[key];
		    }
            //ms_complex = val3;/* ПРоверить*/
            ms_complex.EFFECT = effect_comlex;
            out[key2][idd3] = ms_complex;
          } else {
            out[key2][idd3] = val3; /* Тут то же не правильное присовение */
          }
        } else {
		  if(typeof out[key2] == "undefined"){
			  out[key2] = [];
			  out[key2].length = (idd3+1);
		  }	
          out[key2][idd3] = val3;
        }
        idd3++;
      }
      idd2++;
    }
    return out;
  }

  static getOneTelefonEffect(br) {
    const msTremolo = this.getMsTremolo();
    let out = "";
    for (const val of msTremolo) {
      out = out + val.perc + '% {' + br + ': rotateZ(' + val.deg + 'deg);}';
    }
    return out;
  }

  static get_implodeEffect() {
    const out = {
      rotate_x: ["rotateX", '(0deg)', '(360deg)', '(180deg)'],
      rotate_y: ["rotateY", '(0deg)', '(360deg)', '(180deg)'],
      circle_left: ["rotateZ", '(0deg)', '(-360deg)', '(-180deg)'],
      circle_right: ["rotateZ", '(0deg)', '(360deg)', '(180deg)'],
      rotate_repspective_x_1: ["rotateX", '(0deg)', '(360deg)', '(180deg)'],
      rotate_repspective_x_2: ["rotateX", '(0deg)', '(-360deg)', '(-180deg)'],
      rotate_repspective_y_1: ["rotateY", '(0deg)', '(360deg)', '(180deg)'],
      rotate_repspective_y_2: ["rotateY", '(0deg)', '(-360deg)', '(-180deg)'],
      from_small_to_big: ["scale", '(0)', '(0)', '(1)'],
      from_big_to_small: ["scale", '(1)', '(1)', '(0)']
    };
    return out;
  }
  static getComplexEffectTranform(br, eff) {
        const msTremolo = this.getMsTremolo();
        const col = msTremolo.length;
        let out_itog = "";
        let iz = 0;
        
        msTremolo.forEach(val => {
            let fl_x = 0;
            let fl_y = 0;
            let fl_z = 0;
            let out = `${val.perc}% {${br}: `;
            
            if (eff.includes("rotate_repspective_x_1") && fl_x === 0) {
                const degAll = iz * 360 / (col - 1) * 1;
                out += `${br} rotateX(${degAll}deg) `;
                fl_x = 1;
            }
            if (eff.includes("rotate_repspective_x_2") && fl_x === 0) {
                const degAll = iz * 360 / (col - 1) * -1;
                out += ` rotateX(${degAll}deg) `;
                fl_x = 1;
            }
            if (eff.includes("rotate_repspective_y_1") && fl_y === 0) {
                const degAll = iz * 360 / (col - 1) * 1;
                out += ` rotateY(${degAll}deg) `;
                fl_y = 1;
            }
            if (eff.includes("rotate_repspective_y_2") && fl_y === 0) {
                const degAll = iz * 360 / (col - 1) * -1;
                out += ` rotateY(${degAll}deg) `;
                fl_y = 1;
            }
            if (eff.includes("rotate_x") && fl_x === 0) {
                const degAll = iz * 360 / (col - 1);
                out += ` rotateX(${degAll}deg) `;
                fl_x = 1;
            }
            if (eff.includes("rotate_y") && fl_y === 0) {
                const degAll = iz * 360 / (col - 1);
                out += ` rotateY(${degAll}deg) `;
                fl_y = 1;
            }
            if (eff.includes("circle_left") && fl_z === 0) {
                let degAll;
                if (eff.includes("telefon")) {
                    degAll = iz * 360 / (col - 1) * -1 + val.deg;
                }
                out += ` rotateZ(${degAll}deg) `;
                fl_z = 1;
            }
            if (eff.includes("circle_right") && fl_z === 0) {
                let degAll;
                if (eff.includes("telefon")) {
                    degAll = iz * 360 / (col - 1) * 1 + val.deg;
                }
                out += ` rotateZ(${degAll}deg) `;
                fl_z = 1;
            }
            if (eff.includes("from_small_to_big")) {
                const z05 = col / 2;
                let degAll;
                if (iz <= z05) {
                    degAll = iz / z05;
                } else {
                    degAll = 1 - (iz - z05) / z05;
                }
                out += ` scale(${degAll}) `;
            }
            if (eff.includes("from_big_to_small")) {
                const z05 = col / 2;
                let degAll;
                if (iz <= z05) {
                    degAll = 1 - (z05 - iz) / z05;
                } else {
                    degAll = 1 - (iz - z05) / z05;
                }
                out += `: scale(${degAll}) `;
            }
            if (eff.includes("telefon") && fl_z === 0) {
                out += ` rotateZ(${val.deg}deg) `;
            }
            out += ';}';
            out_itog += out;
            iz++;
        });
        
        return out_itog;
    }
    
    static hexToRgb(hex, alpha = false) {
        hex = hex.replace('#', '');
        const length = hex.length;
        const rgb = {
            r: parseInt(length === 6 ? hex.substring(0, 2) : (length === 3 ? hex[0].repeat(2) : 0), 16),
            g: parseInt(length === 6 ? hex.substring(2, 4) : (length === 3 ? hex[1].repeat(2) : 0), 16),
            b: parseInt(length === 6 ? hex.substring(4, 6) : (length === 3 ? hex[2].repeat(2) : 0), 16)
        };
        
        if (alpha) {
            rgb.a = alpha;
        }
        
        return rgb;
    }
	static checkForvard(ms_iz) {
    for (const [key, val] of Object.entries(ms_iz)) {
      let fl_add = 0;
      for (const val2 of val) {
		if (typeof val2 !== 'undefined') {  
			if (typeof val2['EFFECT'] !== 'undefined') {
			  if (val2['EFFECT'] === 'opacity_up_mnogo' || val2['EFFECT'] === 'opacity_down_mnogo') {
				let iz = 0;
				for (const val3 of val) {
				  if (val3['EFFECT'] === 'opacity_up' || val3['EFFECT'] === 'opacity_down') {
					ms_iz[key][iz]['FORWARD'] = 0;
				  }
				  iz++;
				}
			  }
			}
		 }
      }
    }
    return ms_iz;
  }
  static getOnceEffectLib(fullMs, n) {
        let timing = '-webkit-animation-timing-function';
        let transition_timing = 'transition-timing-function';
        let transform_origin = 'transform-origin';
        let tr = 'transform';
        
        if (n === 1) {
            timing = 'animation-timing-function';
            transition_timing = 'transition-timing-function';
            transform_origin = 'transform-origin';
        }
        if (n === 2) {
            tr = '-webkit-transform';
            transition_timing = '-webkit-transition-timing-function';
            transform_origin = '-webkit-transform-origin';
        }
        if (n === 3) {
            tr = '-moz-transform';
            timing = '-moz-animation-timing-function';
            transition_timing = '-moz-transition-timing-function';
            transform_origin = '-moz-transform-origin';
        }
        if (n === 4) {
            tr = '-o-transform';
            transition_timing = '-o-transition-timing-function';
            transform_origin = '-o-transform-origin';
        }
        if (n === 5) {
            tr = '-ms-transform';
            transform_origin = '-ms-transform-origin';
        }
        
        let out = "";
        
        switch (fullMs.SINGLE_EFFECT_LIST) {
            case 'swirloutbcktop':
                out = `0% {opacity: 1; ${tr}: rotate(0) scale(1); ${transform_origin}: 50% 0;} 100% {opacity: 0; ${tr}: rotate(-540deg) scale(0); ${transform_origin}: 50% 0;}`;
                break;
            case 'swirloutbckright':
                out = `0% {opacity: 1; ${tr}: rotate(0) scale(1); ${transform_origin}: 100% 50%;} 100% {opacity: 0; ${tr}: rotate(-540deg) scale(0); ${transform_origin}: 100% 50%;}`;
                break;
            case 'swirloutbckleft':
                out = `0% {opacity: 1; ${tr}: rotate(0) scale(1); ${transform_origin}: 0 50%;} 100% {opacity: 0; ${tr}: rotate(-540deg) scale(0); ${transform_origin}: 0 50%;}`;
                break;
            case 'swirloutbckcenter':
                out = `0% {opacity: 1; ${tr}: rotate(0) scale(1);} 100% {opacity: 0; ${tr}: rotate(-540deg) scale(0);}`;
                break;
            case 'swirloutbckbottom':
                out = `0% {opacity: 1; ${tr}: rotate(0) scale(1); ${transform_origin}: 50% 100%;} 100% {opacity: 0; ${tr}: rotate(-540deg) scale(0); ${transform_origin}: 50% 100%;}`;
                break;
            case 'swirloutfwdtop':
                out = `0% {opacity: 1; ${tr}: rotate(0) scale(1); ${transform_origin}: 50% 0;} 100% {opacity: 0; ${tr}: rotate(-540deg) scale(2); ${transform_origin}: 50% 0;}`;
                break;
            case 'swirloutfwdright':
                out = `0% {opacity: 1; ${tr}: rotate(0) scale(1); ${transform_origin}: 100% 50%;} 100% {opacity: 0; ${tr}: rotate(-540deg) scale(2); ${transform_origin}: 100% 50%;}`;
                break;
        }
		if (fullMs.SINGLE_EFFECT_LIST === 'swirloutfwdleft') {
      out = `
        0% {
          opacity: 1;
          ${tr}: rotate(0) scale(1);
          ${transform_origin}: 0 50%;
        }
        100% {
          opacity: 0;
          ${tr}: rotate(-540deg) scale(2);
          ${transform_origin}: 0 50%;
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'swirloutfwdcenter') {
      out = `
        0% {
          opacity: 1;
          ${tr}: rotate(0) scale(1);
        }
        100% {
          opacity: 0;
          ${tr}: rotate(-540deg) scale(2);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'swirloutfwd') {
      out = `
        0% {
          opacity: 1;
          ${tr}: rotate(0) scale(1);
          ${transform_origin}: 50% 100%;
        }
        100% {
          opacity: 0;
          ${tr}: rotate(-540deg) scale(2);
          ${transform_origin}: 50% 100%;
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'rotateoutupright') {
      out = `
        0% {
          ${transform_origin}: right bottom;
          opacity: 1;
        }
        100% {
          ${transform_origin}: right bottom;
          ${tr}: rotate3d(0, 0, 1, 90deg);
          opacity: 0;
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'rotateoutupleft') {
      out = `
        0% {
          ${transform_origin}: left bottom;
          opacity: 1;
        }
        100% {
          ${transform_origin}: left bottom;
          ${tr}: rotate3d(0, 0, 1, -45deg);
          opacity: 0;
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'rotateoutdownright') {
      out = `
        0% {
          ${transform_origin}: right bottom;
          opacity: 1;
        }
        100% {
          ${transform_origin}: right bottom;
          ${tr}: rotate3d(0, 0, 1, -45deg);
          opacity: 0;
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'rotateoutdownleft') {
      out = `
        0% {
          ${transform_origin}: left bottom;
          opacity: 1;
        }
        100% {
          ${transform_origin}: left bottom;
          ${tr}: rotate3d(0, 0, 1, 45deg);
          opacity: 0;
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'rotateout') {
      out = `
        0% {
          ${transform_origin}: center;
          opacity: 1;
        }
        100% {
          ${transform_origin}: center;
          ${tr}: rotate3d(0, 0, 1, 200deg);
          opacity: 0;
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'bounceoutup') {
      out = `
        20% {
          ${tr}: translate3d(0, -10px, 0);
        }
        40%, 45% {
          opacity: 1;
          ${tr}: translate3d(0, 20px, 0);
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(0, -2000px, 0);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'bounceoutright') {
      out = `
        20% {
          opacity: 1;
          ${tr}: translate3d(-20px, 0, 0);
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(2000px, 0, 0);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'bounceoutleft') {
      out = `
        20% {
          opacity: 1;
          ${tr}: translate3d(20px, 0, 0);
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(-2000px, 0, 0);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'bounceoutdown') {
      out = `
        20% {
          ${tr}: translate3d(0, 10px, 0);
        }
        40%, 45% {
          opacity: 1;
          ${tr}: translate3d(0, -20px, 0);
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(0, 2000px, 0);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'bounceout') {
      out = `
        20% {
          ${tr}: scale3d(0.9, 0.9, 0.9);
        }
        50%, 55% {
          opacity: 1;
          ${tr}: scale3d(1.1, 1.1, 1.1);
        }
        100% {
          opacity: 0;
          ${tr}: scale3d(0.3, 0.3, 0.3);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'zoomoutup') {
      out = `
        40% {
          opacity: 1;
          ${tr}: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
          ${timing}: cubic-bezier(0.550, 0.055, 0.675, 0.190);
        }
        100% {
          opacity: 0;
          ${tr}: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
          ${transform_origin}: center bottom;
          ${timing}: cubic-bezier(0.175, 0.885, 0.320, 1);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'zoomoutright') {
      out = `
        40% {
          opacity: 1;
          ${tr}: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
        }
        100% {
          opacity: 0;
          ${tr}: scale(0.1) translate3d(2000px, 0, 0);
          ${transform_origin}: right center;
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'zoomoutleft') {
      out = `
        40% {
          opacity: 1;
          ${tr}: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
        }
        100% {
          opacity: 0;
          ${tr}: scale(.1) translate3d(-2000px, 0, 0);
          ${transform_origin}: left center;
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'zoomoutdown') {
      out = `
        40% {
          opacity: 1;
          ${tr}: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
          ${timing}: cubic-bezier(0.550, 0.055, 0.675, 0.190);
        }
        100% {
          opacity: 0;
          ${tr}: scale3d(.1, .1, .1) translate3d(0, 2000px, 0);
          ${transform_origin}: center bottom;
          ${timing}: cubic-bezier(0.175, 0.885, 0.320, 1);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'fadeoutupbig') {
      out = `
        0% {
          opacity: 1;
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(0, -2000px, 0);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'fadeoutup') {
      out = `
        0% {
          opacity: 1;
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(0, -100%, 0);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'fadeoutrightbig') {
      out = `
        0% {
          opacity: 1;
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(2000px, 0, 0);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'fadeoutright') {
      out = `
        0% {
          opacity: 1;
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(100%, 0, 0);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'fadeoutleftbig') {
      out = `
        0% {
          opacity: 1;
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(-2000px, 0, 0);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'fadeoutleft') {
      out = `
        0% {
          opacity: 1;
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(-100%, 0, 0);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'fadeoutdownbig') {
      out = `
        0% {
          opacity: 1;
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(0, 2000px, 0);
        }
      `;
    } else if (fullMs.SINGLE_EFFECT_LIST === 'fadeoutdown') {
      out = `
        0% {
          opacity: 1;
        }
        100% {
          opacity: 0;
          ${tr}: translate3d(0, 100%, 0);
        }
      `;
    }
	 switch (fullMs['SINGLE_EFFECT_LIST']) {
            case 'slideoutup':
                out = `0% {${tr}: translateY(0);} 100% {visibility: hidden; ${tr}: translateY(-100%);}`;
                break;
            case 'slideoutright':
                out = `0% {${tr}: translateX(0);} 100% {visibility: hidden; ${tr}: translateX(100%);}`;
                break;
            case 'slideoutleft':
                out = `0% {${tr}: translateX(0);} 100% {visibility: hidden; ${tr}: translateX(-100%);}`;
                break;
            case 'slideoutdown':
                out = `0% {${tr}: translateY(0);} 100% {visibility: hidden; ${tr}: translateY(100%);}`;
                break;
            case 'lightspeedout':
                out = `0% {opacity: 1;} 100% {${tr}: translate3d(100%, 0, 0) skewX(30deg); opacity: 0;}`;
                break;
            case 'flipouty':
                out = `0% {${tr}: perspective(400px);} 30% {${tr}: perspective(400px) rotate3d(0, 1, 0, -15deg); opacity: 1;} 100% {${tr}: perspective(400px) rotate3d(0, 1, 0, 90deg); opacity: 0;}`;
                break;
            case 'flipoutx':
                out = `0% {${tr}: perspective(400px);} 30% {${tr}: perspective(400px) rotate3d(1, 0, 0, -20deg); opacity: 1;} 100% {${tr}: perspective(400px) rotate3d(1, 0, 0, 90deg); opacity: 0;}`;
                break;
            // Additional cases for other animations
            case 'swirlinbcktop':
                out = `0% {opacity: 0; ${tr}: rotate(-540deg) scale(2); ${transform_origin}: 50% 0;} 100% {opacity: 1; ${tr}: rotate(0) scale(1); ${transform_origin}: 50% 0;}`;
                break;
            // Continue with similar structure for other cases...
            case 'bounceinup':
                out = `0%, 60%, 75%, 90%, 100% {${transition_timing}: cubic-bezier(0.215, 0.610, 0.355, 1.000);} 0% {opacity: 0; ${tr}: translate3d(0, 3000px, 0);} 60% {opacity: 1; ${tr}: translate3d(0, -20px, 0);} 75% {${tr}: translate3d(0, 10px, 0);} 90% {${tr}: translate3d(0, -5px, 0);} 100% {${tr}: translate3d(0, 0, 0);}`;
                break;
            default:
                out = 'No effect found.';
                break;
        }
		if (fullMs['SINGLE_EFFECT_LIST'] === 'bounceinright') {
            out = '0%, 60%, 75%, 90%, 100% {' + transitionTiming + ': cubic-bezier(0.215, 0.610, 0.355, 1.000);}0% {opacity: 0;' + tr + ': translate3d(3000px, 0, 0);}60% {opacity: 1;' + tr + ': translate3d(-25px, 0, 0);}75% {' + tr + ': translate3d(10px, 0, 0);}90% {' + tr + ': translate3d(-5px, 0, 0);}100% {' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'bounceinleft') {
            out = '0%, 60%, 75%, 90%, 100% {' + transitionTiming + ': cubic-bezier(0.215, 0.610, 0.355, 1.000);}0% {opacity: 0;' + tr + ': translate3d(-3000px, 0, 0);}60% {opacity: 1;' + tr + ': translate3d(25px, 0, 0);}75% {' + tr + ': translate3d(-10px, 0, 0);}90% {' + tr + ': translate3d(5px, 0, 0);}100% {' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'bounceindown') {
            out = '0%, 60%, 75%, 90%, 100% {' + transitionTiming + ': cubic-bezier(0.215, 0.610, 0.355, 1.000);}0% {opacity: 0;' + tr + ': translate3d(0, -3000px, 0);}60% {opacity: 1;' + tr + ': translate3d(0, 25px, 0);}75% {' + tr + ': translate3d(0, -10px, 0);}90% {' + tr + ': translate3d(0, 5px, 0);}100% {' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'bouncein') {
            out = '0%, 20%, 40%, 60%, 80%, 100% {' + transitionTiming + ': cubic-bezier(0.215, 0.610, 0.355, 1.000);}0% {opacity: 0;' + tr + ': scale3d(.3, .3, .3);}20% {' + tr + ': scale3d(1.1, 1.1, 1.1);}40% {' + tr + ': scale3d(.9, .9, .9);}60% {opacity: 1;' + tr + ': scale3d(1.03, 1.03, 1.03);}80% {' + tr + ': scale3d(.97, .97, .97);}100% {opacity: 1;' + tr + ': scale3d(1, 1, 1);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'zoominup') {
            out = '0% {opacity: 0;' + tr + ': scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);' + timing + ': cubic-bezier(0.550, 0.055, 0.675, 0.190);}60% {opacity: 1;' + tr + ': scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);' + timing + ': cubic-bezier(0.175, 0.885, 0.320, 1);}100% {opacity: 1;' + tr + ': scale3d(1, 1, 1) translate3d(0, 0px, 0);' + timing + ': cubic-bezier(0.175, 0.885, 0.320, 1);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'zoominright') {
            out = '0% {opacity: 0;' + tr + ': scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);' + timing + ': cubic-bezier(0.550, 0.055, 0.675, 0.190);}60% {opacity: 1;' + tr + ': scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);' + timing + ': cubic-bezier(0.175, 0.885, 0.320, 1);}100% {opacity: 1;' + tr + ': scale3d(1, 1, 1) translate3d(0px, 0, 0);' + timing + ': cubic-bezier(0.175, 0.885, 0.320, 1);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'zoominleft') {
            out = '0% {opacity: 0;' + tr + ': scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);' + timing + ': cubic-bezier(0.550, 0.055, 0.675, 0.190);}60% {opacity: 1;' + tr + ': scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);' + timing + ': cubic-bezier(0.175, 0.885, 0.320, 1);}100% {opacity: 1;' + tr + ': scale3d(1, 1, 1) translate3d(0px, 0, 0);' + timing + ': cubic-bezier(0.175, 0.885, 0.320, 1);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'zoomindown') {
            out = '0% {opacity: 0;' + tr + ': scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);' + timing + ': cubic-bezier(0.550, 0.055, 0.675, 0.190);}60% {opacity: 1;' + tr + ': scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);' + timing + ': cubic-bezier(0.175, 0.885, 0.320, 1);}100% {opacity: 1;' + tr + ': scale3d(1, 1, 1) translate3d(0, 0px, 0);' + timing + ': cubic-bezier(0.175, 0.885, 0.320, 1);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'zoomin') {
            out = '0% {opacity: 0;' + tr + ': scale3d(0.3, 0.3, 0.3);}50% {opacity: 1;}100% {opacity: 1;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'fadeinupbig') {
            out = '0% {opacity: 0;' + tr + ': translate3d(0, 2000px, 0);}100% {opacity: 1;' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'fadeinup') {
            out = '0% {opacity: 0;' + tr + ': translate3d(0, 100%, 0);}100% {opacity: 1;' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'fadeinrightbig') {
            out = '0% {opacity: 0;' + tr + ': translate3d(2000px, 0, 0);}100% {opacity: 1;' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'fadeinright') {
            out = '0% {opacity: 0;' + tr + ': translate3d(100%, 0, 0);}100% {opacity: 1;' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'fadeinleftbig') {
            out = '0% {opacity: 0;' + tr + ': translate3d(-2000px, 0, 0);}100% {opacity: 1;' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'fadeinleft') {
            out = '0% {opacity: 0;' + tr + ': translate3d(-100%, 0, 0);}100% {opacity: 1;' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'fadeindownbig') {
            out = '0% {opacity: 0;' + tr + ': translate3d(0, -2000px, 0);}100% {opacity: 1;' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'fadeindown') {
            out = '0% {opacity: 0;' + tr + ': translate3d(0, -100%, 0);}100% {opacity: 1;' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] === 'slideinup') {
            out = '0% {' + tr + ': translateY(100%);visibility: visible;}100% {' + tr + ': translateY(0);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'slideinright') {
            out = '0% {' + tr + ': translateX(100%); visibility: visible;} 100% {' + tr + ': translateX(0);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'slideinleft') {
            out = '0% {' + tr + ': translateX(-100%); visibility: visible;} 100% {' + tr + ': translateX(0);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'slideindown') {
            out = '0% {' + tr + ': translateY(-100%); visibility: visible;} 100% {' + tr + ': translateY(0);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'flipiny') {
            out = '0% {' + tr + ': perspective(400px) rotate3d(0, 1, 0, 90deg); ' + timing + ': ease-in; opacity: 0;} 40% {' + tr + ': perspective(400px) rotate3d(0, 1, 0, -20deg); ' + timing + ': ease-in;} 60% {' + tr + ': perspective(400px) rotate3d(0, 1, 0, 10deg); opacity: 1;} 80% {' + tr + ': perspective(400px) rotate3d(0, 1, 0, -5deg);} 100% {' + tr + ': perspective(400px);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'flipinx') {
            out = '0% {' + tr + ': perspective(400px) rotate3d(1, 0, 0, 90deg); ' + timing + ': ease-in; opacity: 0;} 40% {' + tr + ': perspective(400px) rotate3d(1, 0, 0, -20deg); ' + timing + ': ease-in;} 60% {' + tr + ': perspective(400px) rotate3d(1, 0, 0, 10deg); opacity: 1;} 80% {' + tr + ': perspective(400px) rotate3d(1, 0, 0, -5deg);} 100% {' + tr + ': perspective(400px);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'wobble') {
            out = '0% {' + tr + ': none;} 15% {' + tr + ': translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);} 30% {' + tr + ': translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);} 45% {' + tr + ': translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);} 60% {' + tr + ': translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);} 75% {' + tr + ': translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);} 100% {' + tr + ': none;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'tada') {
            out = '0% {' + tr + ': scale3d(1, 1, 1);} 10%, 20% {' + tr + ': scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg);} 30%, 50%, 70%, 90% {' + tr + ': scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);} 40%, 60%, 80% {' + tr + ': scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);} 100% {' + tr + ': scale3d(1, 1, 1);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'swing') {
            out = '20% {' + tr + ': rotate3d(0, 0, 1, 15deg);} 40% {' + tr + ': rotate3d(0, 0, 1, -10deg);} 60% {' + tr + ': rotate3d(0, 0, 1, 5deg);} 80% {' + tr + ': rotate3d(0, 0, 1, -5deg);} 100% {' + tr + ': rotate3d(0, 0, 1, 0deg);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'shake') {
            out = '0%, 100% {' + tr + ': translate3d(0, 0, 0);} 10%, 30%, 50%, 70%, 90% {' + tr + ': translate3d(-10px, 0, 0);} 20%, 40%, 60%, 80% {' + tr + ': translate3d(10px, 0, 0);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'pulse') {
            out = '0% {' + tr + ': scale3d(1, 1, 1);} 50% {' + tr + ': scale3d(1.05, 1.05, 1.05);} 100% {' + tr + ': scale3d(1, 1, 1);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'flash') {
            out = '0%, 50%, 100% {opacity: 1;} 25%, 75% {opacity: 0;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'bounce') {
            out = '0%, 20%, 53%, 80%, 100% {' + transition_timing + ': cubic-bezier(0.215, 0.610, 0.355, 1.000); ' + tr + ': translate3d(0,0,0);} 40%, 43% {' + transition_timing + ': cubic-bezier(0.755, 0.050, 0.855, 0.060); ' + tr + ': translate3d(0, -30px, 0);} 70% {' + transition_timing + ': cubic-bezier(0.755, 0.050, 0.855, 0.060); ' + tr + ': translate3d(0, -15px, 0);} 90% {' + tr + ': translate3d(0,-4px,0);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'bounceballbottom') {
            out = '0% {' + tr + ': scale3d(1, 1, 1) translateY(0%);} 30% {' + tr + ': scale3d(1.25, 0.75, 1) translateY(12.5%);} 40% {' + tr + ': scale3d(0.75, 1.25, 1) translateY(-20.5%);} 50% {' + tr + ': scale3d(1.15, 0.85, 1) translateY(7.5%);} 65% {' + tr + ': scale3d(.95, 1.05, 1) translateY(-4.5%);} 75% {' + tr + ': scale3d(1.05, .95, 1) translateY(2.5%);} 100% {' + tr + ': scale3d(1, 1, 1) translateY(0%);}';
            out = this.getBallBottom(tr);
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'speedin') {
            out = '0% {' + tr + ': translate3d(100%, 0, 0) skewX(-30deg); opacity: 0;} 60% {' + tr + ': skewX(20deg); opacity: 1;} 80% {' + tr + ': skewX(-5deg); opacity: 1;} 100% {' + tr + ': none; opacity: 1;}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'rubber') {
            out = '0% {' + tr + ': scale3d(1, 1, 1);} 30% {' + tr + ': scale3d(1.25, 0.75, 1);} 40% {' + tr + ': scale3d(0.75, 1.25, 1);} 50% {' + tr + ': scale3d(1.15, 0.85, 1);} 65% {' + tr + ': scale3d(.95, 1.05, 1);} 75% {' + tr + ': scale3d(1.05, .95, 1);} 100% {' + tr + ': scale3d(1, 1, 1);}';
        }
        if (fullMs['SINGLE_EFFECT_LIST'] == 'flip1') {
            const px = 500;
            out = '0% {' + tr + ': perspective(' + px + 'px) rotate3d(0, 1, 0, -360deg); ' + timing + ': ease-out;} 40% {' + tr + ': perspective(' + px + 'px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg); ' + timing + ': ease-out;} 50% {' + tr + ': perspective(' + px + 'px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg); ' + timing + ': ease-in;} 80% {' + tr + ': perspective(' + px + 'px) scale3d(.95, .95, .95); ' + timing + ': ease-in;} 100% {' + tr + ': perspective(' + px + 'px); ' + timing + ': ease-in;}';
        }
        return out;
    }
	static getBallBottom(tr) {
        let out = "";
        let jumpCount = 2;
        let iz = 0;
        let iz2 = 0;
        let procDiff = 100 / (7 * jumpCount);
        let procDiffY = 40;
        let proc = 0;
        let delenie = 0;
        let delenie2 = 0;
        let diffSc = 0.4;
        let plus = 1;
        for (iz = 0; iz < jumpCount; iz++) {
            iz2 = 0;
            delenie++;
            for (iz2 = 0; iz2 < 7; iz2++) {
                delenie2++;
                if (iz === 0 && iz2 === 0) {
                    // Do nothing
                } else {
                    proc = proc + Math.round(procDiff);
                }
                plus = plus * -1;

                let s1, s2, s3, proc2;
                if (delenie2 > 1) {
                    s1 = 1 + diffSc / (delenie2 - 1) * plus;
                    proc2 = Math.round(procDiffY / (delenie2 - 1) * plus, 2);
                } else {
                    s1 = 1;
                    proc2 = 0;
                }

                if (delenie2 > 1) {
                    s2 = 1 + diffSc / (delenie2 - 1) * plus * -1;
                } else {
                    s2 = 1;
                }

                s3 = 1;
                out += `
                    ${proc}% {
                        ${tr}: scale3d(${s1.toFixed(4)}, ${s2.toFixed(4)}, ${s3.toFixed(2)}) translateY(${proc2}%);
                    }
                `;
            }
        }
        return out;
    }
}
JavaScript

Войти Регистрация
Корзина 0 позиций
на сумму 0 ₽