objs-core 2.4.0 → 2.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +17 -6
- package/objs-extension/lib/objs-inject.js +1 -1
- package/objs-extension/manifest.json +1 -1
- package/objs.built.js +1 -1
- package/objs.built.min.js +58 -58
- package/objs.d.ts +1 -1
- package/objs.global.js +5308 -0
- package/objs.global.min.js +98 -0
- package/objs.js +1 -1
- package/package.json +3 -1
package/objs.built.min.js
CHANGED
|
@@ -1,74 +1,74 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* @fileoverview Objs-core library
|
|
3
|
-
* @version 2.4.
|
|
3
|
+
* @version 2.4.1
|
|
4
4
|
* @author Roman Torshin
|
|
5
5
|
* @license Apache-2.0
|
|
6
|
-
*/const ee=!0,t=n=>{let e={els:[],ie:{},delegated:{},parented:{},store:{},refs:{},_refsByIndex:[],states:[],isDebug:!1,currentState:"",savedStates:{},isRoot:!1,_parent:null},i=1,r=2,p=3,L="boolean",x="object",C="function",_="string",D="number",R="notEmptyString",v="undefined",$="dangerouslySetInnerHTML",u,f=t.D,j=-1,O=0,I=0,m=typeof process<"u"||t.D===t.DocumentMVP,s=0,d=0;const N=e,g=o=>typeof o,y=(o,a)=>{for(const b in o)Object.hasOwn(o,b)&&a(b,o)},E=t.onError,S=o=>t.verify(o),w=(o,a="")=>(...b)=>{(t.debug||e.isDebug)&&console.log(a?`${a}()`:o,b.length?"with "+b.join(", "):"without parameters");try{const h=o(b[0],b[i],b[r],b[p]);return h!==u?h:e}catch(h){E(h,a)}},A=o=>{for(s=O;s<=j;s++)o()},B=o=>o?.els?o.el:(g(o)!==x&&(o=t.first(o).el),o),q=(o=!0,a=e.els)=>{const b=a.length;if(e.length=b,j=b-i,O=0,e.el=b?a[0]:u,e.last=b?a[j]:u,o&&(y(e.states,(h,l)=>{delete e[l[h]]}),e.states=[],e.ie={}),Array.isArray(e._refsByIndex)){const h=e._refsByIndex.length;if(h>b)y(e._refsByIndex,l=>{const c=+l;c>=b&&delete e._refsByIndex[c]}),e._refsByIndex.length=b;else if(h<b)for(let l=h;l<b;l++)e._refsByIndex[l]={}}};e.reset=t;const F=o=>{if(m||!o.querySelectorAll)return;const a=o.querySelectorAll("[data-o-init]"),b={};a.forEach(h=>{const l=h.getAttribute("data-o-init");l!==null&&(b[l]||(b[l]=[]),b[l].push(h))}),y(b,h=>{const l=t.inits[h];l&&l.getSSR(Number(h),b[h])})},P=(o,a,b)=>{y(a,h=>{let l=a[h];g(l)===C&&(l=l(b)),h==="append"&&g(l)===x&&(l.els&&(l=[l]),l[0]?.els&&(valueBuff=[],y(l,c=>{valueBuff.push(...l[c].els)}),l=valueBuff)),l!==u&&o.getAttribute(h)!==l&&!["tag","tagName","name","sample","state","events","ssr","nodeName","revertChildren","root","ref"].includes(h)&&(["html","innerHTML"].includes(h)?(o.innerHTML=l,!m&&F(o)):h==="className"?o.setAttribute("class",l):h==="dataset"&&g(l)===x?y(l,c=>{o.dataset[c]=l[c]}):h==="toggleClass"?o.classList.toggle(l):h==="addClass"?g(l)===x?o.classList.add(...l):o.classList.add(l):h==="removeClass"?o.classList.remove(l):h==="style"&&g(l)===x?y(l,c=>{o.style[c]=l[c]}):(h==="append"||h==="children"||h==="childNodes")&&g(l)===x?y(l.length?l:[l],c=>{h==="append"||!o.childNodes[c]?o.appendChild(l[c]):o.childNodes[c]!==l[c]&&o.childNodes[c].replaceWith(l[c])}):o.setAttribute(h,l))}),o.dataset.oState=a.state,t.autotag&&a.name&&(o.dataset[t.autotag]=t.camelToKebab(a.name))};e.debug=w(()=>{e.isDebug=!0},"debug ON"),e.saveAs=w(o=>{S([[o,[R]]]),t.getSaved[o]?(t.debug||e.isDebug)&&console.warn("the key exists (not saved):"+o):t.getSaved[o]=e},"saveAs"),e.unmount=()=>((t.debug||e.isDebug)&&console.log("unmount() for initID:"+e.initID),g(e.remove)===C?e.remove():e.els?.length&&e.els.forEach(o=>{o?.parentNode&&o.parentNode.removeChild(o)}),t.inits[e.initID]=void 0,e={},!0),e.init=w(o=>{S([[o,[x,C]]]);const a=e.initID||t.inits.length||0;if(e.initID=a,q(),t.inits[e.initID]=e,g(o)==="function"){e.render=w(c=>{const T=f.createElement("div");setTimeout(()=>{t.reactRender(o,T,c)}),e.add(T)});return}(g(o)!==x||o.render===u)&&(o={render:o}),y(o,c=>{e?.render&&c==="render"||(e.states.push(c),e[c]=w((T=[{}])=>{e.currentState=c;const k=o[c]||{tag:"div"},M=Array.isArray(e.els)?e.els.slice(O,j+i):[],U=M.length?M:e.els||[];g(k)===x&&(k.state=c,k["data-o-init"]=a);const z=(W,V={})=>{const X=g(k)===C?k(V):k;if(g(X)===x)return f.createElement(X.tag||X.tagName||"div");const K=f.createElement("div");return K.innerHTML=X,K.children.length>i||!K.firstElementChild?(K.dataset.oInit=W,K):(K.firstElementChild.dataset.oInit=W,K.firstElementChild)},J=T;Array.isArray(T)||(T=[T]),T.length||(T=[T]);const H=!U[0]&&c==="render";T=T.map((W,V)=>{const X=Object.assign({},g(W)===x?W:{},{self:e,o:t,i:W.i===u?V:W.i,parent:e._parent,data:Array.isArray(J)?J[V]:J});return H&&(!k.ssr||m)&&U.push(z(a,X)),X}),H&&(e.els=U,q(!1));const Y=()=>{y(k.events,W=>{e.on(W,k.events[W])})};U&&(d=U.length===T.length,U.map((W,V)=>{T[d?V:0].i=V+O;const X=g(k)===C?k(T[d?V:0]):k;g(X)===x&&(X.state=c,H&&(X["data-o-init"]=a,X["data-o-init-i"]=V,X.events&&(e._hydrateEvents=e._hydrateEvents||[],e._hydrateEvents[V]=X.events)),P(W,X,T[d?V:0]))}),H&&(e._refsByIndex=[],e.refs={},e.els.forEach((W,V)=>{if(!W.querySelectorAll)return;const X={};W.querySelectorAll("[ref]").forEach(K=>{const Q=K.getAttribute("ref"),Z=t(K);X[Q]=Z,V===0&&(e.refs[Q]=Z)}),e._refsByIndex[V]=X}),!m&&e._hydrateEvents&&(e._hydrateEvents.forEach((W,V)=>{W&&(e.select(V),y(W,X=>{const K=W[X];if(g(K)===x&&K.targetRef&&g(K.handler)===C){const Z=(e._refsByIndex?.[V]??e.refs)?.[K.targetRef];Z&&Z.on(X,K.handler)}else g(K)===C&&e.on(X,K)}))}),e.all()))),H&&g(k)===x&&k.events&&!m&&!k.ssr&&Y()}))});const b=o.render||o,h=!m&&g(b)===x&&b.events,l=!m&&e._hydrateEvents&&e._hydrateEvents.length;(h||l)&&(e.initSSRAfterGettingSSR=()=>{e._refsByIndex=[],e.refs={},e.els.forEach((c,T)=>{if(!c.querySelectorAll)return;const k={};c.querySelectorAll("[ref]").forEach(M=>{const U=M.getAttribute("ref"),z=t(M);k[U]=z,T===0&&(e.refs[U]=z),M.removeAttribute("ref")}),e._refsByIndex[T]=k,T===0&&(e.refs=k)}),h&&y(b.events,c=>{e.on(c,b.events[c])}),e._hydrateEvents&&(e._hydrateEvents.forEach((c,T)=>{c&&(e.select(T),y(c,k=>{const M=c[k];if(g(M)===x&&M.targetRef&&g(M.handler)===C){const z=(e._refsByIndex?.[T]??e.refs)?.[M.targetRef];z&&z.on(k,M.handler)}else g(M)===C&&e.on(k,M)}))}),e.all())})},"init"),e.connect=w((o,a="render",b)=>{S([[o,[x]],[a,[R]],[b,[_,v]]]),o.connect(N,a,b)},"connect"),e.getSSR=w((o,a)=>{S([[o,[D,v]]]);const b=o!==void 0?o:e.initID;if(m||g(o)===v&&g(e.initID)===v)return;const h=a&&a.length?a:t.D.querySelectorAll(`[data-o-init="${b}"]`);h.length&&(e.els=Array.from(h),o!==void 0&&(e.initID=o,t.inits[o]=e),q(!1),g(e.initSSRAfterGettingSSR)===C?e.initSSRAfterGettingSSR():a&&a.length&&(e._refsByIndex=[],e.refs={},e.els.forEach((l,c)=>{if(!l.querySelectorAll)return;const T={};l.querySelectorAll("[ref]").forEach(k=>{const M=k.getAttribute("ref");T[M]=t(k),c===0&&(e.refs[M]=T[M]),k.removeAttribute("ref")}),e._refsByIndex[c]=T,c===0&&(e.refs=T)})))},"getSSR"),e.initState=w((o,a)=>{S([[o,[x]],[a,[x,v]]]),e.init(o).render(a)},"initState");const G=(o,a,b)=>{const h=o.attributes,l={tagName:o.tagName.toLowerCase()};for(const c of h)l[c.nodeName]=c.value;if(b){l.innerHTML=o.innerHTML,l.revertChildren=[];const c=o.querySelectorAll("[data-o-init]");for(const T of c){const k=T.getAttribute("data-o-init");l.revertChildren.push(k),t.inits[k]?.saveState(a,!1)}}return l};return e.saveState=w((o,a=!0)=>{if(S([[o,[R,v]],[a,[L]]]),!e.el)throw Error("saveState(): There are no elements to save");const b=o||"fastSavedState",h={els:[],parentNode:e.el.parentNode,root:a};A(()=>{h.els.push(G(e.els[s],b,a))}),h.ie=Object.assign({},e.ie),h.delegated=Object.assign({},e.delegated),h.store=Object.assign({},e.store),e.isRoot=e.isRoot||a,e.savedStates[b]=h},"saveState"),e.revertState=w(o=>{S([[o,[R,v]]]);const a=o||"fastSavedState";if(!e.savedStates[a])throw Error(`revertState(): The state "${a}" should have been saved by saveState()`);const b=e.savedStates[a];e.offAll(),e.offDelegate(),e.store=Object.assign({},b.store),b.els.forEach((h,l)=>{if(!e.els[l]){const c=t.D.createElement(h.tagName);b.parentNode&&(l?e.els[l-1].after(c):b.parentNode.append(c)),e.add(c)}P(e.els[l],h)}),e.delegated=Object.assign({},b.delegated),e.ie=Object.assign({},b.ie),e.onAll(),y(b.delegated,h=>{b.delegated[h].forEach(l=>{A(()=>{e.els[s].addEventListener(h,l)})})}),e.currentState=a,b.root&&b.els.forEach(({rootElement:h})=>{h.revertChildren.forEach(l=>{t.inits[l]?.revertState(a),t('[data-o-init="'+l+'"]').els.forEach((c,T)=>{c.replaceWith(t.inits[l]?.els[T])})})})},"revertState"),e.loseState=w(o=>{S([[o,[R]]]),e.savedStates[o]&&(delete e.savedStates[o],A(()=>{const a=e.els[s].querySelectorAll("[data-o-init]");for(const b of a){const h=b.getAttribute("data-o-init");t.inits[h]?.loseState(o)}}))},"sample"),e.sample=w((o="render")=>(S([[o,[R]]]),{[o]:G(e.els[O])}),"sample"),e.select=w(o=>{let a=o;a!=null&&g(a)===x&&a.target&&e.els.length&&(a=e.els.findIndex(b=>b===a.target||b.contains(a.target)),a<0&&(a=0)),S([[a,[D,v]]]),a===u&&(a=e.length-i),j=a,O=a,e.el=e.els[a],I=i,Array.isArray(e._refsByIndex)&&e._refsByIndex[a]&&(e.refs=e._refsByIndex[a])},"select"),e.all=w(()=>{j=e.length-i,O=0,e.el=e.els[0],I=0,Array.isArray(e._refsByIndex)&&e._refsByIndex.length&&(e.refs=e._refsByIndex[0]||{})},"all"),e.remove=w(o=>{if(S([[o,[D,v]]]),o===u&&I&&(o=O),o!==u){const a=e.els[o];a?.parentNode?a.parentNode.removeChild(a):a===void 0&&o>=e.els.length&&t.onError&&t.onError("remove("+o+"): index out of bounds","remove")}else A(()=>{const a=e.els[s];a?.parentNode&&a.parentNode.removeChild(a)});q(!1)},"remove"),e.skip=w(o=>{S([[o,[D,v]]]),o===u&&(o=O),e.els.splice(o,i),Array.isArray(e._refsByIndex)&&e._refsByIndex.splice(o,i),q()},"skip"),e.add=w(o=>{S([[o,[_,x,D]]]),e.initID===u&&(g(o)==="string"&&o!==""?e.els.push(...Array.from(f.querySelectorAll(o))):g(o)===x?o.tagName?e.els.push(o):o.els?e.els.push(...o.els):o.length&&o[0].tagName&&e.els.push(...o):g(o)==="number"&&t.inits[o]&&(e=t.inits[o]),q(!1),e.initID!==u&&e.dataset({oInit:e.initID}))},"add"),e.appendInside=w(o=>{S([[o,[x,R]]]),o?.els&&(e._parent=o),A(()=>{B(o).appendChild(e.els[s])})},"appendInside"),e.appendBefore=w(o=>{S([[o,[x,R]]]),A(()=>{B(o).parentNode.insertBefore(e.els[s],B(o))})},"appendBefore"),e.appendAfter=w(o=>{S([[o,[x,R]]]),A(()=>{B(o).after(...e.els)})},"appendAfter"),e.find=w((o="")=>{S([[o,_]]);const a=[];return A(()=>{a.push(...Array.from(e.els[s].querySelectorAll(":scope "+o)))}),t(a)},"find"),e.first=w((o="")=>{S([[o,_]]);let a=u;const b=[];return A(()=>{a=e.els[s].querySelector(o),a&&b.push(a)}),t(b)},"first"),e.attr=w((o,a)=>{if(a!==null&&S([[o,_],[a,[_,v]]]),a===u){const b=[];return A(()=>{b[s]=e.els[s].getAttribute(o)}),I?b[0]:b}else A(a!==null?()=>{e.els[s].setAttribute(o,a)}:()=>{e.els[s].removeAttribute(o)})},"attr"),e.attrs=w(()=>{const o=[];return A(()=>{const a={};[...e.els[s].attributes].forEach(b=>{a[b.nodeName]=b.nodeValue}),o.push(a)}),I?o[0]:o},"attrs"),e.dataset=w(o=>{if(S([[o,[x,v]]]),typeof o===x)A(()=>{y(o,a=>{e.els[s].dataset[a]=o[a]})});else{const a=[];return A(()=>{a.push({...e.els[s].dataset})}),I?a[0]:a}},"dataset"),e.style=w(o=>{o!==null&&S([[o,[_,v]]]),e.attr("style",o)},"style"),e.css=w((o={})=>{if(o===null){e.style(null);return}S([[o,x]]);let a="";y(o,b=>{a+=b+":"+o[b].replace('"',"'")+";"}),e.style(a||null)},"css"),e.cssMerge=w((o={})=>{if(o===null){e.style(null);return}S([[o,x]]);const a=h=>h.indexOf("-")!==-1?h:t.camelToKebab(h),b=h=>{const l={};if(!h||typeof h!==_)return l;const c=h.split(";");for(let T=0;T<c.length;T++){const k=c[T],M=k.indexOf(":");if(M===-1)continue;const U=k.slice(0,M).trim(),z=k.slice(M+1).trim();U&&(l[U]=z)}return l};A(()=>{const h=e.els[s],l=b(h.getAttribute("style"));y(o,T=>{const k=a(T),M=o[T];M===null||M===u?delete l[k]:l[k]=String(M).replace('"',"'")});let c="";y(l,T=>{c+=T+":"+l[T]+";"}),c?h.setAttribute("style",c):h.removeAttribute("style")})},"cssMerge"),e.setClass=w(o=>{S([[o,_]]),A(()=>{e.els[s].setAttribute("class",o)})},"setClass"),e.addClass=w((...o)=>{A(()=>{e.els[s].classList.add(...o)})},"addClass"),e.removeClass=w((...o)=>{A(()=>{e.els[s].classList.remove(...o)})},"removeClass"),e.toggleClass=w((o,a)=>{S([[o,R],[a,[L,v]]]),A(()=>{e.els[s].classList.toggle(o,a)})},"toggleClass"),e.haveClass=o=>{S([[o,R]]);let a=!0;return A(()=>{e.els[s].classList.contains(o)||(a=!1)}),(e.isDebug||t.debug)&&console.log("haveClass() with",o),a},e.innerHTML=w(o=>{if(S([[o,[_,v]]]),o!==u)A(()=>{e.els[s].innerHTML=o});else{let a="";return A(()=>{a+=m&&e.els[s].innerHTML.length===0?t.D.parseElement(e.els[s],!1):e.els[s].innerHTML}),a}},"innerHTML"),e.innerText=w(o=>{S([[o,[_]]]),A(()=>{e.els[s].innerText=o})},"innerText"),e.textContent=w(o=>{S([[o,[_]]]),A(()=>{e.els[s].textContent=o})},"textContent"),e.html=w(o=>{if(S([[o,[_,v]]]),o!==void 0)e.innerHTML(o);else{let a="";return A(()=>{a+=m?e.els[s].outerHTML():e.els[s].outerHTML}),a}},"html"),e.toString=function(){return e.html()},e[Symbol.toPrimitive]=function(o){return o==="string"||o==="default"?e.html():o==="number"?e.els?.length??0:e.html()},e.val=w(o=>{if(o===void 0)return e.el?.value;A(()=>{e.els[s].value=o})},"val"),e.forEach=w(o=>{S([[o,[C]]]),A(()=>{o({self:e,i:s,o:t,el:e.els[s]})})},"forEach"),e.prepareFor=w((o,a)=>{S([[o,[x,C,v]],[a,[C,v]]]);const b=o&&g(o)===x&&o.createElement;if(!b&&g(o)!==C)throw Error("prepareFor(): pass React (full object) or React.createElement as first argument");const h=b?o.createElement:o,l=b?o.useEffect:void 0;return c=>{if(c.ref===u)throw Error("No ref property to convert Objs to React");const T=Object.assign({},c),k=h("div",{ref:c.ref});return delete T.ref,l(()=>{y(T,M=>{if(M.substring(0,1)==="on"){const U=t.camelToKebab(M).split("-")[1];e.on(U,T[M]),delete T[M]}}),e.render(T),e.appendInside(k.ref.current)},[]),k}},"prepareFor"),e.on=w((o,a,b,h)=>{S([[o,[R]],[a,[C]],[b,[x,v]],[h,[L,v]]]),o.split(", ").forEach(l=>{A(()=>{e.els[s].addEventListener(l,a,b,h)}),e.ie[l]||(e.ie[l]=[]),e.ie[l].push([a,b,h])})},"on"),e.off=w((o,a,b)=>{S([[o,[R]],[a,[C]],[b,[x,v]]]),o.split(", ").forEach(h=>{A(()=>{e.els[s].removeEventListener(h,a,b)}),e.ie[h]&&(e.ie[h]=e.ie[h].filter(l=>l[0]!==a))})},"off"),e.onDelegate=w((o,a,b)=>{S([[o,[R]],[a,[R]],[b,[C]]]),o.split(", ").forEach(h=>{const l=c=>{const T=c.target.closest(a);T&&(c.delegate=T,c.objs=e,b(c))};A(()=>{e.els[s].addEventListener(h,l)}),e.delegated[h]||(e.delegated[h]=[]),e.delegated[h].push(l)})},"onDelegate"),e.offDelegate=w(o=>{S([[o,[R]]]),y(e.delegated,a=>{if(!o||o===a)for(;e.delegated[a].length;){const b=e.delegated[a].pop();A(()=>{e.els[s].removeEventListener(a,b)})}}),e.delegated={}},"offDelegate"),e.onParent=w((o,a,b)=>{S([[o,[R]],[a,[R,x]],[b,[C]]]);const h=g(a)===x?a:t.D.querySelector(a);o.split(", ").forEach(l=>{const c=T=>{T.objs=e,b(T)};h.addEventListener(l,c),e.parented[l]||(e.parented[l]=[]),e.parented[l].push(c)})},"onParent"),e.offParent=w((o,a)=>{S([[o,[R]],[a,[R,x]]]);const b=g(a)===x?a:t.D.querySelector(a);y(e.parented,h=>{(!o||o===h)&&(e.parented[h].forEach(l=>{b.removeEventListener(h,l)}),delete e.parented[h])})},"offParent"),e.onAll=w((o,a)=>{S([[o,[R,v]],[a,[L,v]]]),y(e.ie,(b,h)=>{(!o||o===b)&&h[b].forEach(l=>{A(()=>{a?e.els[s].removeEventListener(b,l[0]):e.els[s].addEventListener(b,l[0],l[i],l[r])})})})},"onAll"),e.offAll=w(o=>{S([[o,[R]]]),e.onAll(o,i)},"offAll"),n&&e.add(n),e.take=o=>{if(S([[o,[_,x,D]]]),e.add(o),e.el){const a=e.el.dataset.oInit;if(a!==u&&t.inits[a])return e.length===i?(d=e.els[0],Object.assign(e,t.inits[a]),e.els=[d]):e=t.inits[a],q(!1,e.els),e}},e};t.first=n=>(t.verify([[n,["notEmptyString"]]]),t.debug&&console.log(n," -> ","o.first()"),t(t.D.querySelector(n)).select(0)),t.inits=[],t.getSaved={},t.errors=[],t.showErrors=!1,t.logErrors=()=>{t.errors.length?t.errors.forEach(n=>console.error(n)):console.log("No errors")},t.onError=(n,e)=>{t.showErrors?console.error(n,e):(t.errors.push(n),e&&t.errors.push(e))},t.reactRender=()=>new Error("React render function is not defined"),t.autotag=void 0,t.reactQA=n=>({["data-"+(t.autotag||"qa")]:n.replace(/([A-Z])/g,(e,i)=>"-"+i.toLowerCase()).replace(/^-/,"")}),t.specialTypes={notEmptyString:(n,e)=>e==="string"&&n.length,array:n=>Array.isArray(n),promise:n=>n instanceof Promise||!!(n&&typeof n.then=="function")},t.verify=(n,e=!1)=>{for(const i of n){const r=typeof i[0];let p=Array.isArray(i[1])?i[1]:[i[1]],L=!1;if(p.includes(r))return!0;p=p.filter(x=>!!t.specialTypes[x]);for(const x of p)if(L=t.specialTypes[x](i[0],r),L)return!0}return e?!1:new Error("Type verification failed")},t.safeVerify=n=>t.verify(n,!0),t.init=(n,e)=>t().init(n,e),t.initState=(n,e)=>t().init(n).render(e),t.take=n=>t().take(n),t.getStates=()=>t.inits.reduce((n,e)=>(n.push(e?.states),n),[]),t.getStores=()=>t.inits.reduce((n,e)=>(n.push(e?.store),n),[]),t.getListeners=()=>t.inits.reduce((n,e)=>(n.push(e?.ie),n),[]),t.createStore=n=>{const e=Object.assign({},n);return e._defaults=Object.assign({},n),e._listeners=[],e.subscribe=function(i,r){return this._listeners.push(p=>i[r]?.(p)),this},e.notify=function(){this._listeners.forEach(i=>i(this))},e.reset=function(){const i={_listeners:1,subscribe:1,notify:1,_defaults:1,reset:1};for(const r of Object.keys(this._defaults))i[r]||(this[r]=this._defaults[r])},e},t.U=void 0,t.W=2,t.H=100,t.F=!1,t.C=(n,e)=>Object.hasOwn(n,e),t.kebabToCamel=n=>n.replace(/-./g,e=>e.toUpperCase()[1]),t.camelToKebab=n=>n.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase(),t.route=(n,e)=>{t.verify([[n,["notEmptyString","function","boolean"]],[e,["function","object"]]]);const i=typeof n=="function"?n(window.location.pathname):n;return i===!0||window.location.pathname===i?e?typeof e=="function"?(e(),!0):e:t:typeof e=="function"?!1:{}},t.router=(n={})=>{t.verify([[n,["object"]]]);for(const e in n)if(t.C(n,e)&&window.location.pathname===e)return typeof n[e]=="function"?(n[e](),!0):n[e];return!1},t.DocumentMVP={addEventListener:()=>{},parseElement:(n,e=!0)=>{t.verify([[n,["object","string"]],[e,["boolean"]]]);const i=(r,p="")=>{let L="";for(const x in r)t.C(r,x)&&(L+=` ${p}${t.camelToKebab(x)}="${typeof r[x]!="object"?r[x]:Object.entries(r[x]).map(C=>`${C[0]}: ${C[1]};`).join(" ")}"`);return L};if(typeof n=="string")return n;if(e){const r=["area","base","br","col","embed","hr","img","input","link","meta","param","source","track","wbr"],p=n.tagName.toLowerCase(),L=n.attributes["data-o-init"],x=L!==void 0?` data-o-init="${L}"`:"";return`<${p}${n.className?` class="${n.className}"`:""}${i(n.attributes)}${x}${i(n.dataset,"data-")}${r.includes(p)?"/":""}>${r.includes(p)?"":n.innerHTML.length?n.innerHTML:n.children.map(C=>t.D.parseElement(C)).join("")}${r.includes(p)?"":`</${p}>`}`}return n.innerHTML.length?n.innerHTML:n.children.map(r=>t.D.parseElement(r)).join("")},createElement:n=>{t.verify([[n,["notEmptyString"]]]);const e={tagName:n.toUpperCase(),attributes:{},innerHTML:"",children:[],dataset:{},className:"",classArray:[],style:{},addEventListener:()=>{},removeEventListener:()=>{}};return e.classList={add:(...i)=>{t.verify([[i,["array"]]]),e.classArray.push(i),e.className=e.classArray.join(" ")},has:i=>(t.verify([[i,["notEmptyString"]]]),e.classArray.includes(i)),remove:i=>{t.verify([[i,["notEmptyString"]]]),e.classArray=e.classArray.filter(r=>i!==r),e.className=e.classArray.join(" ")}},e.classList.toggle=i=>{t.verify([[i,["notEmptyString"]]]),e.classList.has(i)?e.classList.remove(i):e.classList.add(i)},e.setAttribute=(i,r)=>{t.verify([[i,["notEmptyString"]],[r,["string","number","boolean","undefined"]]]),e.attributes[i]=r},e.getAttribute=i=>(t.verify([[i,["notEmptyString"]]]),e.attributes[i]),e.removeAttribute=i=>{t.verify([[i,["notEmptyString"]]]),delete e.attributes[i]},e.appendChild=i=>{t.verify([[i,["object"]]]),e.children.push(i),e.firstElementChild=e.children[0]},e.outerHTML=()=>t.D.parseElement(e),e}},t.D=typeof document<"u"&&typeof process>"u"?document:t.DocumentMVP,t.setCookie=(n,e="",i={})=>{if(t.verify([[n,["notEmptyString"]],[e,["string","number","boolean"]],[i,["object"]]]),t.D.cookie===void 0){console.log("Cookies are not supported on server side");return}let r=encodeURIComponent(n)+"="+encodeURIComponent(e);i={path:"/",...i},i.expires instanceof Date?i.expires=i.expires.toUTCString():typeof i.expires=="number"&&(i.expires=new Date(i.expires).toUTCString());for(const p in i){r+="; "+p;const L=i[p];L!==!0&&(r+="="+L)}t.D.cookie=r},t.getCookie=n=>{if(t.verify([[n,["notEmptyString"]]]),t.D.cookie===void 0){console.log("Cookies are not supported on server side");return}const e=t.D.cookie.match(RegExp("(?:^|; )"+n.replace(/([.$?*|{}()[\]\\/+^])/g,"\\$1")+"=([^;]*)"));return e?decodeURIComponent(e[1]):void 0},t.deleteCookie=n=>{t.verify([[n,["notEmptyString"]]]),t.setCookie(n,"",{"max-age":0})},t.clearCookies=()=>{if(t.D.cookie===void 0){console.log("Cookies are not supported on server side");return}const n=t.D.cookie.split(";");for(;n.length;){let e=n.pop();for(;e.charAt(0)===" ";)e=e.substring(1);const i=e.split("=")[0];t.deleteCookie(i)}},t.clearLocalStorage=n=>{if(t.verify([[n,["boolean","undefined"]]]),!(typeof localStorage>"u"))if(n)localStorage.clear();else for(let e=localStorage.length-1;e>=0;e--){const i=localStorage.key(e);i.indexOf("oInc-")===-1&&i.indexOf("oTest-")===-1&&localStorage.removeItem(i)}},t.clearSessionStorage=n=>{if(t.verify([[n,["boolean","undefined"]]]),!(typeof sessionStorage>"u"))if(!n)sessionStorage.clear();else for(let e=sessionStorage.length-1;e>=0;e--){const i=sessionStorage.key(e);i&&i.indexOf("oTest-")===0&&sessionStorage.removeItem(i)}},t.clearTestsStorage=()=>{t.clearSessionStorage(1)},t.clearAfterTests=()=>{t.clearCookies(),t.clearLocalStorage(!1),t.clearTestsStorage()},t.ajax=(n,e={})=>{t.verify([[n,["notEmptyString"]],[e,["object"]]]);const i=new URLSearchParams;if(e.data&&typeof e.data=="object"){for(const r in e.data)t.C(e.data,r)&&(typeof e.data[r]=="object"?i.set(r,encodeURIComponent(JSON.stringify(e.data[r]))):i.set(r,e.data[r]));e.method.toLowerCase()==="get"?n+="?"+i.toString():e.body||(e.body=i),delete e.data}return e.headers||(e.headers={"X-Requested-With":"XMLHttpRequest"}),fetch(n,e)},t.get=(n,e={})=>(t.verify([[n,["notEmptyString"]],[e,["object"]]]),t.ajax(n,{...e,method:"GET"})),t.post=(n,e={})=>(t.verify([[n,["notEmptyString"]],[e,["object"]]]),t.ajax(n,{...e,method:"POST"})),t.newLoader=n=>{t.verify([[n,["promise","undefined"]]]);let e=[],i=null,r=!1,p=!1;const L=x=>{r=!1,p=!1,i=null,setTimeout(()=>{x.then(C=>{r=!0,!C.ok&&typeof C.ok<"u"?(p=!0,e.forEach(([_,D,R])=>{R&&_[R](C)})):typeof C.json=="function"?C.json().then(_=>{i=_,e.forEach(([D,R])=>{D[R](i)})}):(i=C,e.forEach(([_,D])=>{_[D](i)}))}).catch(C=>{p=!0,e.forEach(([_,D,R])=>{R&&_[R](C)})})},33)};return n&&L(n),{reload:L,isObjsLoader:!0,listeners:e,isFinished:()=>r,getStore:()=>i,connect:(x,C="render",_)=>{t.verify([[x,["object"]],[C,["notEmptyString"]],[_,["string","undefined"]]]),r?p?_&&x[_]():typeof x[C]=="function"&&x[C](i):e.push([x,C,_])},disconnect:x=>{t.verify([[x,["object"]]]),e=e.filter(([C])=>C!==x)}}},t.getParams=n=>{t.verify([[n,["string","undefined"]]]);const e={},i=new URLSearchParams(window.location.search).entries();for(const r of i)e[r[0]]=r[1];return n?e[n]:e},t.incCache=!0,t.incCacheExp=1e3*60*60*24,t.incTimeout=6e3,t.incSource="",t.incForce=t.F,t.incAsync=!0,t.incCors=t.F,t.incSeparator="?",t.incFns={},t.incSet=[0],t.incReady=[0],t.incN=0,t.incGetHash=n=>n.split(t.incSeparator)[1]||"",t.incCheck=(n=0,e,i=0)=>(t.verify([[n,["number"]],[e,["number","undefined"]],[i,["number"]]]),!i&&n&&e===t.U&&t.incReady[n]?t.incSet[n]===1:t.incReady[n]===t.U||t.incReady[n][e]===t.U?t.F:(t.incReady[n][e].loaded=i,t.incFns[t.incReady[n][e].name]=i,t.incReady[n][0]+=i,n&&t.incReady[n].length===t.incReady[n][0]&&(typeof t.incSet[n]=="function"&&t.incSet[n](n),t.incSet[n]=1),t.incSet[n]===1)),t.incCacheClear=(n=t.F)=>{t.verify([[n,["boolean"]]]);for(const e in t.incFns)t.C(t.incFns,e)&&(localStorage.removeItem("oInc-"+e),localStorage.removeItem("oInc-"+e+"-expires"));return n&&(t.incReady.forEach((e,i)=>{i&&e.forEach((r,p)=>{p&&t("#oInc-"+i+"-"+p).remove()})}),t.incN=0,t.incFns={},t.incSet=[0],t.incReady=[0]),!0},t.inc=(n,e,i)=>{if(t.verify([[n,["object","undefined"]],[e,["function","undefined"]],[i,["function","undefined"]]]),typeof localStorage>"u")return;let r=0,p=0,L="",x=!1;const C="function",_=-1;if(typeof n!="object"||!n)return t.incSet[0];t.incSet[0]++;const D=t.incSet[0];t.incSet[D]=e||0,t.incReady[D]=[];const R=t.incReady[D];R[0]=1;const v={};for(const $ in n)if(t.C(n,$)){if($==="preload"){x=!0;continue}L=t.incGetHash(n[$]),r++,t.incN++;const u=n[$].indexOf(".css")>_?"style":"script";if(n[$]=(t.incSource?t.incSource+"/":"")+n[$],Number.isNaN(Number($))&&t.C(t.incFns,$)&&t.incFns[$]&&!t.incForce){R[r]={name:$,loaded:1},p++;continue}if(R[r]={name:$,loaded:0},Number.isNaN(Number($))&&(t.incFns[$]=0),Number.isNaN(Number($))&&t.incCache&&(n[$].substring(0,4)!=="http"||!t.incCors)&&window.location.protocol!=="file:"&&(n[$].indexOf(".css")>_||n[$].indexOf(".js")>_)){const f=localStorage,j=f.getItem("oInc-"+$),O=f.getItem("oInc-"+$+"-expires"),I=f.getItem("oInc-"+$+"-hash");j&&O&&Date.now()<O&&I===L?(x||t.initState({tag:u,id:"oInc-"+D+"-"+r,innerHTML:j,"data-o-inc":D}).appendInside("head"),R[r].loaded=1,t.incFns[$]=1,p++):(v[$]=r,t.get(n[$],{mode:t.incCors?"cors":"same-origin"}).then(m=>{if(m.status!==200){t.onError&&t.onError({message:t.incSource+n[$]+" was not loaded"});return}m.text().then(s=>{f.setItem("oInc-"+$,s),f.setItem("oInc-"+$+"-expires",Date.now()+t.incCacheExp),f.setItem("oInc-"+$+"-hash",L),x||t.initState({tag:u,id:"oInc-"+D+"-"+v[$],innerHTML:s,"data-o-inc":D}).appendInside("head"),t.incCheck(D,v[$],1)})}))}else{const f={tag:u,id:"oInc-"+D+"-"+r,"data-o-inc":D,async:t.incAsync,onload:"o.incCheck("+D+","+r+",1)"};n[$].indexOf(".css")>_?(f.tag="link",f.rel="stylesheet",f.href=n[$]):(n[$].indexOf(".js")>_||(f.tag="img",f.style="display:none;"),f.src=n[$]),t.initState(f).appendInside(f.style?"body":"head")}}return R[0]+=p,r!==0&&(p===r?typeof e===C&&e(D):setTimeout($=>{t.incReady[$]&&t.incReady[$].length<t.incReady[$][0]&&(t.incSet[$]=0,typeof i===C&&i(D))},t.incTimeout,D)),t.incSet[0]},t.connectRedux=(n,e,i,r="render")=>{t.verify([[n,["object"]],[e,["function"]],[i,["object"]],[r,["notEmptyString"]]]);const p=()=>{if(typeof i[r]=="function"){const L=e(n.getState());i[r](L!==null&&typeof L=="object"?L:{value:L})}};return p(),n.subscribe(p)},t.connectMobX=(n,e,i,r,p="render")=>(t.verify([[n,["object"]],[e,["object"]],[i,["function"]],[r,["object"]],[p,["notEmptyString"]]]),n.autorun(()=>{if(typeof r[p]=="function"){const L=i(e);r[p](L!==null&&typeof L=="object"?L:{value:L})}})),t.ObjsContext=null,t.withReactContext=(n,e,i,r,p="render")=>function(){const x=n.useContext(e);return n.useEffect(()=>{if(typeof r[p]=="function"){const C=i(x);r[p](C!==null&&typeof C=="object"?C:{value:C})}},[x]),null},t.debug=!1,t.sleep=n=>new Promise(e=>setTimeout(e,n)),t.tLog=[],t.tRes=[],t.tStatus=[],t.tFns=[],t.tShowOk=t.F,t.tStyled=t.F,t.tTime=2e3,t.tests=[],t.tExpectedSteps={},t.tFinalized={},t.tAutolog=t.F,t.tBeforeEach=void 0,t.tAfterEach=void 0,t.addTest=(n,...e)=>{t.verify([[n,["notEmptyString"]],[e,["array"]]]);let i={};e.length&&typeof e[e.length-1]=="object"&&!Array.isArray(e[e.length-1])&&(i=e.pop());const r=t.tests.length;return t.tests[r]={title:n,tests:e,hooks:i},{run:()=>{typeof i.before=="function"&&(t.tBeforeEach=i.before),typeof i.after=="function"&&(t.tAfterEach=i.after),t.runTest(r)},autorun:()=>{typeof i.before=="function"&&(t.tBeforeEach=i.before),typeof i.after=="function"&&(t.tAfterEach=i.after),t.runTest(r,!0)},testId:r}},t.updateLogs=()=>{for(let n=0;n<t.tests.length;n++)t.tLog[n]=t.tLog[testN]=sessionStorage.getItem(`oTest-Log-${testN}`)||"";return t.tLog},t.runTest=(n=0,e,i)=>{if(t.verify([[n,["number"]],[e,["boolean","undefined"]],[i,["boolean","undefined"]]]),!t.tests[n])return;i||(sessionStorage?.removeItem(`oTest-Log-${n}`),sessionStorage?.removeItem(`oTest-Res-${n}`),sessionStorage?.removeItem(`oTest-Status-${n}`)),sessionStorage?.setItem("oTest-Run",n),e?sessionStorage?.setItem("oTest-Autorun",e):sessionStorage?.removeItem("oTest-Autorun");const r=t.tests[n];let p=r.tests.pop();typeof p!="function"&&(r.tests.push(p),p=()=>{}),r.tests.push(L=>{p(L),sessionStorage.setItem("dddd",1),sessionStorage?.removeItem("oTest-Run"),e&&t.runTest(n+1,e)}),t.test(r.title,...r.tests)},t.tPre='<div style="font-family:monospace;text-align:left;">',t.tOk='<span style="background:#cfc;padding: 0 15px;">OK</span> ',t.tXx='<div style="background:#fcc;padding:3px;">',t.tDc="</div>",t.test=(n="",...e)=>{t.verify([[n,["notEmptyString"]],[e,["array"]]]);const i=sessionStorage?.getItem("oTest-Run"),r=i||t.tLog.length;let p=0,L="\u251C OK: ",x="\u251C \u2718 ",C=`
|
|
7
|
-
`,
|
|
8
|
-
`,
|
|
9
|
-
`,
|
|
10
|
-
`;return}
|
|
11
|
-
`,
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
`):(
|
|
15
|
-
`);let
|
|
16
|
-
`,typeof t.tFns[p]=="function"&&t.tFns[p](p)}},sessionStorage?.getItem("oTest-Run")&&window?.addEventListener("load",()=>{t.runTest(sessionStorage?.getItem("oTest-Run"),sessionStorage?.getItem("oTest-Autorun")||t.F,!0)},!1),t.measure=n=>{if(!n)return{};const e=n.getBoundingClientRect(),i=window.getComputedStyle(n);return{width:e.width,height:e.height,top:e.top,left:e.left,visible:i.display!=="none"&&i.visibility!=="hidden"&&e.width>0,opacity:i.opacity,zIndex:i.zIndex}},t.assertVisible=n=>!!t.measure(n).visible,t.assertSize=(n,e={})=>{if(!n)return"element is null";const i=t.measure(n);if(e.w!==void 0&&Math.round(i.width)!==e.w)return`width: expected ${e.w}, got ${Math.round(i.width)}`;if(e.h!==void 0&&Math.round(i.height)!==e.h)return`height: expected ${e.h}, got ${Math.round(i.height)}`;const r=p=>{const L=window.getComputedStyle(n).getPropertyValue(p);return L?parseFloat(L):0};return e.padding!==void 0&&r("padding-top")!==e.padding?`padding: expected ${e.padding}, got ${r("padding-top")}`:e.paddingTop!==void 0&&r("padding-top")!==e.paddingTop?`paddingTop: expected ${e.paddingTop}, got ${r("padding-top")}`:e.paddingRight!==void 0&&r("padding-right")!==e.paddingRight?`paddingRight: expected ${e.paddingRight}, got ${r("padding-right")}`:e.paddingBottom!==void 0&&r("padding-bottom")!==e.paddingBottom?`paddingBottom: expected ${e.paddingBottom}, got ${r("padding-bottom")}`:e.paddingLeft!==void 0&&r("padding-left")!==e.paddingLeft?`paddingLeft: expected ${e.paddingLeft}, got ${r("padding-left")}`:e.margin!==void 0&&r("margin-top")!==e.margin?`margin: expected ${e.margin}, got ${r("margin-top")}`:e.marginTop!==void 0&&r("margin-top")!==e.marginTop?`marginTop: expected ${e.marginTop}, got ${r("margin-top")}`:e.marginRight!==void 0&&r("margin-right")!==e.marginRight?`marginRight: expected ${e.marginRight}, got ${r("margin-right")}`:e.marginBottom!==void 0&&r("margin-bottom")!==e.marginBottom?`marginBottom: expected ${e.marginBottom}, got ${r("margin-bottom")}`:e.marginLeft!==void 0&&r("margin-left")!==e.marginLeft?`marginLeft: expected ${e.marginLeft}, got ${r("margin-left")}`:!0},t.recorder={active:!1,actions:[],mocks:{},initialData:{},assertions:[],observeRoot:null,strictCapture:null,_originalFetch:null,_listeners:[],_observer:null},t.recordingAssertionDebug=!1,t.startRecording=(n,e,i)=>{if(t.recorder.active)return;let r,p,L,x=null;if(n!=null&&typeof n=="object"&&!Array.isArray(n)&&(t.C(n,"observe")||t.C(n,"events")||t.C(n,"timeouts")||t.C(n,"strictCaptureAssertions")||t.C(n,"strictCaptureNetwork")||t.C(n,"strictCaptureWebSocket"))){const s=n;r=s.observe!=null?String(s.observe):void 0,p=s.events,L=s.timeouts,(t.C(s,"strictCaptureAssertions")||t.C(s,"strictCaptureNetwork")||t.C(s,"strictCaptureWebSocket"))&&(x={assertions:!!s.strictCaptureAssertions,network:!!s.strictCaptureNetwork,websocket:!!s.strictCaptureWebSocket})}else r=typeof n=="string"?n:void 0,p=e,L=i;const _=["click","mouseover","scroll","input","change","submit","keydown","focus","blur"],D={click:100,mouseover:50,scroll:30,input:50,change:50,submit:100,keydown:50,focus:50,blur:50},R=p||_,v=Object.assign({},D,L||{}),$={scroll:30,mouseover:50,keydown:50,focus:50,blur:50},u=t.recorder;u.active=!0,u.actions=[],u.mocks={},u.stepDelays=v,u.initialData={url:window.location.href,timestamp:Date.now()},u.strictCapture=x,u.observeRoot=r||null,u.assertions=[],u.removedElements=[],t.inits.forEach((s,d)=>{s?.store&&(u.initialData["init_"+d]=JSON.parse(JSON.stringify(s.store)))}),u._originalFetch=window.fetch,window.fetch=async(s,d={})=>{const N=(d.method||"GET").toUpperCase();let g;try{g=d.body?JSON.parse(d.body):void 0}catch{g=d.body}const y=await u._originalFetch(s,d),E=y.clone();let S;try{S=await E.json()}catch{S=await E.text().catch(()=>null)}const w=N+":"+s;return u.mocks[w]={url:s,method:N,request:g,response:S,status:y.status},y},u._originalXHROpen=XMLHttpRequest.prototype.open,u._originalXHRSend=XMLHttpRequest.prototype.send,XMLHttpRequest.prototype.open=function(s,d){return this._oMethod=(s||"GET").toUpperCase(),this._oUrl=d,u._originalXHROpen.apply(this,arguments)},XMLHttpRequest.prototype.send=function(s){const d=()=>{if(this.readyState!==4)return;let N;try{N=s?JSON.parse(s):void 0}catch{N=s}let g;try{const E=this.responseText;g=E?JSON.parse(E):null}catch{g=this.responseText??null}const y=(this._oMethod||"GET")+":"+(this._oUrl||"");u.mocks[y]={url:this._oUrl,method:this._oMethod,request:N,response:g,status:this.status}};return this.addEventListener("readystatechange",d),u._originalXHRSend.apply(this,arguments)},u.websocketEvents=[],u._originalWebSocket=window.WebSocket,window.WebSocket=function(s,d){const N=new u._originalWebSocket(s,d),g=u.websocketEvents.length;u.websocketEvents.push({url:typeof s=="string"?s:String(s),protocol:Array.isArray(d)?d[0]:d,open:!0,messages:[]}),N.addEventListener("message",E=>{const S=typeof E.data=="string"?E.data:String(E.data);u.websocketEvents[g].messages.push({dir:"in",data:S})}),N.addEventListener("close",()=>{u.websocketEvents[g].open=!1});const y=N.send.bind(N);return N.send=function(E){const S=typeof E=="string"?E:String(E);return u.websocketEvents[g].messages.push({dir:"out",data:S}),y(E)},N};const f={"data-o-init":1,"data-o-init-i":1,"data-o-state":1},j=(s,d)=>{if(t.D.querySelectorAll(s).length<=1)return s;let N=d;for(;N&&N!==t.D.body;){let g=N.id?"#"+N.id:null;if(!g&&N.attributes){const y=t.autotag?"data-"+t.autotag:null;if(y){const E=N.getAttribute(y);E!=null&&(g=`[${y}="${E}"]`)}if(!g){for(const E of N.attributes)if(E.name.startsWith("data-")&&!f[E.name]){g=`[${E.name}="${E.value}"]`;break}}}if(g){const y=g+" "+s;if(t.D.querySelectorAll(y).length===1)return y}N=N.parentElement}return s},O=s=>{if(!s||s.nodeType!==1)return"";let d="";if(s.dataset){const N=t.autotag&&s.dataset[t.autotag];N&&(d=j(`[data-${t.autotag}="${N}"]`,s.parentElement))}if(!d&&s.tagName){const N=s.id?"#"+s.id:s.className?s.tagName.toLowerCase()+"."+[...s.classList].join("."):s.tagName.toLowerCase();d=s.id?N:j(N,s.parentElement)}return d},I=r&&t.D.querySelector(r)||t.D.body;u._observer=new MutationObserver(s=>{const d=u.actions.length-1;if(d<0)return;const N=u.actions[d];t.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[recording] MutationObserver batch:",{actionIdx:d,lastAction:N?{type:N.type,target:N.target}:null,mutationTypes:s.map(g=>g.type),addedCount:s.reduce((g,y)=>g+(y.addedNodes?.length||0),0),removedCount:s.reduce((g,y)=>g+(y.removedNodes?.length||0),0)}),s.forEach(g=>{const y=(E,S)=>{let w,A;if(E&&I){const B=I.querySelectorAll(E);if(B.length>1){const q=[...B].indexOf(S);if(q!==-1)w=E,A=q;else{let F=S;for(;F&&F!==I&&F.nodeType===1;){const P=t.autotag&&F.dataset&&F.dataset[t.autotag];if(P){const G=`[data-${t.autotag}="${P}"]`,o=I.querySelectorAll(G);if(o.length>1){const a=[...o].indexOf(F);if(a!==-1){w=G,A=a;break}}}F=F.parentElement}}}}return{listSelector:w,index:A}};if(g.type==="childList"&&(g.addedNodes.forEach(E=>{if(E.nodeType!==1||!E.offsetParent)return;const S=O(E);if(!S||u.assertions.some(F=>F.actionIdx===d&&F.selector===S&&F.type==="visible"))return;const w=(E.textContent?.trim()||"").slice(0,80)||void 0,{listSelector:A,index:B}=y(S,E),q={actionIdx:d,type:"visible",selector:S,text:w};A!=null&&(q.listSelector=A),B!=null&&(q.index=B),u.assertions.push(q),t.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[recording] +visible assertion:",{actionIdx:d,lastAction:N?.type+" "+N?.target,selector:S,text:(w||"").slice(0,40),index:B,listSelector:A})}),g.removedNodes.forEach(E=>{if(E.nodeType!==1)return;const S=O(E);if(!S)return;const w=(E.textContent?.trim()||"").slice(0,80)||void 0,A=g.target;let B;E.previousSibling?B=Array.from(A.children).indexOf(E.previousSibling)+1:E.nextSibling?B=Array.from(A.children).indexOf(E.nextSibling):B=0;let q;if(t.autotag&&E.dataset?.[t.autotag]){const P=E.dataset[t.autotag];q=`[data-${t.autotag}="${P}"]`}const F={actionIdx:d,type:"removed",selector:S,text:w};q&&(F.listSelector=q),F.index=B,u.removedElements.push(F),t.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[recording] +removed element:",{actionIdx:d,lastAction:N?.type+" "+N?.target,selector:S,text:(w||"").slice(0,40),index:B,listSelector:q})})),g.type==="attributes"){const E=g.attributeName;if(!E)return;const S=O(g.target);if(!S)return;const A={class:"class",style:"style",hidden:"hidden",disabled:"disabled","aria-expanded":"aria-expanded","aria-checked":"aria-checked"}[E];if(!A||u.assertions.some(o=>o.actionIdx===d&&o.selector===S&&o.type===A))return;const{listSelector:B,index:q}=y(S,g.target),F=g.target;let P;A==="class"?P=F.className:A==="style"?P=F.style?.cssText||F.getAttribute("style")||"":A==="hidden"?P=F.hidden:A==="disabled"?P=F.disabled===!0:A==="aria-expanded"?P=F.getAttribute("aria-expanded"):A==="aria-checked"&&(P=F.getAttribute("aria-checked"));const G={actionIdx:d,type:A,selector:S};A==="class"?G.className=P:A==="style"?G.style=P:A==="hidden"?G.hidden=P:A==="disabled"?G.disabled=P:A==="aria-expanded"?G.ariaExpanded=P:A==="aria-checked"&&(G.ariaChecked=P),B!=null&&(G.listSelector=B),q!=null&&(G.index=q),u.assertions.push(G),t.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[recording] +attr assertion:",{actionIdx:d,lastAction:N?.type+" "+N?.target,selector:S,type:A,value:P,index:q,listSelector:B})}})}),u._observer.observe(I,{childList:!0,subtree:!0,attributes:!0,attributeFilter:["class","style","hidden","disabled","aria-expanded","aria-checked"]});const m={};R.forEach(s=>{const d=N=>{const g=N.target;if(r&&I&&g?.nodeType===1&&!I.contains(g))return;let y="";if(g?.dataset){const a=t.autotag&&g.dataset[t.autotag];a&&(y=j(`[data-${t.autotag}="${a}"]`,g.parentElement))}if(!y&&g?.tagName){const a=g.id?"#"+g.id:g.className?g.tagName.toLowerCase()+"."+[...g.classList].join("."):g.tagName.toLowerCase();y=g.id?a:j(a,g.parentElement)}let E,S;if(y&&I){const a=I.querySelectorAll(y);if(a.length>1){const b=[...a].indexOf(g);if(b!==-1)E=y,S=b;else{let h=g;for(;h&&h!==I&&h.nodeType===1;){const l=t.autotag&&h.dataset&&h.dataset[t.autotag];if(l){const c=`[data-${t.autotag}="${l}"]`,T=I.querySelectorAll(c);if(T.length>1){const k=[...T].indexOf(h);if(k!==-1){E=c,S=k;break}}}h=h.parentElement}}}}const w=g?.tagName?g.tagName.toLowerCase()+(g.type?":"+g.type:""):void 0,A=s==="scroll"?window.scrollY:void 0,B=s==="input"||s==="change"?g?.value:void 0,q=s==="change"&&(g?.type==="checkbox"||g?.type==="radio")?g?.checked:void 0,F=s==="keydown"?g?.key:void 0,P=s==="keydown"?g?.code:void 0,G=s==="click"||s==="change"||s==="submit"?0:v[s]!==void 0?v[s]:$[s]??0,o=()=>{if((s==="blur"||s==="focus")&&y){const b=u.actions.length-1,h=b>=0?u.actions[b]:null;if(h){if(h.target===y&&h.listSelector==null==(E==null)&&h.targetIndex==null==(S==null)&&(h.targetIndex==null||h.targetIndex===S))return;for(const c of u.removedElements)if(c.actionIdx===b&&(c.selector===y||y.startsWith(c.selector+" ")||y.startsWith(c.selector+">")))return}}const a={type:s,target:y,time:Date.now()};w&&(a.targetType=w),A!==void 0&&(a.scrollY=A),B!==void 0&&(a.value=B),q!==void 0&&(a.checked=q),F!==void 0&&(a.key=F),P!==void 0&&(a.code=P),E!=null&&(a.listSelector=E),S!=null&&(a.targetIndex=S),u.actions.push(a)};G===0?o():(clearTimeout(m[s]),m[s]=setTimeout(o,G))};t.D.addEventListener(s,d,!0),u._listeners.push({ev:s,handler:d})})},t.stopRecording=()=>{const n=t.recorder;n.active=!1,n._originalFetch&&(window.fetch=n._originalFetch,n._originalFetch=null),n._originalXHROpen&&(XMLHttpRequest.prototype.open=n._originalXHROpen,XMLHttpRequest.prototype.send=n._originalXHRSend,n._originalXHROpen=null,n._originalXHRSend=null),n._originalWebSocket&&(window.WebSocket=n._originalWebSocket,n._originalWebSocket=null),n._listeners.forEach(({ev:i,handler:r})=>{t.D.removeEventListener(i,r,!0)}),n._listeners=[],n._observer&&(n._observer.disconnect(),n._observer=null);const e={actions:[...n.actions],mocks:{...n.mocks},initialData:{...n.initialData},stepDelays:{...n.stepDelays},assertions:[...n.assertions||[]],removedElements:[...n.removedElements||[]],observeRoot:n.observeRoot||null,websocketEvents:[...n.websocketEvents||[]]};return n.strictCapture&&(e.strictCapture={...n.strictCapture}),e},t.clearRecording=n=>{if(n!==void 0)sessionStorage?.removeItem("oTest-Recording-"+n);else for(let e=sessionStorage?.length-1;e>=0;e--){const i=sessionStorage?.key(e);i&&i.indexOf("oTest-Recording-")===0&&sessionStorage?.removeItem(i)}},t.runRecordingAssertions=(n,e,i,r)=>{const p=!!(r&&r.strictAssertions),L=r&&r.strictRemoved!==void 0?!!r.strictRemoved:p,x=r&&r.assertions,C=x??(n.assertions||[]).filter(s=>i==null||s.actionIdx===i);t.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[runRecordingAssertions] run:",{actionIdx:i,scope:i==null?"teardown (all)":"per-action",assertionsCount:C.length,assertions:C.map(s=>({actionIdx:s.actionIdx,type:s.type,selector:s.selector,index:s.index,text:(s.text||"").slice(0,40)}))});const _=new Set,D=C.filter(s=>{const d=`${s.selector}|${s.type}|${s.actionIdx}|${s.index??""}`;return _.has(d)?!1:(_.add(d),!0)}),v=(()=>{if(e!=null)return typeof e=="string"?t.D.querySelector(e)||t.D.body:e;const s=n.observeRoot;return s&&t.D.querySelector(s)||t.D.body})(),$=s=>(s||"").trim().replace(/\s+/g," "),u=s=>$(String(s||"").replace(/\s*:\s*/g,": ").replace(/\s*;\s*/g,"; ")),f=s=>s?$(s.textContent||""):"",j=r?.removedElements||[],O=s=>{if(!j.length||i==null)return!1;const d=$(s.text||"");for(const N of j)if(!(N.actionIdx>i)&&$(N.text||"")===d&&N.selector===s.selector&&!(s.listSelector!=null&&N.listSelector!==s.listSelector)&&!(s.index!=null&&N.index!==s.index))return!0;return!1};let I=0;const m=[];for(const s of D){if(O(s)){if(!L){I+=1,t.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[runRecordingAssertions] skip (explicit removed):",{actionIdx:s.actionIdx,selector:s.selector,text:(s.text||"").slice(0,40)});continue}let y=null;const E=$(s.text||"");if(s.listSelector!=null&&s.index!=null){const S=v.querySelectorAll(s.listSelector);let w=S[s.index];if(!w&&s.index>0&&(w=S[s.index-1]),w&&(y=s.selector!==s.listSelector&&w.querySelector(s.selector)||w),!y&&E&&s.type==="visible")for(let A=0;A<S.length;A++){const B=S[A],q=s.selector!==s.listSelector&&B.querySelector(s.selector)||B;if(q&&f(q).indexOf(E)!==-1){y=q;break}}}else{const S=v.querySelectorAll(s.selector);y=S.length>0?S[0]:t.D.querySelector(s.selector)}if(y&&s.type==="visible"){const S=y.nodeType===1&&(y.offsetParent!==null||y.getBoundingClientRect&&y.getBoundingClientRect().width>0),w=f(y);if(S&&(!E||w.indexOf(E)!==-1||E.indexOf(w)!==-1)){m.push({selector:s.selector,message:"expected absent (recorded removed) but matching content still visible"});continue}}else if(y&&s.type!=="visible"){m.push({selector:s.selector,message:"expected absent (recorded removed) but element still present"});continue}I+=1;continue}let d=null,N=!1,g=-1;if(s.listSelector!=null&&s.index!=null){const y=v.querySelectorAll(s.listSelector);g=y.length;const E=$(s.text||""),S=A=>{const B=y[A];return B?(s.selector!==s.listSelector?B.querySelector(s.selector):B)||(s.selector!==s.listSelector?B:null):null};let w;if(p)w=y[s.index],w&&(d=S(s.index),!d&&s.selector!==s.listSelector&&(d=w));else if(w=y[s.index],!w&&s.index>0&&(w=y[s.index-1]),w&&(d=S(s.index)||(s.index>0?S(s.index-1):null),!d&&s.selector!==s.listSelector&&(d=w),s.type==="visible"&&E&&d)){const A=f(d);if(A.indexOf(E)===-1&&E.indexOf(A)===-1)for(let q=0;q<y.length;q++){const F=S(q);if(F&&f(F).indexOf(E)!==-1){d=F,w=y[q];break}}}w||(N=!0)}else{const y=v.querySelectorAll(s.selector);d=y.length>0?y[0]:t.D.querySelector(s.selector)}if(s.type==="visible"){const y=d&&d.nodeType===1&&(d.offsetParent!==null||d.getBoundingClientRect&&d.getBoundingClientRect().width>0),E=$(s.text||""),S=f(d),w=p?!E||S===E:!E||S.indexOf(E)!==-1||E.length>0&&E.indexOf(S)!==-1;if(y&&w)I+=1;else{const A=g>=0?g:v.querySelectorAll(s.listSelector||s.selector).length,B=N?`index out of bounds (list has ${A} items, assertion expected index ${s.index})`:d?y?w?"fail":"text mismatch":"not visible":"element not found";m.push({selector:s.selector,message:B}),typeof console<"u"&&console.warn&&console.warn("[runRecordingAssertions] visible failed:",{actionIdx:s.actionIdx,selector:s.selector,listSelector:s.listSelector,index:s.index,expectedText:s.text||"(any)",actualText:S.slice(0,80),message:B})}}else if(s.type==="class"){const y=(s.className||"").trim().split(/\s+/).filter(Boolean),E=d&&(y.length===0||y.every(w=>d.classList?.contains(w))),S=!p||!s.className||$((d?.className||"").trim())===$((s.className||"").trim());if(E&&S)I+=1;else{const w=N?`index out of bounds (list has ${v.querySelectorAll(s.listSelector).length} items, expected index ${s.index})`:d?E&&!S?`expected exact className "${s.className}" (strict)`:`expected class "${s.className}"`:"element not found";m.push({selector:s.selector,message:w}),typeof console<"u"&&console.warn&&console.warn("[runRecordingAssertions] failed:",{type:s.type,selector:s.selector,actionIdx:s.actionIdx,listSelector:s.listSelector,index:s.index,itemsInRoot:s.listSelector?v.querySelectorAll(s.listSelector).length:"-",message:w})}}else if(s.type==="style"){const y=(s.style||"").trim(),E=(d?.style?.cssText||d?.getAttribute?.("style")||"").trim();if(d&&(!y||(p?u(E)===u(y):E.indexOf(y)!==-1||y===E)))I+=1;else{const w=d?`expected style "${y.slice(0,60)}..."`:"element not found";m.push({selector:s.selector,message:w})}}else if(s.type==="hidden")if(d&&d.hidden===s.hidden)I+=1;else{const E=d?`expected hidden=${s.hidden}`:"element not found";m.push({selector:s.selector,message:E})}else if(s.type==="disabled")if(d&&d.disabled===s.disabled)I+=1;else{const E=d?`expected disabled=${s.disabled}`:"element not found";m.push({selector:s.selector,message:E})}else if(s.type==="aria-expanded"){const y=d?.getAttribute?.("aria-expanded");if(d&&(s.ariaExpanded==null||String(y)===String(s.ariaExpanded)))I+=1;else{const S=d?`expected aria-expanded="${s.ariaExpanded}"`:"element not found";m.push({selector:s.selector,message:S})}}else if(s.type==="aria-checked"){const y=d?.getAttribute?.("aria-checked");if(d&&(s.ariaChecked==null||String(y)===String(s.ariaChecked)))I+=1;else{const S=d?`expected aria-checked="${s.ariaChecked}"`:"element not found";m.push({selector:s.selector,message:S})}}}return{passed:I,total:D.length,failures:m}},t.exportTest=(n,e={})=>{const i=e.delay!==void 0?e.delay:16,r=e.extensionExport===!0,p={actions:n.actions,assertions:n.assertions||[],observeRoot:n.observeRoot||null},L=n.observeRoot?`(o.D.querySelector('${n.observeRoot.replace(/'/g,"\\'")}') || o.D.body)`:"o.D.body",x=u=>{if(u.listSelector!=null&&u.targetIndex!=null){const f=JSON.stringify(u.listSelector),j=u.target===u.listSelector,O=j?f:JSON.stringify(u.target);return` const items = o.D.querySelectorAll(${f});
|
|
17
|
-
const item = items[${
|
|
6
|
+
*/const __DEV__=!0,o=query=>{let result={els:[],ie:{},delegated:{},parented:{},store:{},refs:{},_refsByIndex:[],states:[],isDebug:!1,currentState:"",savedStates:{},isRoot:!1,_parent:null},ONE=1,TWO=2,THREE=3,booleanType="boolean",objectType="object",functionType="function",stringType="string",numberType="number",notEmptyStringType="notEmptyString",undefinedType="undefined",_reactProp="dangerouslySetInnerHTML",u,D=o.D,start=-1,finish=0,select=0,ssr=typeof process<"u"||o.D===o.DocumentMVP,i=0,j=0;const self=result,type=obj=>typeof obj,cycleObj=(obj,func)=>{for(const item in obj)Object.hasOwn(obj,item)&&func(item,obj)},error=o.onError,typeVerify=pairs=>o.verify(pairs),returner=(f,name="")=>(...a)=>{(o.debug||result.isDebug)&&console.log(name?`${name}()`:f,a.length?"with "+a.join(", "):"without parameters");try{const res=f(a[0],a[ONE],a[TWO],a[THREE]);return res!==u?res:result}catch(err){error(err,name)}},iterator=f=>{for(i=finish;i<=start;i++)f()},toEl=el=>el?.els?el.el:(type(el)!==objectType&&(el=o.first(el).el),el),setResultVals=(clearStates=!0,els=result.els)=>{const ln=els.length;if(result.length=ln,start=ln-ONE,finish=0,result.el=ln?els[0]:u,result.last=ln?els[start]:u,clearStates&&(cycleObj(result.states,(i2,state)=>{delete result[state[i2]]}),result.states=[],result.ie={}),Array.isArray(result._refsByIndex)){const currentLen=result._refsByIndex.length;if(currentLen>ln)cycleObj(result._refsByIndex,k=>{const idx=+k;idx>=ln&&delete result._refsByIndex[idx]}),result._refsByIndex.length=ln;else if(currentLen<ln)for(let idx=currentLen;idx<ln;idx++)result._refsByIndex[idx]={}}};result.reset=o;const hydrateDataOInitIn=containerEl=>{if(ssr||!containerEl.querySelectorAll)return;const nodes=containerEl.querySelectorAll("[data-o-init]"),byId={};nodes.forEach(node=>{const id=node.getAttribute("data-o-init");id!==null&&(byId[id]||(byId[id]=[]),byId[id].push(node))}),cycleObj(byId,id=>{const inst=o.inits[id];inst&&inst.getSSR(Number(id),byId[id])})},transform=(el,state,props)=>{cycleObj(state,s=>{let value=state[s];type(value)===functionType&&(value=value(props)),s==="append"&&type(value)===objectType&&(value.els&&(value=[value]),value[0]?.els&&(valueBuff=[],cycleObj(value,i2=>{valueBuff.push(...value[i2].els)}),value=valueBuff)),value!==u&&el.getAttribute(s)!==value&&!["tag","tagName","name","sample","state","events","ssr","nodeName","revertChildren","root","ref"].includes(s)&&(["html","innerHTML"].includes(s)?(el.innerHTML=value,!ssr&&hydrateDataOInitIn(el)):s==="className"?el.setAttribute("class",value):s==="dataset"&&type(value)===objectType?cycleObj(value,data=>{el.dataset[data]=value[data]}):s==="toggleClass"?el.classList.toggle(value):s==="addClass"?type(value)===objectType?el.classList.add(...value):el.classList.add(value):s==="removeClass"?el.classList.remove(value):s==="style"&&type(value)===objectType?cycleObj(value,data=>{el.style[data]=value[data]}):(s==="append"||s==="children"||s==="childNodes")&&type(value)===objectType?cycleObj(value.length?value:[value],j2=>{s==="append"||!el.childNodes[j2]?el.appendChild(value[j2]):el.childNodes[j2]!==value[j2]&&el.childNodes[j2].replaceWith(value[j2])}):el.setAttribute(s,value))}),el.dataset.oState=state.state,o.autotag&&state.name&&(el.dataset[o.autotag]=o.camelToKebab(state.name))};result.debug=returner(()=>{result.isDebug=!0},"debug ON"),result.saveAs=returner(key=>{typeVerify([[key,[notEmptyStringType]]]),o.getSaved[key]?(o.debug||result.isDebug)&&console.warn("the key exists (not saved):"+key):o.getSaved[key]=result},"saveAs"),result.unmount=()=>((o.debug||result.isDebug)&&console.log("unmount() for initID:"+result.initID),type(result.remove)===functionType?result.remove():result.els?.length&&result.els.forEach(el=>{el?.parentNode&&el.parentNode.removeChild(el)}),o.inits[result.initID]=void 0,result={},!0),result.init=returner(states=>{typeVerify([[states,[objectType,functionType]]]);const initN=result.initID||o.inits.length||0;if(result.initID=initN,setResultVals(),o.inits[result.initID]=result,type(states)==="function"){result.render=returner(props=>{const root=D.createElement("div");setTimeout(()=>{o.reactRender(states,root,props)}),result.add(root)});return}(type(states)!==objectType||states.render===u)&&(states={render:states}),cycleObj(states,state=>{result?.render&&state==="render"||(result.states.push(state),result[state]=returner((props=[{}])=>{result.currentState=state;const data=states[state]||{tag:"div"},slice=Array.isArray(result.els)?result.els.slice(finish,start+ONE):[],els=slice.length?slice:result.els||[];type(data)===objectType&&(data.state=state,data["data-o-init"]=initN);const newEl=(n,prop={})=>{const resolved=type(data)===functionType?data(prop):data;if(type(resolved)===objectType)return D.createElement(resolved.tag||resolved.tagName||"div");const newElem=D.createElement("div");return newElem.innerHTML=resolved,newElem.children.length>ONE||!newElem.firstElementChild?(newElem.dataset.oInit=n,newElem):(newElem.firstElementChild.dataset.oInit=n,newElem.firstElementChild)},rawData=props;Array.isArray(props)||(props=[props]),props.length||(props=[props]);const creation=!els[0]&&state==="render";props=props.map((prop,i2)=>{const newProp=Object.assign({},type(prop)===objectType?prop:{},{self:result,o,i:prop.i===u?i2:prop.i,parent:result._parent,data:Array.isArray(rawData)?rawData[i2]:rawData});return creation&&(!data.ssr||ssr)&&els.push(newEl(initN,newProp)),newProp}),creation&&(result.els=els,setResultVals(!1));const initSSR=()=>{cycleObj(data.events,event=>{result.on(event,data.events[event])})};els&&(j=els.length===props.length,els.map((el,i2)=>{props[j?i2:0].i=i2+finish;const buff=type(data)===functionType?data(props[j?i2:0]):data;type(buff)===objectType&&(buff.state=state,creation&&(buff["data-o-init"]=initN,buff["data-o-init-i"]=i2,buff.events&&(result._hydrateEvents=result._hydrateEvents||[],result._hydrateEvents[i2]=buff.events)),transform(el,buff,props[j?i2:0]))}),creation&&(result._refsByIndex=[],result.refs={},result.els.forEach((el,idx)=>{if(!el.querySelectorAll)return;const refsForEl={};el.querySelectorAll("[ref]").forEach(refEl=>{const refName=refEl.getAttribute("ref"),refInstance=o(refEl);refsForEl[refName]=refInstance,idx===0&&(result.refs[refName]=refInstance)}),result._refsByIndex[idx]=refsForEl}),!ssr&&result._hydrateEvents&&(result._hydrateEvents.forEach((evts,idx)=>{evts&&(result.select(idx),cycleObj(evts,event=>{const spec=evts[event];if(type(spec)===objectType&&spec.targetRef&&type(spec.handler)===functionType){const ref=(result._refsByIndex?.[idx]??result.refs)?.[spec.targetRef];ref&&ref.on(event,spec.handler)}else type(spec)===functionType&&result.on(event,spec)}))}),result.all()))),creation&&type(data)===objectType&&data.events&&!ssr&&!data.ssr&&initSSR()}))});const renderState=states.render||states,hasStateEvents=!ssr&&type(renderState)===objectType&&renderState.events,hasHydrateEvents=!ssr&&result._hydrateEvents&&result._hydrateEvents.length;(hasStateEvents||hasHydrateEvents)&&(result.initSSRAfterGettingSSR=()=>{result._refsByIndex=[],result.refs={},result.els.forEach((el,idx)=>{if(!el.querySelectorAll)return;const refsForEl={};el.querySelectorAll("[ref]").forEach(refEl=>{const refName=refEl.getAttribute("ref"),refInstance=o(refEl);refsForEl[refName]=refInstance,idx===0&&(result.refs[refName]=refInstance),refEl.removeAttribute("ref")}),result._refsByIndex[idx]=refsForEl,idx===0&&(result.refs=refsForEl)}),hasStateEvents&&cycleObj(renderState.events,event=>{result.on(event,renderState.events[event])}),result._hydrateEvents&&(result._hydrateEvents.forEach((evts,idx)=>{evts&&(result.select(idx),cycleObj(evts,event=>{const spec=evts[event];if(type(spec)===objectType&&spec.targetRef&&type(spec.handler)===functionType){const ref=(result._refsByIndex?.[idx]??result.refs)?.[spec.targetRef];ref&&ref.on(event,spec.handler)}else type(spec)===functionType&&result.on(event,spec)}))}),result.all())})},"init"),result.connect=returner((loader,state="render",fail)=>{typeVerify([[loader,[objectType]],[state,[notEmptyStringType]],[fail,[stringType,undefinedType]]]),loader.connect(self,state,fail)},"connect"),result.getSSR=returner((initId,fromEls)=>{typeVerify([[initId,[numberType,undefinedType]]]);const effectiveId=initId!==void 0?initId:result.initID;if(ssr||type(initId)===undefinedType&&type(result.initID)===undefinedType)return;const ssrEls=fromEls&&fromEls.length?fromEls:o.D.querySelectorAll(`[data-o-init="${effectiveId}"]`);ssrEls.length&&(result.els=Array.from(ssrEls),initId!==void 0&&(result.initID=initId,o.inits[initId]=result),setResultVals(!1),type(result.initSSRAfterGettingSSR)===functionType?result.initSSRAfterGettingSSR():fromEls&&fromEls.length&&(result._refsByIndex=[],result.refs={},result.els.forEach((el,idx)=>{if(!el.querySelectorAll)return;const refsForEl={};el.querySelectorAll("[ref]").forEach(refEl=>{const refName=refEl.getAttribute("ref");refsForEl[refName]=o(refEl),idx===0&&(result.refs[refName]=refsForEl[refName]),refEl.removeAttribute("ref")}),result._refsByIndex[idx]=refsForEl,idx===0&&(result.refs=refsForEl)})))},"getSSR"),result.initState=returner((state,props)=>{typeVerify([[state,[objectType]],[props,[objectType,undefinedType]]]),result.init(state).render(props)},"initState");const parseState=(el,stateId,root)=>{const attrs=el.attributes,stateData={tagName:el.tagName.toLowerCase()};for(const attr of attrs)stateData[attr.nodeName]=attr.value;if(root){stateData.innerHTML=el.innerHTML,stateData.revertChildren=[];const initedChildren=el.querySelectorAll("[data-o-init]");for(const child of initedChildren){const initId=child.getAttribute("data-o-init");stateData.revertChildren.push(initId),o.inits[initId]?.saveState(stateId,!1)}}return stateData};return result.saveState=returner((stateId,root=!0)=>{if(typeVerify([[stateId,[notEmptyStringType,undefinedType]],[root,[booleanType]]]),!result.el)throw Error("saveState(): There are no elements to save");const targetState=stateId||"fastSavedState",stateRevert={els:[],parentNode:result.el.parentNode,root};iterator(()=>{stateRevert.els.push(parseState(result.els[i],targetState,root))}),stateRevert.ie=Object.assign({},result.ie),stateRevert.delegated=Object.assign({},result.delegated),stateRevert.store=Object.assign({},result.store),result.isRoot=result.isRoot||root,result.savedStates[targetState]=stateRevert},"saveState"),result.revertState=returner(state=>{typeVerify([[state,[notEmptyStringType,undefinedType]]]);const targetState=state||"fastSavedState";if(!result.savedStates[targetState])throw Error(`revertState(): The state "${targetState}" should have been saved by saveState()`);const stateRevert=result.savedStates[targetState];result.offAll(),result.offDelegate(),result.store=Object.assign({},stateRevert.store),stateRevert.els.forEach((elData,index)=>{if(!result.els[index]){const newEl=o.D.createElement(elData.tagName);stateRevert.parentNode&&(index?result.els[index-1].after(newEl):stateRevert.parentNode.append(newEl)),result.add(newEl)}transform(result.els[index],elData)}),result.delegated=Object.assign({},stateRevert.delegated),result.ie=Object.assign({},stateRevert.ie),result.onAll(),cycleObj(stateRevert.delegated,ev=>{stateRevert.delegated[ev].forEach(f=>{iterator(()=>{result.els[i].addEventListener(ev,f)})})}),result.currentState=targetState,stateRevert.root&&stateRevert.els.forEach(({rootElement})=>{rootElement.revertChildren.forEach(initId=>{o.inits[initId]?.revertState(targetState),o('[data-o-init="'+initId+'"]').els.forEach((el,index)=>{el.replaceWith(o.inits[initId]?.els[index])})})})},"revertState"),result.loseState=returner(stateId=>{typeVerify([[stateId,[notEmptyStringType]]]),result.savedStates[stateId]&&(delete result.savedStates[stateId],iterator(()=>{const initedChildren=result.els[i].querySelectorAll("[data-o-init]");for(const child of initedChildren){const initId=child.getAttribute("data-o-init");o.inits[initId]?.loseState(stateId)}}))},"sample"),result.sample=returner((state="render")=>(typeVerify([[state,[notEmptyStringType]]]),{[state]:parseState(result.els[finish])}),"sample"),result.select=returner(i2=>{let idx=i2;idx!=null&&type(idx)===objectType&&idx.target&&result.els.length&&(idx=result.els.findIndex(el=>el===idx.target||el.contains(idx.target)),idx<0&&(idx=0)),typeVerify([[idx,[numberType,undefinedType]]]),idx===u&&(idx=result.length-ONE),start=idx,finish=idx,result.el=result.els[idx],select=ONE,Array.isArray(result._refsByIndex)&&result._refsByIndex[idx]&&(result.refs=result._refsByIndex[idx])},"select"),result.all=returner(()=>{start=result.length-ONE,finish=0,result.el=result.els[0],select=0,Array.isArray(result._refsByIndex)&&result._refsByIndex.length&&(result.refs=result._refsByIndex[0]||{})},"all"),result.remove=returner(j2=>{if(typeVerify([[j2,[numberType,undefinedType]]]),j2===u&&select&&(j2=finish),j2!==u){const el=result.els[j2];el?.parentNode?el.parentNode.removeChild(el):el===void 0&&j2>=result.els.length&&o.onError&&o.onError("remove("+j2+"): index out of bounds","remove")}else iterator(()=>{const el=result.els[i];el?.parentNode&&el.parentNode.removeChild(el)});setResultVals(!1)},"remove"),result.skip=returner(j2=>{typeVerify([[j2,[numberType,undefinedType]]]),j2===u&&(j2=finish),result.els.splice(j2,ONE),Array.isArray(result._refsByIndex)&&result._refsByIndex.splice(j2,ONE),setResultVals()},"skip"),result.add=returner(el=>{typeVerify([[el,[stringType,objectType,numberType]]]),result.initID===u&&(type(el)==="string"&&el!==""?result.els.push(...Array.from(D.querySelectorAll(el))):type(el)===objectType?el.tagName?result.els.push(el):el.els?result.els.push(...el.els):el.length&&el[0].tagName&&result.els.push(...el):type(el)==="number"&&o.inits[el]&&(result=o.inits[el]),setResultVals(!1),result.initID!==u&&result.dataset({oInit:result.initID}))},"add"),result.appendInside=returner(el=>{typeVerify([[el,[objectType,notEmptyStringType]]]),el?.els&&(result._parent=el),iterator(()=>{toEl(el).appendChild(result.els[i])})},"appendInside"),result.appendBefore=returner(el=>{typeVerify([[el,[objectType,notEmptyStringType]]]),iterator(()=>{toEl(el).parentNode.insertBefore(result.els[i],toEl(el))})},"appendBefore"),result.appendAfter=returner(el=>{typeVerify([[el,[objectType,notEmptyStringType]]]),iterator(()=>{toEl(el).after(...result.els)})},"appendAfter"),result.find=returner((innerQuery="")=>{typeVerify([[innerQuery,stringType]]);const newEls=[];return iterator(()=>{newEls.push(...Array.from(result.els[i].querySelectorAll(":scope "+innerQuery)))}),o(newEls)},"find"),result.first=returner((innerQuery="")=>{typeVerify([[innerQuery,stringType]]);let buff=u;const newEls=[];return iterator(()=>{buff=result.els[i].querySelector(innerQuery),buff&&newEls.push(buff)}),o(newEls)},"first"),result.attr=returner((attr,val)=>{if(val!==null&&typeVerify([[attr,stringType],[val,[stringType,undefinedType]]]),val===u){const attrs=[];return iterator(()=>{attrs[i]=result.els[i].getAttribute(attr)}),select?attrs[0]:attrs}else iterator(val!==null?()=>{result.els[i].setAttribute(attr,val)}:()=>{result.els[i].removeAttribute(attr)})},"attr"),result.attrs=returner(()=>{const res=[];return iterator(()=>{const obj={};[...result.els[i].attributes].forEach(attr=>{obj[attr.nodeName]=attr.nodeValue}),res.push(obj)}),select?res[0]:res},"attrs"),result.dataset=returner(values=>{if(typeVerify([[values,[objectType,undefinedType]]]),typeof values===objectType)iterator(()=>{cycleObj(values,data=>{result.els[i].dataset[data]=values[data]})});else{const res=[];return iterator(()=>{res.push({...result.els[i].dataset})}),select?res[0]:res}},"dataset"),result.style=returner(val=>{val!==null&&typeVerify([[val,[stringType,undefinedType]]]),result.attr("style",val)},"style"),result.css=returner((styles={})=>{if(styles===null){result.style(null);return}typeVerify([[styles,objectType]]);let val="";cycleObj(styles,style=>{val+=style+":"+styles[style].replace('"',"'")+";"}),result.style(val||null)},"css"),result.cssMerge=returner((styles={})=>{if(styles===null){result.style(null);return}typeVerify([[styles,objectType]]);const normKey=k=>k.indexOf("-")!==-1?k:o.camelToKebab(k),parseStyleAttr=s=>{const out={};if(!s||typeof s!==stringType)return out;const parts=s.split(";");for(let p=0;p<parts.length;p++){const part=parts[p],idx=part.indexOf(":");if(idx===-1)continue;const key=part.slice(0,idx).trim(),val=part.slice(idx+1).trim();key&&(out[key]=val)}return out};iterator(()=>{const el=result.els[i],merged=parseStyleAttr(el.getAttribute("style"));cycleObj(styles,style=>{const k=normKey(style),v=styles[style];v===null||v===u?delete merged[k]:merged[k]=String(v).replace('"',"'")});let serialized="";cycleObj(merged,k=>{serialized+=k+":"+merged[k]+";"}),serialized?el.setAttribute("style",serialized):el.removeAttribute("style")})},"cssMerge"),result.setClass=returner(cl=>{typeVerify([[cl,stringType]]),iterator(()=>{result.els[i].setAttribute("class",cl)})},"setClass"),result.addClass=returner((...cls)=>{iterator(()=>{result.els[i].classList.add(...cls)})},"addClass"),result.removeClass=returner((...cls)=>{iterator(()=>{result.els[i].classList.remove(...cls)})},"removeClass"),result.toggleClass=returner((cl,check)=>{typeVerify([[cl,notEmptyStringType],[check,[booleanType,undefinedType]]]),iterator(()=>{result.els[i].classList.toggle(cl,check)})},"toggleClass"),result.haveClass=cl=>{typeVerify([[cl,notEmptyStringType]]);let res=!0;return iterator(()=>{result.els[i].classList.contains(cl)||(res=!1)}),(result.isDebug||o.debug)&&console.log("haveClass() with",cl),res},result.innerHTML=returner(html=>{if(typeVerify([[html,[stringType,undefinedType]]]),html!==u)iterator(()=>{result.els[i].innerHTML=html});else{let res="";return iterator(()=>{res+=ssr&&result.els[i].innerHTML.length===0?o.D.parseElement(result.els[i],!1):result.els[i].innerHTML}),res}},"innerHTML"),result.innerText=returner(text=>{typeVerify([[text,[stringType]]]),iterator(()=>{result.els[i].innerText=text})},"innerText"),result.textContent=returner(text=>{typeVerify([[text,[stringType]]]),iterator(()=>{result.els[i].textContent=text})},"textContent"),result.html=returner(value=>{if(typeVerify([[value,[stringType,undefinedType]]]),value!==void 0)result.innerHTML(value);else{let html="";return iterator(()=>{html+=ssr?result.els[i].outerHTML():result.els[i].outerHTML}),html}},"html"),result.toString=function(){return result.html()},result[Symbol.toPrimitive]=function(hint){return hint==="string"||hint==="default"?result.html():hint==="number"?result.els?.length??0:result.html()},result.val=returner(value=>{if(value===void 0)return result.el?.value;iterator(()=>{result.els[i].value=value})},"val"),result.forEach=returner(f=>{typeVerify([[f,[functionType]]]),iterator(()=>{f({self:result,i,o,el:result.els[i]})})},"forEach"),result.prepareFor=returner((reactArg,ReactComponent)=>{typeVerify([[reactArg,[objectType,functionType,undefinedType]],[ReactComponent,[functionType,undefinedType]]]);const isFullReact=reactArg&&type(reactArg)===objectType&&reactArg.createElement;if(!isFullReact&&type(reactArg)!==functionType)throw Error("prepareFor(): pass React (full object) or React.createElement as first argument");const createElement=isFullReact?reactArg.createElement:reactArg,useEffect=isFullReact?reactArg.useEffect:void 0;return p=>{if(p.ref===u)throw Error("No ref property to convert Objs to React");const props=Object.assign({},p),reactElement=createElement("div",{ref:p.ref});return delete props.ref,useEffect(()=>{cycleObj(props,key=>{if(key.substring(0,1)==="on"){const e=o.camelToKebab(key).split("-")[1];result.on(e,props[key]),delete props[key]}}),result.render(props),result.appendInside(reactElement.ref.current)},[]),reactElement}},"prepareFor"),result.on=returner((a,b,c,d)=>{typeVerify([[a,[notEmptyStringType]],[b,[functionType]],[c,[objectType,undefinedType]],[d,[booleanType,undefinedType]]]),a.split(", ").forEach(ev=>{iterator(()=>{result.els[i].addEventListener(ev,b,c,d)}),result.ie[ev]||(result.ie[ev]=[]),result.ie[ev].push([b,c,d])})},"on"),result.off=returner((a,b,c)=>{typeVerify([[a,[notEmptyStringType]],[b,[functionType]],[c,[objectType,undefinedType]]]),a.split(", ").forEach(ev=>{iterator(()=>{result.els[i].removeEventListener(ev,b,c)}),result.ie[ev]&&(result.ie[ev]=result.ie[ev].filter(f=>f[0]!==b))})},"off"),result.onDelegate=returner((e,selector,f)=>{typeVerify([[e,[notEmptyStringType]],[selector,[notEmptyStringType]],[f,[functionType]]]),e.split(", ").forEach(ev=>{const delegateCheck=event=>{const delegate=event.target.closest(selector);delegate&&(event.delegate=delegate,event.objs=result,f(event))};iterator(()=>{result.els[i].addEventListener(ev,delegateCheck)}),result.delegated[ev]||(result.delegated[ev]=[]),result.delegated[ev].push(delegateCheck)})},"onDelegate"),result.offDelegate=returner(e=>{typeVerify([[e,[notEmptyStringType]]]),cycleObj(result.delegated,ev=>{if(!e||e===ev)for(;result.delegated[ev].length;){const f=result.delegated[ev].pop();iterator(()=>{result.els[i].removeEventListener(ev,f)})}}),result.delegated={}},"offDelegate"),result.onParent=returner((e,selector,f)=>{typeVerify([[e,[notEmptyStringType]],[selector,[notEmptyStringType,objectType]],[f,[functionType]]]);const parent=type(selector)===objectType?selector:o.D.querySelector(selector);e.split(", ").forEach(ev=>{const parentCheck=event=>{event.objs=result,f(event)};parent.addEventListener(ev,parentCheck),result.parented[ev]||(result.parented[ev]=[]),result.parented[ev].push(parentCheck)})},"onParent"),result.offParent=returner((e,query2)=>{typeVerify([[e,[notEmptyStringType]],[query2,[notEmptyStringType,objectType]]]);const parent=type(query2)===objectType?query2:o.D.querySelector(query2);cycleObj(result.parented,ev=>{(!e||e===ev)&&(result.parented[ev].forEach(f=>{parent.removeEventListener(ev,f)}),delete result.parented[ev])})},"offParent"),result.onAll=returner((type2,off)=>{typeVerify([[type2,[notEmptyStringType,undefinedType]],[off,[booleanType,undefinedType]]]),cycleObj(result.ie,(ev,events)=>{(!type2||type2===ev)&&events[ev].forEach(data=>{iterator(()=>{off?result.els[i].removeEventListener(ev,data[0]):result.els[i].addEventListener(ev,data[0],data[ONE],data[TWO])})})})},"onAll"),result.offAll=returner(type2=>{typeVerify([[type2,[notEmptyStringType]]]),result.onAll(type2,ONE)},"offAll"),query&&result.add(query),result.take=innerQuery=>{if(typeVerify([[innerQuery,[stringType,objectType,numberType]]]),result.add(innerQuery),result.el){const initID=result.el.dataset.oInit;if(initID!==u&&o.inits[initID])return result.length===ONE?(j=result.els[0],Object.assign(result,o.inits[initID]),result.els=[j]):result=o.inits[initID],setResultVals(!1,result.els),result}},result};o.first=query=>(o.verify([[query,["notEmptyString"]]]),o.debug&&console.log(query," -> ","o.first()"),o(o.D.querySelector(query)).select(0)),o.inits=[],o.getSaved={},o.errors=[],o.showErrors=!1,o.logErrors=()=>{o.errors.length?o.errors.forEach(e=>console.error(e)):console.log("No errors")},o.onError=(e,name)=>{o.showErrors?console.error(e,name):(o.errors.push(e),name&&o.errors.push(name))},o.reactRender=()=>new Error("React render function is not defined"),o.autotag=void 0,o.reactQA=name=>({["data-"+(o.autotag||"qa")]:name.replace(/([A-Z])/g,(_,l)=>"-"+l.toLowerCase()).replace(/^-/,"")}),o.specialTypes={notEmptyString:(val,type)=>type==="string"&&val.length,array:val=>Array.isArray(val),promise:val=>val instanceof Promise||!!(val&&typeof val.then=="function")},o.verify=(pairs,safe=!1)=>{for(const pair of pairs){const type=typeof pair[0];let expectedTypes=Array.isArray(pair[1])?pair[1]:[pair[1]],isValid=!1;if(expectedTypes.includes(type))return!0;expectedTypes=expectedTypes.filter(t=>!!o.specialTypes[t]);for(const expectedType of expectedTypes)if(isValid=o.specialTypes[expectedType](pair[0],type),isValid)return!0}return safe?!1:new Error("Type verification failed")},o.safeVerify=pairs=>o.verify(pairs,!0),o.init=(states,reactRender)=>o().init(states,reactRender),o.initState=(state,props)=>o().init(state).render(props),o.take=query=>o().take(query),o.getStates=()=>o.inits.reduce((acc,result)=>(acc.push(result?.states),acc),[]),o.getStores=()=>o.inits.reduce((acc,result)=>(acc.push(result?.store),acc),[]),o.getListeners=()=>o.inits.reduce((acc,result)=>(acc.push(result?.ie),acc),[]),o.createStore=defaults=>{const store=Object.assign({},defaults);return store._defaults=Object.assign({},defaults),store._listeners=[],store.subscribe=function(component,stateName){return this._listeners.push(data=>component[stateName]?.(data)),this},store.notify=function(){this._listeners.forEach(fn=>fn(this))},store.reset=function(){const skip={_listeners:1,subscribe:1,notify:1,_defaults:1,reset:1};for(const key of Object.keys(this._defaults))skip[key]||(this[key]=this._defaults[key])},store},o.U=void 0,o.W=2,o.H=100,o.F=!1,o.C=(a,b)=>Object.hasOwn(a,b),o.kebabToCamel=str=>str.replace(/-./g,m=>m.toUpperCase()[1]),o.camelToKebab=str=>str.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase(),o.route=(path,task)=>{o.verify([[path,["notEmptyString","function","boolean"]],[task,["function","object"]]]);const result=typeof path=="function"?path(window.location.pathname):path;return result===!0||window.location.pathname===result?task?typeof task=="function"?(task(),!0):task:o:typeof task=="function"?!1:{}},o.router=(routes={})=>{o.verify([[routes,["object"]]]);for(const route in routes)if(o.C(routes,route)&&window.location.pathname===route)return typeof routes[route]=="function"?(routes[route](),!0):routes[route];return!1},o.DocumentMVP={addEventListener:()=>{},parseElement:(elem,outer=!0)=>{o.verify([[elem,["object","string"]],[outer,["boolean"]]]);const attrToStr=(attrs,prefix="")=>{let attrStr="";for(const attr in attrs)o.C(attrs,attr)&&(attrStr+=` ${prefix}${o.camelToKebab(attr)}="${typeof attrs[attr]!="object"?attrs[attr]:Object.entries(attrs[attr]).map(e=>`${e[0]}: ${e[1]};`).join(" ")}"`);return attrStr};if(typeof elem=="string")return elem;if(outer){const selfClosing=["area","base","br","col","embed","hr","img","input","link","meta","param","source","track","wbr"],tagName=elem.tagName.toLowerCase(),dataOInit=elem.attributes["data-o-init"],dataOInitAttr=dataOInit!==void 0?` data-o-init="${dataOInit}"`:"";return`<${tagName}${elem.className?` class="${elem.className}"`:""}${attrToStr(elem.attributes)}${dataOInitAttr}${attrToStr(elem.dataset,"data-")}${selfClosing.includes(tagName)?"/":""}>${selfClosing.includes(tagName)?"":elem.innerHTML.length?elem.innerHTML:elem.children.map(el=>o.D.parseElement(el)).join("")}${selfClosing.includes(tagName)?"":`</${tagName}>`}`}return elem.innerHTML.length?elem.innerHTML:elem.children.map(el=>o.D.parseElement(el)).join("")},createElement:tag=>{o.verify([[tag,["notEmptyString"]]]);const elem={tagName:tag.toUpperCase(),attributes:{},innerHTML:"",children:[],dataset:{},className:"",classArray:[],style:{},addEventListener:()=>{},removeEventListener:()=>{}};return elem.classList={add:(...cl)=>{o.verify([[cl,["array"]]]),elem.classArray.push(cl),elem.className=elem.classArray.join(" ")},has:cl=>(o.verify([[cl,["notEmptyString"]]]),elem.classArray.includes(cl)),remove:cl=>{o.verify([[cl,["notEmptyString"]]]),elem.classArray=elem.classArray.filter(listed=>cl!==listed),elem.className=elem.classArray.join(" ")}},elem.classList.toggle=cl=>{o.verify([[cl,["notEmptyString"]]]),elem.classList.has(cl)?elem.classList.remove(cl):elem.classList.add(cl)},elem.setAttribute=(attr,val)=>{o.verify([[attr,["notEmptyString"]],[val,["string","number","boolean","undefined"]]]),elem.attributes[attr]=val},elem.getAttribute=attr=>(o.verify([[attr,["notEmptyString"]]]),elem.attributes[attr]),elem.removeAttribute=attr=>{o.verify([[attr,["notEmptyString"]]]),delete elem.attributes[attr]},elem.appendChild=el=>{o.verify([[el,["object"]]]),elem.children.push(el),elem.firstElementChild=elem.children[0]},elem.outerHTML=()=>o.D.parseElement(elem),elem}},o.D=typeof document<"u"&&typeof process>"u"?document:o.DocumentMVP,o.setCookie=(title,value="",params={})=>{if(o.verify([[title,["notEmptyString"]],[value,["string","number","boolean"]],[params,["object"]]]),o.D.cookie===void 0){console.log("Cookies are not supported on server side");return}let str=encodeURIComponent(title)+"="+encodeURIComponent(value);params={path:"/",...params},params.expires instanceof Date?params.expires=params.expires.toUTCString():typeof params.expires=="number"&&(params.expires=new Date(params.expires).toUTCString());for(const key in params){str+="; "+key;const r=params[key];r!==!0&&(str+="="+r)}o.D.cookie=str},o.getCookie=title=>{if(o.verify([[title,["notEmptyString"]]]),o.D.cookie===void 0){console.log("Cookies are not supported on server side");return}const val=o.D.cookie.match(RegExp("(?:^|; )"+title.replace(/([.$?*|{}()[\]\\/+^])/g,"\\$1")+"=([^;]*)"));return val?decodeURIComponent(val[1]):void 0},o.deleteCookie=title=>{o.verify([[title,["notEmptyString"]]]),o.setCookie(title,"",{"max-age":0})},o.clearCookies=()=>{if(o.D.cookie===void 0){console.log("Cookies are not supported on server side");return}const ca=o.D.cookie.split(";");for(;ca.length;){let c=ca.pop();for(;c.charAt(0)===" ";)c=c.substring(1);const key=c.split("=")[0];o.deleteCookie(key)}},o.clearLocalStorage=all=>{if(o.verify([[all,["boolean","undefined"]]]),!(typeof localStorage>"u"))if(all)localStorage.clear();else for(let i=localStorage.length-1;i>=0;i--){const key=localStorage.key(i);key.indexOf("oInc-")===-1&&key.indexOf("oTest-")===-1&&localStorage.removeItem(key)}},o.clearSessionStorage=onlyTests=>{if(o.verify([[onlyTests,["boolean","undefined"]]]),!(typeof sessionStorage>"u"))if(!onlyTests)sessionStorage.clear();else for(let i=sessionStorage.length-1;i>=0;i--){const key=sessionStorage.key(i);key&&key.indexOf("oTest-")===0&&sessionStorage.removeItem(key)}},o.clearTestsStorage=()=>{o.clearSessionStorage(1)},o.clearAfterTests=()=>{o.clearCookies(),o.clearLocalStorage(!1),o.clearTestsStorage()},o.ajax=(url,props={})=>{o.verify([[url,["notEmptyString"]],[props,["object"]]]);const row=new URLSearchParams;if(props.data&&typeof props.data=="object"){for(const param in props.data)o.C(props.data,param)&&(typeof props.data[param]=="object"?row.set(param,encodeURIComponent(JSON.stringify(props.data[param]))):row.set(param,props.data[param]));props.method.toLowerCase()==="get"?url+="?"+row.toString():props.body||(props.body=row),delete props.data}return props.headers||(props.headers={"X-Requested-With":"XMLHttpRequest"}),fetch(url,props)},o.get=(url,props={})=>(o.verify([[url,["notEmptyString"]],[props,["object"]]]),o.ajax(url,{...props,method:"GET"})),o.post=(url,props={})=>(o.verify([[url,["notEmptyString"]],[props,["object"]]]),o.ajax(url,{...props,method:"POST"})),o.newLoader=promise=>{o.verify([[promise,["promise","undefined"]]]);let listeners=[],data=null,finished=!1,error=!1;const reload=p=>{finished=!1,error=!1,data=null,setTimeout(()=>{p.then(response=>{finished=!0,!response.ok&&typeof response.ok<"u"?(error=!0,listeners.forEach(([listener,_state,fail])=>{fail&&listener[fail](response)})):typeof response.json=="function"?response.json().then(jsonData=>{data=jsonData,listeners.forEach(([listener,state])=>{listener[state](data)})}):(data=response,listeners.forEach(([listener,state])=>{listener[state](data)}))}).catch(err=>{error=!0,listeners.forEach(([listener,_state,fail])=>{fail&&listener[fail](err)})})},33)};return promise&&reload(promise),{reload,isObjsLoader:!0,listeners,isFinished:()=>finished,getStore:()=>data,connect:(listener,state="render",fail)=>{o.verify([[listener,["object"]],[state,["notEmptyString"]],[fail,["string","undefined"]]]),finished?error?fail&&listener[fail]():typeof listener[state]=="function"&&listener[state](data):listeners.push([listener,state,fail])},disconnect:listener=>{o.verify([[listener,["object"]]]),listeners=listeners.filter(([l])=>l!==listener)}}},o.getParams=key=>{o.verify([[key,["string","undefined"]]]);const params={},paramsRaw=new URLSearchParams(window.location.search).entries();for(const entry of paramsRaw)params[entry[0]]=entry[1];return key?params[key]:params},o.incCache=!0,o.incCacheExp=1e3*60*60*24,o.incTimeout=6e3,o.incSource="",o.incForce=o.F,o.incAsync=!0,o.incCors=o.F,o.incSeparator="?",o.incFns={},o.incSet=[0],o.incReady=[0],o.incN=0,o.incGetHash=path=>path.split(o.incSeparator)[1]||"",o.incCheck=(set=0,fnId,loaded=0)=>(o.verify([[set,["number"]],[fnId,["number","undefined"]],[loaded,["number"]]]),!loaded&&set&&fnId===o.U&&o.incReady[set]?o.incSet[set]===1:o.incReady[set]===o.U||o.incReady[set][fnId]===o.U?o.F:(o.incReady[set][fnId].loaded=loaded,o.incFns[o.incReady[set][fnId].name]=loaded,o.incReady[set][0]+=loaded,set&&o.incReady[set].length===o.incReady[set][0]&&(typeof o.incSet[set]=="function"&&o.incSet[set](set),o.incSet[set]=1),o.incSet[set]===1)),o.incCacheClear=(all=o.F)=>{o.verify([[all,["boolean"]]]);for(const name in o.incFns)o.C(o.incFns,name)&&(localStorage.removeItem("oInc-"+name),localStorage.removeItem("oInc-"+name+"-expires"));return all&&(o.incReady.forEach((val,i)=>{i&&val.forEach((_a,j)=>{j&&o("#oInc-"+i+"-"+j).remove()})}),o.incN=0,o.incFns={},o.incSet=[0],o.incReady=[0]),!0},o.inc=(sources,callBack,callBad)=>{if(o.verify([[sources,["object","undefined"]],[callBack,["function","undefined"]],[callBad,["function","undefined"]]]),typeof localStorage>"u")return;let sourcesN=0,sourcesReady=0,hash="",preload=!1;const f="function",no=-1;if(typeof sources!="object"||!sources)return o.incSet[0];o.incSet[0]++;const setN=o.incSet[0];o.incSet[setN]=callBack||0,o.incReady[setN]=[];const fnsStatus=o.incReady[setN];fnsStatus[0]=1;const fnId={};for(const name in sources)if(o.C(sources,name)){if(name==="preload"){preload=!0;continue}hash=o.incGetHash(sources[name]),sourcesN++,o.incN++;const tag=sources[name].indexOf(".css")>no?"style":"script";if(sources[name]=(o.incSource?o.incSource+"/":"")+sources[name],Number.isNaN(Number(name))&&o.C(o.incFns,name)&&o.incFns[name]&&!o.incForce){fnsStatus[sourcesN]={name,loaded:1},sourcesReady++;continue}if(fnsStatus[sourcesN]={name,loaded:0},Number.isNaN(Number(name))&&(o.incFns[name]=0),Number.isNaN(Number(name))&&o.incCache&&(sources[name].substring(0,4)!=="http"||!o.incCors)&&window.location.protocol!=="file:"&&(sources[name].indexOf(".css")>no||sources[name].indexOf(".js")>no)){const ls=localStorage,script=ls.getItem("oInc-"+name),cacheSavedTill=ls.getItem("oInc-"+name+"-expires"),cacheHash=ls.getItem("oInc-"+name+"-hash");script&&cacheSavedTill&&Date.now()<cacheSavedTill&&cacheHash===hash?(preload||o.initState({tag,id:"oInc-"+setN+"-"+sourcesN,innerHTML:script,"data-o-inc":setN}).appendInside("head"),fnsStatus[sourcesN].loaded=1,o.incFns[name]=1,sourcesReady++):(fnId[name]=sourcesN,o.get(sources[name],{mode:o.incCors?"cors":"same-origin"}).then(response=>{if(response.status!==200){o.onError&&o.onError({message:o.incSource+sources[name]+" was not loaded"});return}response.text().then(script2=>{ls.setItem("oInc-"+name,script2),ls.setItem("oInc-"+name+"-expires",Date.now()+o.incCacheExp),ls.setItem("oInc-"+name+"-hash",hash),preload||o.initState({tag,id:"oInc-"+setN+"-"+fnId[name],innerHTML:script2,"data-o-inc":setN}).appendInside("head"),o.incCheck(setN,fnId[name],1)})}))}else{const state={tag,id:"oInc-"+setN+"-"+sourcesN,"data-o-inc":setN,async:o.incAsync,onload:"o.incCheck("+setN+","+sourcesN+",1)"};sources[name].indexOf(".css")>no?(state.tag="link",state.rel="stylesheet",state.href=sources[name]):(sources[name].indexOf(".js")>no||(state.tag="img",state.style="display:none;"),state.src=sources[name]),o.initState(state).appendInside(state.style?"body":"head")}}return fnsStatus[0]+=sourcesReady,sourcesN!==0&&(sourcesReady===sourcesN?typeof callBack===f&&callBack(setN):setTimeout(set=>{o.incReady[set]&&o.incReady[set].length<o.incReady[set][0]&&(o.incSet[set]=0,typeof callBad===f&&callBad(setN))},o.incTimeout,setN)),o.incSet[0]},o.connectRedux=(store,selector,component,state="render")=>{o.verify([[store,["object"]],[selector,["function"]],[component,["object"]],[state,["notEmptyString"]]]);const update=()=>{if(typeof component[state]=="function"){const val=selector(store.getState());component[state](val!==null&&typeof val=="object"?val:{value:val})}};return update(),store.subscribe(update)},o.connectMobX=(mobx,observable,accessor,component,state="render")=>(o.verify([[mobx,["object"]],[observable,["object"]],[accessor,["function"]],[component,["object"]],[state,["notEmptyString"]]]),mobx.autorun(()=>{if(typeof component[state]=="function"){const val=accessor(observable);component[state](val!==null&&typeof val=="object"?val:{value:val})}})),o.ObjsContext=null,o.withReactContext=(React,Context,selector,component,state="render")=>function(){const value=React.useContext(Context);return React.useEffect(()=>{if(typeof component[state]=="function"){const val=selector(value);component[state](val!==null&&typeof val=="object"?val:{value:val})}},[value]),null},o.debug=!1,o.sleep=ms=>new Promise(r=>setTimeout(r,ms)),o.tLog=[],o.tRes=[],o.tStatus=[],o.tFns=[],o.tShowOk=o.F,o.tStyled=o.F,o.tTime=2e3,o.tests=[],o.tExpectedSteps={},o.tFinalized={},o.tAutolog=o.F,o.tBeforeEach=void 0,o.tAfterEach=void 0,o.addTest=(title,...tests)=>{o.verify([[title,["notEmptyString"]],[tests,["array"]]]);let hooks={};tests.length&&typeof tests[tests.length-1]=="object"&&!Array.isArray(tests[tests.length-1])&&(hooks=tests.pop());const testId=o.tests.length;return o.tests[testId]={title,tests,hooks},{run:()=>{typeof hooks.before=="function"&&(o.tBeforeEach=hooks.before),typeof hooks.after=="function"&&(o.tAfterEach=hooks.after),o.runTest(testId)},autorun:()=>{typeof hooks.before=="function"&&(o.tBeforeEach=hooks.before),typeof hooks.after=="function"&&(o.tAfterEach=hooks.after),o.runTest(testId,!0)},testId}},o.updateLogs=()=>{for(let i=0;i<o.tests.length;i++)o.tLog[i]=o.tLog[testN]=sessionStorage.getItem(`oTest-Log-${testN}`)||"";return o.tLog},o.runTest=(testId=0,autoRun,savePrev)=>{if(o.verify([[testId,["number"]],[autoRun,["boolean","undefined"]],[savePrev,["boolean","undefined"]]]),!o.tests[testId])return;savePrev||(sessionStorage?.removeItem(`oTest-Log-${testId}`),sessionStorage?.removeItem(`oTest-Res-${testId}`),sessionStorage?.removeItem(`oTest-Status-${testId}`)),sessionStorage?.setItem("oTest-Run",testId),autoRun?sessionStorage?.setItem("oTest-Autorun",autoRun):sessionStorage?.removeItem("oTest-Autorun");const testSession=o.tests[testId];let lastTest=testSession.tests.pop();typeof lastTest!="function"&&(testSession.tests.push(lastTest),lastTest=()=>{}),testSession.tests.push(testN2=>{lastTest(testN2),sessionStorage.setItem("dddd",1),sessionStorage?.removeItem("oTest-Run"),autoRun&&o.runTest(testId+1,autoRun)}),o.test(testSession.title,...testSession.tests)},o.tPre='<div style="font-family:monospace;text-align:left;">',o.tOk='<span style="background:#cfc;padding: 0 15px;">OK</span> ',o.tXx='<div style="background:#fcc;padding:3px;">',o.tDc="</div>",o.test=(title="",...tests)=>{o.verify([[title,["notEmptyString"]],[tests,["array"]]]);const testSession=sessionStorage?.getItem("oTest-Run"),testN2=testSession||o.tLog.length;let waits=0,preOk="\u251C OK: ",preXx="\u251C \u2718 ",posOk=`
|
|
7
|
+
`,posXx=`
|
|
8
|
+
`,row="",num=tests.length,done=0;const log=(line="",error=!1,log2=!1)=>{o.tAutolog&&(error?console.error(line):(o.tShowOk||log2)&&console.log(line))};let opts={};if(typeof tests[num-1]=="function"&&(o.tFns[testN2]=tests[num-1],num--),num>0&&typeof tests[num-1]=="object"&&!Array.isArray(tests[num-1])&&(tests[num-1].sync!==void 0||tests[num-1].confirmOnFailure!==void 0)&&(opts=tests[num-1],num--),testSession){o.tLog[testN2]=sessionStorage.getItem(`oTest-Log-${testN2}`)||"",o.tRes[testN2]=sessionStorage.getItem(`oTest-Res-${testN2}`)||!1,o.tStatus[testN2]=JSON.parse(sessionStorage.getItem(`oTest-Status-${testN2}`)||"[]");for(let i=0;i<o.tStatus[testN2].length;i++){const s=o.tStatus[testN2][i];(s===!0||s===!1)&&done++}}o.tStyled&&(preOk=o.tPre+o.tOk,preXx=o.tPre+o.tXx,posOk=o.tDc,posXx=posOk+posOk),(!testSession||o.tLog[testN2].length===0)&&(log("\u2552 "+title+" #"+testN2,!1,!0),o.tStyled?o.tLog[testN2]="<div><b>"+title+" #"+testN2+"</b></div>":o.tLog[testN2]="\u2552 "+title+" #"+testN2+`
|
|
9
|
+
`,o.tRes[testN2]=o.F,o.tStatus[testN2]=[]),o.tExpectedSteps[testN2]=num,o.tFinalized[testN2]=!1;const showConfirmOnFailureOverlay=(stepIdx,msg)=>new Promise(resolve=>{const box=o.overlay({innerHTML:`<div style="display:flex;flex-direction:column;gap:8px;"><div style="cursor:grab;">Step ${stepIdx+1} failed: ${msg||"error"}. Continue testing?</div><div style="display:flex;gap:8px;"><button class="o-cf-continue" style="padding:6px 12px;background:#2563eb;color:#fff;border:none;border-radius:6px;cursor:pointer;">Continue</button><button class="o-cf-stop" style="padding:6px 12px;background:#dc2626;color:#fff;border:none;border-radius:6px;cursor:pointer;">Stop</button></div></div>`,timeout:opts.confirmOnFailureTimeout||void 0,onClose:r=>resolve(r||{continue:!1}),excludeDragSelector:".o-cf-continue, .o-cf-stop"});box.first(".o-cf-continue").on("click",()=>{box._overlayCleanup(),resolve({continue:!0})}),box.first(".o-cf-stop").on("click",()=>{box._overlayCleanup(),resolve({continue:!1})})}),finalize=()=>{if(o.tFinalized[testN2])return;if(waits>0){row="\u251C ",row+="DONE "+done+"/"+num+", waiting: "+waits,log(row,!0),o.tStyled?o.tLog[testN2]+=o.tPre+'<div style="color:orange;"><b>DONE '+done+"/"+num+", waiting: "+waits+"</b>"+o.tDc+o.tDc:o.tLog[testN2]+=row+`
|
|
10
|
+
`;return}o.tFinalized[testN2]=!0;const anyFailed=o.tStatus[testN2].some(s=>s===!1);o.tRes[testN2]=!anyFailed&&done===num,row="\u2558 ",row+="DONE "+done+"/"+num,log(row,done!==num),log(),o.tStyled?o.tLog[testN2]+=o.tPre+'<div style="color:'+(done!==num?"red":"green")+';"><b>DONE '+done+"/"+num+"</b>"+o.tDc+o.tDc:o.tLog[testN2]+=row+`
|
|
11
|
+
`,testSession&&(sessionStorage.setItem(`oTest-Log-${testN2}`,o.tLog[testN2]),sessionStorage.setItem(`oTest-Res-${testN2}`,o.tRes[testN2]),sessionStorage.setItem(`oTest-Status-${testN2}`,JSON.stringify(o.tStatus[testN2]))),typeof o.tFns[testN2]=="function"&&o.tFns[testN2](testN2)};if(opts.sync||opts.confirmOnFailure)return(async()=>{for(let i=o.tStatus[testN2].length;i<num;i++){const testInfo={n:testN2,i,title:tests[i][0],tShowOk:o.tShowOk,tStyled:o.tStyled};let res=tests[i][1];if(typeof res>"u"){o.tStyled?o.tLog[testN2]+="<div>"+testInfo.title+"</div>":o.tLog[testN2]+=testInfo.title+`
|
|
12
|
+
`,log("\u251C "+testInfo.title,!1,!0),o.tStatus[testN2][i]=!0,done++;continue}if(typeof o.tBeforeEach=="function"&&o.tBeforeEach(testInfo),typeof res=="function")try{res=res(testInfo)}catch(error){res=error.message,o.onError&&o.onError(error)}if(typeof o.tAfterEach=="function"&&o.tAfterEach(testInfo,res),res&&typeof res.then=="function"){try{const value=await res,ok=value===!0||value==null||value&&typeof value=="object"&&value.ok===!0,msg=value&&value.errors&&value.errors.length?value.errors.join("; "):typeof value=="string"?value:"";if(o.testUpdate(testInfo,ok,ok?"":msg?": "+msg:""),done++,!ok&&opts.confirmOnFailure&&!(await showConfirmOnFailureOverlay(i,msg)).continue)break}catch(err){if(o.testUpdate(testInfo,!1,err.message||"Promise rejected"),opts.confirmOnFailure&&!(await showConfirmOnFailureOverlay(i,err.message||"Promise rejected")).continue)break}continue}if(typeof o.tStatus[testN2][i]>"u")o.tStatus[testN2][i]=typeof res=="string"?o.F:res;else{sessionStorage.setItem(`oTest-Status-${testN2}`,JSON.stringify(o.tStatus[testN2]));return}if(res===!0)done++,o.tShowOk&&(o.tLog[testN2]+=preOk+tests[i][0]+posOk,log("\u251C OK: "+tests[i][0]));else if(res!==o.U){if(o.tLog[testN2]+=preXx+tests[i][0]+(res!==o.F?": "+res:"")+posXx,log("\u251C \u2718 "+tests[i][0]+(res!==o.F?": "+res:""),!0),opts.confirmOnFailure&&!(await showConfirmOnFailureOverlay(i,typeof res=="string"?res:"")).continue)break}else{waits++,setTimeout(info=>{info.title+=" (timeout)",o.testUpdate(info)},o.tTime,testInfo);return}}finalize()})(),testN2;for(let i=o.tStatus[testN2].length;i<num;i++){const testInfo={n:testN2,i,title:tests[i][0],tShowOk:o.tShowOk,tStyled:o.tStyled};let res=tests[i][1];if(typeof res>"u"){o.tStyled?o.tLog[testN2]+="<div>"+testInfo.title+"</div>":o.tLog[testN2]+=testInfo.title+`
|
|
13
|
+
`,log("\u251C "+testInfo.title,!1,!0),o.tStatus[testN2][i]=!0,done++;continue}if(typeof o.tBeforeEach=="function"&&o.tBeforeEach(testInfo),typeof res=="function")try{res=res(testInfo)}catch(error){res=error.message,o.onError&&o.onError(error)}if(typeof o.tAfterEach=="function"&&o.tAfterEach(testInfo,res),res&&typeof res.then=="function"){waits++;const timeoutId=setTimeout(()=>{testInfo.title+=" (timeout)",o.testUpdate(testInfo)},o.tTime);res.then(value=>{clearTimeout(timeoutId);const ok=value===!0||value&&value.ok===!0,msg=value&&value.errors&&value.errors.length?value.errors.join("; "):typeof value=="string"?value:"";o.testUpdate(testInfo,ok,ok?"":msg?": "+msg:"")}).catch(err=>{clearTimeout(timeoutId),o.testUpdate(testInfo,!1,err.message||"Promise rejected")});continue}if(typeof o.tStatus[testN2][i]>"u")o.tStatus[testN2][i]=typeof res=="string"?o.F:res;else{sessionStorage.setItem(`oTest-Status-${testN2}`,JSON.stringify(o.tStatus[testN2]));return}res===!0?(done++,o.tShowOk&&(o.tLog[testN2]+=preOk+tests[i][0]+posOk,log("\u251C OK: "+tests[i][0]))):res!==o.U?(o.tLog[testN2]+=preXx+tests[i][0]+(res!==o.F?": "+res:"")+posXx,log("\u251C \u2718 "+tests[i][0]+(res!==o.F?": "+res:""),!0)):(waits++,setTimeout(info=>{info.title+=" (timeout)",o.testUpdate(info)},o.tTime,testInfo))}return finalize(),testN2},o.testUpdate=(info,res=o.F,suff="")=>{o.verify([[info,["object"]],[res,["boolean","string"]],[suff,["string"]]]);let row="";const testN2=info.n,log=(line="",error=!1)=>{o.tAutolog&&(error?console.error(line):console.log(line))};if(o.tStatus[testN2][info.i]===o.U||o.tStatus[testN2][info.i]===null){o.tStatus[testN2][info.i]=res===!0,res===!0?info.tShowOk&&(row="\u251C OK: "+info.title+suff,log(row),info.tStyled?o.tLog[testN2]+=o.tPre+o.tOk+info.title+suff+o.tDc:o.tLog[testN2]+=row+`
|
|
14
|
+
`):(o.tRes[testN2]=o.F,row="\u251C \u2718 "+info.title+(res?": "+res:"")+suff,log(row,!0),info.tStyled?o.tLog[testN2]+=o.tPre+o.tXx+info.title+suff+(res?": "+res:"")+o.tDc+o.tDc:o.tLog[testN2]+=row+`
|
|
15
|
+
`);let fails=0,n=0;for(const s of o.tStatus[testN2]){if(s===o.U||s===null)return;s||fails++,n++}const expectedSteps=o.tests[testN2]?.tests?.length??o.tExpectedSteps[testN2]??Number.MAX_SAFE_INTEGER;if(n<expectedSteps){sessionStorage?.getItem("oTest-Run")===testN2&&(sessionStorage.setItem(`oTest-Log-${testN2}`,o.tLog[testN2]),sessionStorage.setItem(`oTest-Res-${testN2}`,o.tRes[testN2]),sessionStorage.setItem(`oTest-Status-${testN2}`,JSON.stringify(o.tStatus[testN2])));return}if(o.tFinalized[testN2])return;o.tFinalized[testN2]=!0,sessionStorage?.getItem("oTest-Run")===testN2&&(sessionStorage.setItem(`oTest-Log-${testN2}`,o.tLog[testN2]),sessionStorage.setItem(`oTest-Res-${testN2}`,o.tRes[testN2]),sessionStorage.setItem(`oTest-Status-${testN2}`,JSON.stringify(o.tStatus[testN2]))),o.tRes[testN2]=!fails,row=fails?"FAILED "+fails+"/"+n:"DONE "+n+"/"+n,log("\u2558 "+row,!!fails),log(),info.tStyled?o.tLog[testN2]+=o.tPre+'<b style="color:'+(fails?"red":"green")+';">'+row+"</b>"+o.tDc:o.tLog[testN2]+="\u2558 "+row+`
|
|
16
|
+
`,typeof o.tFns[testN2]=="function"&&o.tFns[testN2](testN2)}},sessionStorage?.getItem("oTest-Run")&&window?.addEventListener("load",()=>{o.runTest(sessionStorage?.getItem("oTest-Run"),sessionStorage?.getItem("oTest-Autorun")||o.F,!0)},!1),o.measure=el=>{if(!el)return{};const rect=el.getBoundingClientRect(),style=window.getComputedStyle(el);return{width:rect.width,height:rect.height,top:rect.top,left:rect.left,visible:style.display!=="none"&&style.visibility!=="hidden"&&rect.width>0,opacity:style.opacity,zIndex:style.zIndex}},o.assertVisible=el=>!!o.measure(el).visible,o.assertSize=(el,expected={})=>{if(!el)return"element is null";const m=o.measure(el);if(expected.w!==void 0&&Math.round(m.width)!==expected.w)return`width: expected ${expected.w}, got ${Math.round(m.width)}`;if(expected.h!==void 0&&Math.round(m.height)!==expected.h)return`height: expected ${expected.h}, got ${Math.round(m.height)}`;const getPx=prop=>{const v=window.getComputedStyle(el).getPropertyValue(prop);return v?parseFloat(v):0};return expected.padding!==void 0&&getPx("padding-top")!==expected.padding?`padding: expected ${expected.padding}, got ${getPx("padding-top")}`:expected.paddingTop!==void 0&&getPx("padding-top")!==expected.paddingTop?`paddingTop: expected ${expected.paddingTop}, got ${getPx("padding-top")}`:expected.paddingRight!==void 0&&getPx("padding-right")!==expected.paddingRight?`paddingRight: expected ${expected.paddingRight}, got ${getPx("padding-right")}`:expected.paddingBottom!==void 0&&getPx("padding-bottom")!==expected.paddingBottom?`paddingBottom: expected ${expected.paddingBottom}, got ${getPx("padding-bottom")}`:expected.paddingLeft!==void 0&&getPx("padding-left")!==expected.paddingLeft?`paddingLeft: expected ${expected.paddingLeft}, got ${getPx("padding-left")}`:expected.margin!==void 0&&getPx("margin-top")!==expected.margin?`margin: expected ${expected.margin}, got ${getPx("margin-top")}`:expected.marginTop!==void 0&&getPx("margin-top")!==expected.marginTop?`marginTop: expected ${expected.marginTop}, got ${getPx("margin-top")}`:expected.marginRight!==void 0&&getPx("margin-right")!==expected.marginRight?`marginRight: expected ${expected.marginRight}, got ${getPx("margin-right")}`:expected.marginBottom!==void 0&&getPx("margin-bottom")!==expected.marginBottom?`marginBottom: expected ${expected.marginBottom}, got ${getPx("margin-bottom")}`:expected.marginLeft!==void 0&&getPx("margin-left")!==expected.marginLeft?`marginLeft: expected ${expected.marginLeft}, got ${getPx("margin-left")}`:!0},o.recorder={active:!1,actions:[],mocks:{},initialData:{},assertions:[],observeRoot:null,strictCapture:null,_originalFetch:null,_listeners:[],_observer:null},o.recordingAssertionDebug=!1,o.startRecording=(observe,events,timeouts)=>{if(o.recorder.active)return;let observeSel,eventsOpt,timeoutsOpt,strictCapture=null;if(observe!=null&&typeof observe=="object"&&!Array.isArray(observe)&&(o.C(observe,"observe")||o.C(observe,"events")||o.C(observe,"timeouts")||o.C(observe,"strictCaptureAssertions")||o.C(observe,"strictCaptureNetwork")||o.C(observe,"strictCaptureWebSocket"))){const bag=observe;observeSel=bag.observe!=null?String(bag.observe):void 0,eventsOpt=bag.events,timeoutsOpt=bag.timeouts,(o.C(bag,"strictCaptureAssertions")||o.C(bag,"strictCaptureNetwork")||o.C(bag,"strictCaptureWebSocket"))&&(strictCapture={assertions:!!bag.strictCaptureAssertions,network:!!bag.strictCaptureNetwork,websocket:!!bag.strictCaptureWebSocket})}else observeSel=typeof observe=="string"?observe:void 0,eventsOpt=events,timeoutsOpt=timeouts;const defaultEvents=["click","mouseover","scroll","input","change","submit","keydown","focus","blur"],defaultStepDelays={click:100,mouseover:50,scroll:30,input:50,change:50,submit:100,keydown:50,focus:50,blur:50},listenEvents=eventsOpt||defaultEvents,stepDelays=Object.assign({},defaultStepDelays,timeoutsOpt||{}),captureDebounce={scroll:30,mouseover:50,keydown:50,focus:50,blur:50},rec=o.recorder;rec.active=!0,rec.actions=[],rec.mocks={},rec.stepDelays=stepDelays,rec.initialData={url:window.location.href,timestamp:Date.now()},rec.strictCapture=strictCapture,rec.observeRoot=observeSel||null,rec.assertions=[],rec.removedElements=[],o.inits.forEach((inst,idx)=>{inst?.store&&(rec.initialData["init_"+idx]=JSON.parse(JSON.stringify(inst.store)))}),rec._originalFetch=window.fetch,window.fetch=async(url,opts={})=>{const method=(opts.method||"GET").toUpperCase();let reqBody;try{reqBody=opts.body?JSON.parse(opts.body):void 0}catch{reqBody=opts.body}const response=await rec._originalFetch(url,opts),clone=response.clone();let respBody;try{respBody=await clone.json()}catch{respBody=await clone.text().catch(()=>null)}const key=method+":"+url;return rec.mocks[key]={url,method,request:reqBody,response:respBody,status:response.status},response},rec._originalXHROpen=XMLHttpRequest.prototype.open,rec._originalXHRSend=XMLHttpRequest.prototype.send,XMLHttpRequest.prototype.open=function(method,url){return this._oMethod=(method||"GET").toUpperCase(),this._oUrl=url,rec._originalXHROpen.apply(this,arguments)},XMLHttpRequest.prototype.send=function(body){const capture=()=>{if(this.readyState!==4)return;let reqBody;try{reqBody=body?JSON.parse(body):void 0}catch{reqBody=body}let respBody;try{const text=this.responseText;respBody=text?JSON.parse(text):null}catch{respBody=this.responseText??null}const key=(this._oMethod||"GET")+":"+(this._oUrl||"");rec.mocks[key]={url:this._oUrl,method:this._oMethod,request:reqBody,response:respBody,status:this.status}};return this.addEventListener("readystatechange",capture),rec._originalXHRSend.apply(this,arguments)},rec.websocketEvents=[],rec._originalWebSocket=window.WebSocket,window.WebSocket=function(url,protocols){const ws=new rec._originalWebSocket(url,protocols),id=rec.websocketEvents.length;rec.websocketEvents.push({url:typeof url=="string"?url:String(url),protocol:Array.isArray(protocols)?protocols[0]:protocols,open:!0,messages:[]}),ws.addEventListener("message",e=>{const data=typeof e.data=="string"?e.data:String(e.data);rec.websocketEvents[id].messages.push({dir:"in",data})}),ws.addEventListener("close",()=>{rec.websocketEvents[id].open=!1});const origSend=ws.send.bind(ws);return ws.send=function(data){const d=typeof data=="string"?data:String(data);return rec.websocketEvents[id].messages.push({dir:"out",data:d}),origSend(data)},ws};const unstableDataAttrs={"data-o-init":1,"data-o-init-i":1,"data-o-state":1},qualify=(sel,fromNode)=>{if(o.D.querySelectorAll(sel).length<=1)return sel;let node=fromNode;for(;node&&node!==o.D.body;){let ancestorSel=node.id?"#"+node.id:null;if(!ancestorSel&&node.attributes){const autotagAttr=o.autotag?"data-"+o.autotag:null;if(autotagAttr){const val=node.getAttribute(autotagAttr);val!=null&&(ancestorSel=`[${autotagAttr}="${val}"]`)}if(!ancestorSel){for(const attr of node.attributes)if(attr.name.startsWith("data-")&&!unstableDataAttrs[attr.name]){ancestorSel=`[${attr.name}="${attr.value}"]`;break}}}if(ancestorSel){const q=ancestorSel+" "+sel;if(o.D.querySelectorAll(q).length===1)return q}node=node.parentElement}return sel},buildSelector=node=>{if(!node||node.nodeType!==1)return"";let sel="";if(node.dataset){const qaKey=o.autotag&&node.dataset[o.autotag];qaKey&&(sel=qualify(`[data-${o.autotag}="${qaKey}"]`,node.parentElement))}if(!sel&&node.tagName){const base=node.id?"#"+node.id:node.className?node.tagName.toLowerCase()+"."+[...node.classList].join("."):node.tagName.toLowerCase();sel=node.id?base:qualify(base,node.parentElement)}return sel},observeTarget=observeSel&&o.D.querySelector(observeSel)||o.D.body;rec._observer=new MutationObserver(mutations=>{const actionIdx=rec.actions.length-1;if(actionIdx<0)return;const lastAction=rec.actions[actionIdx];o.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[recording] MutationObserver batch:",{actionIdx,lastAction:lastAction?{type:lastAction.type,target:lastAction.target}:null,mutationTypes:mutations.map(x=>x.type),addedCount:mutations.reduce((n,x)=>n+(x.addedNodes?.length||0),0),removedCount:mutations.reduce((n,x)=>n+(x.removedNodes?.length||0),0)}),mutations.forEach(m=>{const addAssertionIndex=(sel,node)=>{let listSelector,index;if(sel&&observeTarget){const matches=observeTarget.querySelectorAll(sel);if(matches.length>1){const idxAmong=[...matches].indexOf(node);if(idxAmong!==-1)listSelector=sel,index=idxAmong;else{let n=node;for(;n&&n!==observeTarget&&n.nodeType===1;){const qaAttr=o.autotag&&n.dataset&&n.dataset[o.autotag];if(qaAttr){const itemSel=`[data-${o.autotag}="${qaAttr}"]`,itemMatches=observeTarget.querySelectorAll(itemSel);if(itemMatches.length>1){const idx=[...itemMatches].indexOf(n);if(idx!==-1){listSelector=itemSel,index=idx;break}}}n=n.parentElement}}}}return{listSelector,index}};if(m.type==="childList"&&(m.addedNodes.forEach(node=>{if(node.nodeType!==1||!node.offsetParent)return;const sel=buildSelector(node);if(!sel||rec.assertions.some(a2=>a2.actionIdx===actionIdx&&a2.selector===sel&&a2.type==="visible"))return;const text=(node.textContent?.trim()||"").slice(0,80)||void 0,{listSelector:aListSel,index:aIdx}=addAssertionIndex(sel,node),a={actionIdx,type:"visible",selector:sel,text};aListSel!=null&&(a.listSelector=aListSel),aIdx!=null&&(a.index=aIdx),rec.assertions.push(a),o.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[recording] +visible assertion:",{actionIdx,lastAction:lastAction?.type+" "+lastAction?.target,selector:sel,text:(text||"").slice(0,40),index:aIdx,listSelector:aListSel})}),m.removedNodes.forEach(node=>{if(node.nodeType!==1)return;const sel=buildSelector(node);if(!sel)return;const text=(node.textContent?.trim()||"").slice(0,80)||void 0,parent=m.target;let index;node.previousSibling?index=Array.from(parent.children).indexOf(node.previousSibling)+1:node.nextSibling?index=Array.from(parent.children).indexOf(node.nextSibling):index=0;let listSelector;if(o.autotag&&node.dataset?.[o.autotag]){const qaVal=node.dataset[o.autotag];listSelector=`[data-${o.autotag}="${qaVal}"]`}const entry={actionIdx,type:"removed",selector:sel,text};listSelector&&(entry.listSelector=listSelector),entry.index=index,rec.removedElements.push(entry),o.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[recording] +removed element:",{actionIdx,lastAction:lastAction?.type+" "+lastAction?.target,selector:sel,text:(text||"").slice(0,40),index,listSelector})})),m.type==="attributes"){const attr=m.attributeName;if(!attr)return;const sel=buildSelector(m.target);if(!sel)return;const type={class:"class",style:"style",hidden:"hidden",disabled:"disabled","aria-expanded":"aria-expanded","aria-checked":"aria-checked"}[attr];if(!type||rec.assertions.some(a2=>a2.actionIdx===actionIdx&&a2.selector===sel&&a2.type===type))return;const{listSelector:aListSel,index:aIdx}=addAssertionIndex(sel,m.target),el=m.target;let value;type==="class"?value=el.className:type==="style"?value=el.style?.cssText||el.getAttribute("style")||"":type==="hidden"?value=el.hidden:type==="disabled"?value=el.disabled===!0:type==="aria-expanded"?value=el.getAttribute("aria-expanded"):type==="aria-checked"&&(value=el.getAttribute("aria-checked"));const a={actionIdx,type,selector:sel};type==="class"?a.className=value:type==="style"?a.style=value:type==="hidden"?a.hidden=value:type==="disabled"?a.disabled=value:type==="aria-expanded"?a.ariaExpanded=value:type==="aria-checked"&&(a.ariaChecked=value),aListSel!=null&&(a.listSelector=aListSel),aIdx!=null&&(a.index=aIdx),rec.assertions.push(a),o.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[recording] +attr assertion:",{actionIdx,lastAction:lastAction?.type+" "+lastAction?.target,selector:sel,type,value,index:aIdx,listSelector:aListSel})}})}),rec._observer.observe(observeTarget,{childList:!0,subtree:!0,attributes:!0,attributeFilter:["class","style","hidden","disabled","aria-expanded","aria-checked"]});const timers={};listenEvents.forEach(ev=>{const handler=e=>{const target=e.target;if(observeSel&&observeTarget&&target?.nodeType===1&&!observeTarget.contains(target))return;let selector="";if(target?.dataset){const qaKey=o.autotag&&target.dataset[o.autotag];qaKey&&(selector=qualify(`[data-${o.autotag}="${qaKey}"]`,target.parentElement))}if(!selector&&target?.tagName){const base=target.id?"#"+target.id:target.className?target.tagName.toLowerCase()+"."+[...target.classList].join("."):target.tagName.toLowerCase();selector=target.id?base:qualify(base,target.parentElement)}let listSelector,targetIndex;if(selector&&observeTarget){const matches=observeTarget.querySelectorAll(selector);if(matches.length>1){const idxAmongMatches=[...matches].indexOf(target);if(idxAmongMatches!==-1)listSelector=selector,targetIndex=idxAmongMatches;else{let node=target;for(;node&&node!==observeTarget&&node.nodeType===1;){const qaAttr=o.autotag&&node.dataset&&node.dataset[o.autotag];if(qaAttr){const itemSel=`[data-${o.autotag}="${qaAttr}"]`,itemMatches=observeTarget.querySelectorAll(itemSel);if(itemMatches.length>1){const idx=[...itemMatches].indexOf(node);if(idx!==-1){listSelector=itemSel,targetIndex=idx;break}}}node=node.parentElement}}}}const targetType=target?.tagName?target.tagName.toLowerCase()+(target.type?":"+target.type:""):void 0,scrollY=ev==="scroll"?window.scrollY:void 0,value=ev==="input"||ev==="change"?target?.value:void 0,checked=ev==="change"&&(target?.type==="checkbox"||target?.type==="radio")?target?.checked:void 0,key=ev==="keydown"?target?.key:void 0,code=ev==="keydown"?target?.code:void 0,delay=ev==="click"||ev==="change"||ev==="submit"?0:stepDelays[ev]!==void 0?stepDelays[ev]:captureDebounce[ev]??0,pushAction=()=>{if((ev==="blur"||ev==="focus")&&selector){const lastIdx=rec.actions.length-1,lastAction=lastIdx>=0?rec.actions[lastIdx]:null;if(lastAction){if(lastAction.target===selector&&lastAction.listSelector==null==(listSelector==null)&&lastAction.targetIndex==null==(targetIndex==null)&&(lastAction.targetIndex==null||lastAction.targetIndex===targetIndex))return;for(const r of rec.removedElements)if(r.actionIdx===lastIdx&&(r.selector===selector||selector.startsWith(r.selector+" ")||selector.startsWith(r.selector+">")))return}}const action={type:ev,target:selector,time:Date.now()};targetType&&(action.targetType=targetType),scrollY!==void 0&&(action.scrollY=scrollY),value!==void 0&&(action.value=value),checked!==void 0&&(action.checked=checked),key!==void 0&&(action.key=key),code!==void 0&&(action.code=code),listSelector!=null&&(action.listSelector=listSelector),targetIndex!=null&&(action.targetIndex=targetIndex),rec.actions.push(action)};delay===0?pushAction():(clearTimeout(timers[ev]),timers[ev]=setTimeout(pushAction,delay))};o.D.addEventListener(ev,handler,!0),rec._listeners.push({ev,handler})})},o.stopRecording=()=>{const rec=o.recorder;rec.active=!1,rec._originalFetch&&(window.fetch=rec._originalFetch,rec._originalFetch=null),rec._originalXHROpen&&(XMLHttpRequest.prototype.open=rec._originalXHROpen,XMLHttpRequest.prototype.send=rec._originalXHRSend,rec._originalXHROpen=null,rec._originalXHRSend=null),rec._originalWebSocket&&(window.WebSocket=rec._originalWebSocket,rec._originalWebSocket=null),rec._listeners.forEach(({ev,handler})=>{o.D.removeEventListener(ev,handler,!0)}),rec._listeners=[],rec._observer&&(rec._observer.disconnect(),rec._observer=null);const out={actions:[...rec.actions],mocks:{...rec.mocks},initialData:{...rec.initialData},stepDelays:{...rec.stepDelays},assertions:[...rec.assertions||[]],removedElements:[...rec.removedElements||[]],observeRoot:rec.observeRoot||null,websocketEvents:[...rec.websocketEvents||[]]};return rec.strictCapture&&(out.strictCapture={...rec.strictCapture}),out},o.clearRecording=id=>{if(id!==void 0)sessionStorage?.removeItem("oTest-Recording-"+id);else for(let i=sessionStorage?.length-1;i>=0;i--){const key=sessionStorage?.key(i);key&&key.indexOf("oTest-Recording-")===0&&sessionStorage?.removeItem(key)}},o.runRecordingAssertions=(recording,root,actionIdx,opts)=>{const strictAssertions=!!(opts&&opts.strictAssertions),strictRemoved=opts&&opts.strictRemoved!==void 0?!!opts.strictRemoved:strictAssertions,preFiltered=opts&&opts.assertions,assertions=preFiltered??(recording.assertions||[]).filter(a=>actionIdx==null||a.actionIdx===actionIdx);o.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[runRecordingAssertions] run:",{actionIdx,scope:actionIdx==null?"teardown (all)":"per-action",assertionsCount:assertions.length,assertions:assertions.map(a=>({actionIdx:a.actionIdx,type:a.type,selector:a.selector,index:a.index,text:(a.text||"").slice(0,40)}))});const seen=new Set,deduped=assertions.filter(a=>{const key=`${a.selector}|${a.type}|${a.actionIdx}|${a.index??""}`;return seen.has(key)?!1:(seen.add(key),!0)}),r=(()=>{if(root!=null)return typeof root=="string"?o.D.querySelector(root)||o.D.body:root;const sel=recording.observeRoot;return sel&&o.D.querySelector(sel)||o.D.body})(),norm=s=>(s||"").trim().replace(/\s+/g," "),styleNorm=s=>norm(String(s||"").replace(/\s*:\s*/g,": ").replace(/\s*;\s*/g,"; ")),getText=el=>el?norm(el.textContent||""):"",removedElements=opts?.removedElements||[],isRemoved=a=>{if(!removedElements.length||actionIdx==null)return!1;const expText=norm(a.text||"");for(const r2 of removedElements)if(!(r2.actionIdx>actionIdx)&&norm(r2.text||"")===expText&&r2.selector===a.selector&&!(a.listSelector!=null&&r2.listSelector!==a.listSelector)&&!(a.index!=null&&r2.index!==a.index))return!0;return!1};let passed=0;const failures=[];for(const a of deduped){if(isRemoved(a)){if(!strictRemoved){passed+=1,o.recordingAssertionDebug&&typeof console<"u"&&console.log&&console.log("[runRecordingAssertions] skip (explicit removed):",{actionIdx:a.actionIdx,selector:a.selector,text:(a.text||"").slice(0,40)});continue}let ghost=null;const expText=norm(a.text||"");if(a.listSelector!=null&&a.index!=null){const items=r.querySelectorAll(a.listSelector);let item=items[a.index];if(!item&&a.index>0&&(item=items[a.index-1]),item&&(ghost=a.selector!==a.listSelector&&item.querySelector(a.selector)||item),!ghost&&expText&&a.type==="visible")for(let j=0;j<items.length;j++){const it=items[j],cand=a.selector!==a.listSelector&&it.querySelector(a.selector)||it;if(cand&&getText(cand).indexOf(expText)!==-1){ghost=cand;break}}}else{const matches=r.querySelectorAll(a.selector);ghost=matches.length>0?matches[0]:o.D.querySelector(a.selector)}if(ghost&&a.type==="visible"){const vis=ghost.nodeType===1&&(ghost.offsetParent!==null||ghost.getBoundingClientRect&&ghost.getBoundingClientRect().width>0),gtext=getText(ghost);if(vis&&(!expText||gtext.indexOf(expText)!==-1||expText.indexOf(gtext)!==-1)){failures.push({selector:a.selector,message:"expected absent (recorded removed) but matching content still visible"});continue}}else if(ghost&&a.type!=="visible"){failures.push({selector:a.selector,message:"expected absent (recorded removed) but element still present"});continue}passed+=1;continue}let el=null,indexOutOfBounds=!1,listItemsLength=-1;if(a.listSelector!=null&&a.index!=null){const items=r.querySelectorAll(a.listSelector);listItemsLength=items.length;const expectedText=norm(a.text||""),tryItem=idx=>{const it=items[idx];return it?(a.selector!==a.listSelector?it.querySelector(a.selector):it)||(a.selector!==a.listSelector?it:null):null};let item;if(strictAssertions)item=items[a.index],item&&(el=tryItem(a.index),!el&&a.selector!==a.listSelector&&(el=item));else if(item=items[a.index],!item&&a.index>0&&(item=items[a.index-1]),item&&(el=tryItem(a.index)||(a.index>0?tryItem(a.index-1):null),!el&&a.selector!==a.listSelector&&(el=item),a.type==="visible"&&expectedText&&el)){const actualText=getText(el);if(actualText.indexOf(expectedText)===-1&&expectedText.indexOf(actualText)===-1)for(let j=0;j<items.length;j++){const candEl=tryItem(j);if(candEl&&getText(candEl).indexOf(expectedText)!==-1){el=candEl,item=items[j];break}}}item||(indexOutOfBounds=!0)}else{const matches=r.querySelectorAll(a.selector);el=matches.length>0?matches[0]:o.D.querySelector(a.selector)}if(a.type==="visible"){const visible=el&&el.nodeType===1&&(el.offsetParent!==null||el.getBoundingClientRect&&el.getBoundingClientRect().width>0),expectedText=norm(a.text||""),actualText=getText(el),textOk=strictAssertions?!expectedText||actualText===expectedText:!expectedText||actualText.indexOf(expectedText)!==-1||expectedText.length>0&&expectedText.indexOf(actualText)!==-1;if(visible&&textOk)passed+=1;else{const listCount=listItemsLength>=0?listItemsLength:r.querySelectorAll(a.listSelector||a.selector).length,message=indexOutOfBounds?`index out of bounds (list has ${listCount} items, assertion expected index ${a.index})`:el?visible?textOk?"fail":"text mismatch":"not visible":"element not found";failures.push({selector:a.selector,message}),typeof console<"u"&&console.warn&&console.warn("[runRecordingAssertions] visible failed:",{actionIdx:a.actionIdx,selector:a.selector,listSelector:a.listSelector,index:a.index,expectedText:a.text||"(any)",actualText:actualText.slice(0,80),message})}}else if(a.type==="class"){const tokens=(a.className||"").trim().split(/\s+/).filter(Boolean),hasClass=el&&(tokens.length===0||tokens.every(c=>el.classList?.contains(c))),classOrderOk=!strictAssertions||!a.className||norm((el?.className||"").trim())===norm((a.className||"").trim());if(hasClass&&classOrderOk)passed+=1;else{const msg=indexOutOfBounds?`index out of bounds (list has ${r.querySelectorAll(a.listSelector).length} items, expected index ${a.index})`:el?hasClass&&!classOrderOk?`expected exact className "${a.className}" (strict)`:`expected class "${a.className}"`:"element not found";failures.push({selector:a.selector,message:msg}),typeof console<"u"&&console.warn&&console.warn("[runRecordingAssertions] failed:",{type:a.type,selector:a.selector,actionIdx:a.actionIdx,listSelector:a.listSelector,index:a.index,itemsInRoot:a.listSelector?r.querySelectorAll(a.listSelector).length:"-",message:msg})}}else if(a.type==="style"){const expected=(a.style||"").trim(),actual=(el?.style?.cssText||el?.getAttribute?.("style")||"").trim();if(el&&(!expected||(strictAssertions?styleNorm(actual)===styleNorm(expected):actual.indexOf(expected)!==-1||expected===actual)))passed+=1;else{const msg=el?`expected style "${expected.slice(0,60)}..."`:"element not found";failures.push({selector:a.selector,message:msg})}}else if(a.type==="hidden")if(el&&el.hidden===a.hidden)passed+=1;else{const msg=el?`expected hidden=${a.hidden}`:"element not found";failures.push({selector:a.selector,message:msg})}else if(a.type==="disabled")if(el&&el.disabled===a.disabled)passed+=1;else{const msg=el?`expected disabled=${a.disabled}`:"element not found";failures.push({selector:a.selector,message:msg})}else if(a.type==="aria-expanded"){const actual=el?.getAttribute?.("aria-expanded");if(el&&(a.ariaExpanded==null||String(actual)===String(a.ariaExpanded)))passed+=1;else{const msg=el?`expected aria-expanded="${a.ariaExpanded}"`:"element not found";failures.push({selector:a.selector,message:msg})}}else if(a.type==="aria-checked"){const actual=el?.getAttribute?.("aria-checked");if(el&&(a.ariaChecked==null||String(actual)===String(a.ariaChecked)))passed+=1;else{const msg=el?`expected aria-checked="${a.ariaChecked}"`:"element not found";failures.push({selector:a.selector,message:msg})}}}return{passed,total:deduped.length,failures}},o.exportTest=(recording,options={})=>{const delay=options.delay!==void 0?options.delay:16,extensionExport=options.extensionExport===!0,recordingData={actions:recording.actions,assertions:recording.assertions||[],observeRoot:recording.observeRoot||null},rootVar=recording.observeRoot?`(o.D.querySelector('${recording.observeRoot.replace(/'/g,"\\'")}') || o.D.body)`:"o.D.body",getEl=a=>{if(a.listSelector!=null&&a.targetIndex!=null){const listSel=JSON.stringify(a.listSelector),useItem=a.target===a.listSelector,targetSel=useItem?listSel:JSON.stringify(a.target);return` const items = o.D.querySelectorAll(${listSel});
|
|
17
|
+
const item = items[${a.targetIndex}];
|
|
18
18
|
let el = null;
|
|
19
|
-
if (item) { el = ${
|
|
20
|
-
await o.sleep(${
|
|
19
|
+
if (item) { el = ${useItem?"item":`item.querySelector(${targetSel}) || item`}; }`}return` const el = o.D.querySelector(${JSON.stringify(a.target)});`},endSuffix=delay>0?`
|
|
20
|
+
await o.sleep(${delay});
|
|
21
21
|
return true;
|
|
22
22
|
`:` return true;
|
|
23
|
-
`,
|
|
24
|
-
`:"")+(
|
|
25
|
-
`:"")+` el.dispatchEvent(new Event('${
|
|
26
|
-
`+
|
|
27
|
-
if (!el && '${
|
|
28
|
-
`+
|
|
29
|
-
const r = o.runRecordingAssertions(recordingData, ${
|
|
23
|
+
`,stepFn=delay>0?"async () =>":"() =>",steps=[];for(let i=0;i<recording.actions.length;i++){const a=recording.actions[i];let body;a.type==="scroll"?body=` window.scrollTo(0, ${a.scrollY||0});${endSuffix}`:a.type==="input"||a.type==="change"?body=(a.value!==void 0?` el.value = ${JSON.stringify(a.value)};
|
|
24
|
+
`:"")+(a.checked!==void 0?` el.checked = ${a.checked};
|
|
25
|
+
`:"")+` el.dispatchEvent(new Event('${a.type}', {bubbles:true}));${endSuffix}`:a.type==="submit"?body=` (el.requestSubmit && el.requestSubmit()) || el.submit();${endSuffix}`:a.type==="keydown"?body=` el.dispatchEvent(new KeyboardEvent('keydown', {key:${JSON.stringify(a.key||"")}, code:${JSON.stringify(a.code||"")}, bubbles:true, cancelable:true}));${endSuffix}`:a.type==="focus"?body=` el.focus();${endSuffix}`:a.type==="blur"?body=` el.blur();${endSuffix}`:body=a.type==="click"?` el.click();${endSuffix}`:` el.dispatchEvent(new MouseEvent('${a.type}', {bubbles:true,cancelable:true}));${endSuffix}`;const skipIfMissing=a.type==="blur"||a.type==="focus";steps.push(` ['${a.type} on ${a.target}', ${stepFn} {
|
|
26
|
+
`+getEl(a)+`
|
|
27
|
+
if (!el && '${a.type}' !== 'scroll') { if (${skipIfMissing}) return true; return 'element not found: ${a.target.replace(/'/g,"\\'")}'; }
|
|
28
|
+
`+body+" }]"),(recording.assertions||[]).filter(x=>x.actionIdx===i).length>0&&steps.push(` ['assert after ${a.type}', () => {
|
|
29
|
+
const r = o.runRecordingAssertions(recordingData, ${rootVar}, ${i});
|
|
30
30
|
return r.passed === r.total ? true : r.failures.map(f => f.selector + ': ' + f.message).join('; ');
|
|
31
|
-
}]`)}const
|
|
32
|
-
const recordingMocks = ${Object.keys(
|
|
33
|
-
const recordingData = { actions: ${JSON.stringify(
|
|
31
|
+
}]`)}const header=`// Auto-generated by o.exportTest() \u2014 review and anonymize mocks before committing
|
|
32
|
+
const recordingMocks = ${Object.keys(recording.mocks||{}).length?JSON.stringify(recording.mocks,null,2):"{}"};
|
|
33
|
+
const recordingData = { actions: ${JSON.stringify(recording.actions)}, assertions: ${JSON.stringify(recording.assertions||[])}, observeRoot: ${JSON.stringify(recording.observeRoot||null)} };
|
|
34
34
|
|
|
35
|
-
|
|
36
|
-
${
|
|
35
|
+
`,manualLine=" // Add manual checks: ['Manual: label', () => o.testConfirm('label', ['item1'])],";return extensionExport?header+`const __objsExtensionTestRun = o.test('Recorded test',
|
|
36
|
+
${steps.join(`,
|
|
37
37
|
`)},
|
|
38
|
-
${
|
|
38
|
+
${manualLine}
|
|
39
39
|
{ sync: true }, () => {
|
|
40
40
|
// teardown
|
|
41
41
|
});
|
|
42
|
-
`:
|
|
43
|
-
${
|
|
42
|
+
`:header+`o.addTest('Recorded test', [
|
|
43
|
+
${steps.join(`,
|
|
44
44
|
`)}
|
|
45
|
-
${
|
|
45
|
+
${manualLine}
|
|
46
46
|
], () => {
|
|
47
47
|
// teardown
|
|
48
48
|
});
|
|
49
|
-
`},
|
|
50
|
-
`;return
|
|
49
|
+
`},o.exportPlaywrightTest=(recording,options={})=>{const testName=options.testName||"Recorded session",rawUrl=recording.initialData?.url??"/";let path="/";try{path=new URL(rawUrl).pathname||"/"}catch{path=rawUrl}const baseUrl=options.baseUrl||path,routes=Object.values(recording.mocks).map(mock=>{let urlPath=mock.url;try{urlPath=new URL(mock.url).pathname||urlPath}catch{}urlPath.startsWith("/")||(urlPath="/"+urlPath);const respBody=JSON.stringify(mock.response),reqBody=JSON.stringify(mock.request),method=(mock.method||"GET").toUpperCase();let verify=` if (route.request().method() !== ${JSON.stringify(method)}) { await route.continue(); return; }
|
|
50
|
+
`;return mock.request!=null&&(method==="POST"||method==="PUT"||method==="PATCH")&&(verify+=` const postData = route.request().postData();
|
|
51
51
|
const body = (() => { try { return JSON.parse(postData || '{}'); } catch { return {}; } })();
|
|
52
|
-
expect(body).toEqual(${
|
|
53
|
-
`),` await page.route('**${
|
|
54
|
-
`+
|
|
55
|
-
body: JSON.stringify(${
|
|
52
|
+
expect(body).toEqual(${reqBody});
|
|
53
|
+
`),` await page.route('**${urlPath}', async route => {
|
|
54
|
+
`+verify+` await route.fulfill({ status: ${mock.status||200}, contentType: 'application/json',
|
|
55
|
+
body: JSON.stringify(${respBody}) });
|
|
56
56
|
});`}).join(`
|
|
57
|
-
`),
|
|
57
|
+
`),sd=Object.assign({click:100,mouseover:50,scroll:30,input:50,change:50,submit:100,keydown:50,focus:50,blur:50},recording.stepDelays||{}),steps=recording.actions.map((action,i)=>{const loc=action.listSelector!=null&&action.targetIndex!=null?action.target!==action.listSelector?`page.locator(${JSON.stringify(action.listSelector)}).nth(${action.targetIndex}).locator(${JSON.stringify(action.target)})`:`page.locator(${JSON.stringify(action.listSelector)}).nth(${action.targetIndex})`:`page.locator(${JSON.stringify(action.target)})`,wait=` await page.waitForTimeout(${sd[action.type]||50});`;let step;if(action.type==="scroll")step=` await page.evaluate(() => window.scrollTo(0, ${action.scrollY||0}));`;else if(action.type==="mouseover")step=` await ${loc}.hover();
|
|
58
58
|
// Pure CSS :hover \u2014 no DOM mutation to assert.
|
|
59
|
-
// Fix: toggle a class in a mouseover handler, or add a page.screenshot() visual check.`;else if(
|
|
60
|
-
await expect(${
|
|
61
|
-
`):` // class on ${
|
|
62
|
-
`);return
|
|
63
|
-
`+
|
|
64
|
-
`+
|
|
65
|
-
`),
|
|
59
|
+
// Fix: toggle a class in a mouseover handler, or add a page.screenshot() visual check.`;else if(action.type==="input")step=` await ${loc}.fill(${JSON.stringify(action.value||"")});`;else if(action.type==="change"){const tt=action.targetType||"";if(tt.indexOf(":checkbox")!==-1||tt.indexOf(":radio")!==-1){const on=action.checked!==void 0?action.checked:action.value==="true"||action.value==="on";step=` await ${loc}.${on?"check":"uncheck"}();`}else tt.indexOf("select")!==-1?step=` await ${loc}.selectOption(${JSON.stringify(action.value||"")});`:step=` await ${loc}.fill(${JSON.stringify(action.value||"")});`}else if(action.type==="submit")step=` await ${loc}.evaluate((el) => el.requestSubmit?.() || el.submit());`;else if(action.type==="keydown"){const key=action.key||"";step=key==="Enter"?` await ${loc}.press("Enter");`:key?` await ${loc}.press(${JSON.stringify(key)});`:` await ${loc}.press(${JSON.stringify(action.code||"")});`}else action.type==="focus"?step=` if (await ${loc}.count() > 0) await ${loc}.focus();`:action.type==="blur"?step=` if (await ${loc}.count() > 0) await ${loc}.blur();`:step=` await ${loc}.click();`;const asserts=(recording.assertions||[]).filter(a=>a.actionIdx===i).filter((a,j,arr)=>arr.findIndex(x=>x.selector===a.selector&&x.type===a.type&&x.index===a.index)===j).map(a=>{const aLoc=a.listSelector!=null&&a.index!=null?a.selector!==a.listSelector?`page.locator(${JSON.stringify(a.listSelector)}).nth(${a.index}).locator(${JSON.stringify(a.selector)})`:`page.locator(${JSON.stringify(a.listSelector)}).nth(${a.index})`:`page.locator(${JSON.stringify(a.selector)})`;if(a.type==="visible"){let s=` await expect(${aLoc}).toBeVisible();`;return a.text&&(s+=`
|
|
60
|
+
await expect(${aLoc}).toContainText(${JSON.stringify(a.text)});`),s}if(a.type==="class"){const classes=(a.className||"").trim().split(/\s+/).filter(Boolean);return classes.length>0?classes.map(c=>` await expect(${aLoc}).toHaveClass(${JSON.stringify(c)});`).join(`
|
|
61
|
+
`):` // class on ${a.selector} (no specific classes asserted)`}if(a.type==="style"){const style=(a.style||"").trim();if(style){const m=style.match(/(\w+)\s*:\s*([^;]+)/);return m?` await expect(${aLoc}).toHaveCSS(${JSON.stringify(m[1])}, ${JSON.stringify(m[2].trim())});`:` await expect(${aLoc}).toHaveAttribute("style", ${JSON.stringify(style)});`}return""}return a.type==="hidden"?a.hidden?` await expect(${aLoc}).toBeHidden();`:` await expect(${aLoc}).toBeVisible();`:a.type==="disabled"?a.disabled?` await expect(${aLoc}).toBeDisabled();`:` await expect(${aLoc}).toBeEnabled();`:a.type==="aria-expanded"&&a.ariaExpanded!=null?` await expect(${aLoc}).toHaveAttribute("aria-expanded", ${JSON.stringify(String(a.ariaExpanded))});`:a.type==="aria-checked"&&a.ariaChecked!=null?` await expect(${aLoc}).toHaveAttribute("aria-checked", ${JSON.stringify(String(a.ariaChecked))});`:""}).filter(Boolean).join(`
|
|
62
|
+
`);return step+`
|
|
63
|
+
`+wait+(asserts?`
|
|
64
|
+
`+asserts:"")}).join(`
|
|
65
|
+
`),hasAutoAssertions=(recording.assertions||[]).length>0,wsEvents=recording.websocketEvents||[],hasWsEvents=wsEvents.length>0&&wsEvents.some(c=>c.messages?.length>0),wsSetup=hasWsEvents?` const wsCollected = [];
|
|
66
66
|
page.on('websocket', ws => {
|
|
67
67
|
ws.on('framereceived', ev => wsCollected.push({ dir: 'in', payload: typeof ev.payload === 'string' ? ev.payload : String(ev.payload) }));
|
|
68
68
|
ws.on('framesent', ev => wsCollected.push({ dir: 'out', payload: typeof ev.payload === 'string' ? ev.payload : String(ev.payload) }));
|
|
69
69
|
});
|
|
70
70
|
|
|
71
|
-
`:"",
|
|
71
|
+
`:"",wsAssertions=hasWsEvents?wsEvents.flatMap(conn=>(conn.messages||[]).map(msg=>({dir:msg.dir,data:msg.data}))).map(msg=>` expect(wsCollected).toContainEqual({ dir: ${JSON.stringify(msg.dir)}, payload: ${JSON.stringify(msg.data)} });`).join(`
|
|
72
72
|
`)+`
|
|
73
73
|
|
|
74
74
|
`:"";return`// Auto-generated by o.exportPlaywrightTest() \u2014 review and anonymize mocks before committing
|
|
@@ -76,26 +76,26 @@ ${$}
|
|
|
76
76
|
// Run: npx playwright test recorded.spec.ts
|
|
77
77
|
import { test, expect } from '@playwright/test';
|
|
78
78
|
|
|
79
|
-
test(${JSON.stringify(
|
|
80
|
-
`+(
|
|
81
|
-
`+
|
|
79
|
+
test(${JSON.stringify(testName)}, async ({ page }) => {
|
|
80
|
+
`+(routes?` // Network mocks \u2014 edit/anonymize before committing
|
|
81
|
+
`+routes+`
|
|
82
82
|
|
|
83
|
-
`:"")
|
|
84
|
-
await page.goto(${JSON.stringify(
|
|
83
|
+
`:"")+wsSetup+` // Set baseURL in playwright.config.ts: { use: { baseURL: 'https://staging.example.com' } }
|
|
84
|
+
await page.goto(${JSON.stringify(baseUrl)});
|
|
85
85
|
|
|
86
|
-
`+(
|
|
86
|
+
`+(steps?steps+`
|
|
87
87
|
|
|
88
|
-
`:"")+(
|
|
89
|
-
`+
|
|
88
|
+
`:"")+(wsAssertions?` // WebSocket verifications
|
|
89
|
+
`+wsAssertions:"")+(!hasAutoAssertions&&!hasWsEvents?` // TODO: Add assertions before committing, e.g.:
|
|
90
90
|
// await expect(page.locator('[data-qa="success-panel"]')).toBeVisible();
|
|
91
91
|
// await expect(page).toHaveURL(/\\/confirmation/);
|
|
92
92
|
// await expect(page.locator('[data-qa="error-banner"]')).not.toBeVisible();
|
|
93
|
-
`:
|
|
93
|
+
`:hasAutoAssertions||hasWsEvents?` // Auto-generated assertions above \u2014 review for correctness before committing
|
|
94
94
|
`:"")+`});
|
|
95
|
-
`},t.playRecording=(n,e={})=>{const i=e&&typeof e=="object"&&(e.runAssertions!==void 0||e.root!==void 0||e.manualChecks!==void 0||e.actionDelay!==void 0||e.skipWebSocketMock!==void 0||e.skipNetworkMocks!==void 0||e.recordingAssertionDebug!==void 0||e.strictPlay!==void 0||e.strictAssertions!==void 0||e.strictNetwork!==void 0||e.strictWebSocket!==void 0||e.strictRemoved!==void 0||e.onComplete!==void 0),r=i?e.mockOverrides||{}:e,p=i&&e.runAssertions,L=i?e.root:void 0,x=i&&e.manualChecks||[],C=i&&e.actionDelay!==void 0?e.actionDelay:16,_=i&&e.skipWebSocketMock,D=i&&e.skipNetworkMocks;i&&e.recordingAssertionDebug!==void 0&&(t.recordingAssertionDebug=!!e.recordingAssertionDebug);const R=n.strictCapture||{},v=i&&e.strictPlay===!0,$=i&&e.strictAssertions!==void 0?!!e.strictAssertions:v?!0:!!R.assertions,u=i&&e.strictNetwork!==void 0?!!e.strictNetwork:v?!0:!!R.network,f=i&&e.strictWebSocket!==void 0?!!e.strictWebSocket:v?!0:!!R.websocket,j=i&&e.strictRemoved!==void 0?!!e.strictRemoved:$,O=l=>{if(!(l==null||l==="")){if(typeof l=="string")try{return JSON.parse(l)}catch{return l}return l}},I=(l,c)=>{const T=O(c);return l===T||l==null&&T==null?!0:l==null||T==null?!1:typeof l=="object"&&typeof T=="object"?JSON.stringify(l)===JSON.stringify(T):String(l)===String(T)},m=l=>String(l||"").trim().replace(/\s+/g," "),s=Object.assign({},n.mocks,r),d=window.fetch,N=XMLHttpRequest.prototype.open,g=XMLHttpRequest.prototype.send;D||(window.fetch=(l,c={})=>{const k=(c.method||"GET").toUpperCase()+":"+l;if(s[k]){const M=s[k];if(u&&t.C(M,"request")&&!I(M.request,c.body))return Promise.reject(new Error("[Objs playRecording] strictNetwork: request body does not match recording for "+k));const U=typeof M.response=="string"?M.response:JSON.stringify(M.response);return Promise.resolve(new Response(U,{status:M.status||200}))}return d(l,c)},XMLHttpRequest.prototype.open=function(l,c){return this._oMethod=(l||"GET").toUpperCase(),this._oUrl=c,N.apply(this,arguments)},XMLHttpRequest.prototype.send=function(l){const c=this,T=(c._oMethod||"GET")+":"+(c._oUrl||""),k=s[T];if(k){if(u&&t.C(k,"request")&&!I(k.request,l)){setTimeout(()=>{c.readyState=4,c.status=0,c.statusText="Objs strictNetwork mismatch",c.dispatchEvent(new Event("readystatechange")),c.dispatchEvent(new Event("error"))},0);return}const M=typeof k.response=="string"?k.response:JSON.stringify(k.response);setTimeout(()=>{c.readyState=4,c.status=k.status||200,c.statusText="OK",c.responseText=M,c.response=M,c.dispatchEvent(new Event("readystatechange")),c.dispatchEvent(new Event("load"))},0);return}return g.apply(this,arguments)});let y=null;const E=n.websocketEvents||[];if(!_&&E.length>0&&E.some(l=>l.messages&&l.messages.length>0)&&typeof window.WebSocket=="function"){y=window.WebSocket;let l=0;const c=z=>{const J=typeof z=="string"?z:String(z);try{return new URL(J,window.location.href).href}catch{return J}},T=z=>{const J=c(z);for(let H=l;H<E.length;H++)if(c(E[H].url)===J)return l=H+1,E[H];for(let H=l;H<E.length;H++)if(String(E[H].url)===String(z))return l=H+1,E[H];return null},k=y;class M extends EventTarget{constructor(J,H,Y){super();const W=typeof J=="string"?J:String(J);this.url=W,this.readyState=k.CONNECTING;const V=H;this.protocol=Array.isArray(V)?V[0]||"":V?String(V):"",this.extensions="",this.binaryType="blob",this._messages=(Y.messages||[]).slice(),this._pos=0;const X=this;setTimeout(()=>{X.readyState!==k.CLOSED&&(X.readyState=k.OPEN,X._dispatchOpen(),X._drainInbound())},0)}_dispatchOpen(){const J=new Event("open");this.dispatchEvent(J),typeof this.onopen=="function"&&this.onopen(J)}_dispatchMessage(J){const H=new MessageEvent("message",{data:J});this.dispatchEvent(H),typeof this.onmessage=="function"&&this.onmessage(H)}_drainInbound(){for(;this._pos<this._messages.length&&this._messages[this._pos].dir==="in";){const J=this._messages[this._pos++];this._dispatchMessage(J.data)}}send(J){if(this.readyState!==k.OPEN)throw typeof DOMException<"u"?new DOMException("Still in CONNECTING state.","InvalidStateError"):new Error("InvalidStateError");if(this._pos>=this._messages.length){if(f)throw new Error("[Objs playRecording] strictWebSocket: unexpected send() after recorded frames exhausted");this._drainInbound();return}const H=this._messages[this._pos];if(H.dir==="out"){if(f){const Y=typeof J=="string"?J:String(J),W=String(H.data!=null?H.data:"");if(m(Y)!==m(W))throw new Error("[Objs playRecording] strictWebSocket: outbound frame mismatch")}this._pos++}this._drainInbound()}close(J,H){if(this.readyState===k.CLOSING||this.readyState===k.CLOSED)return;this.readyState=k.CLOSING;const Y=this;setTimeout(()=>{Y.readyState=k.CLOSED;const W=typeof CloseEvent<"u"?new CloseEvent("close",{code:J!==void 0?J:1e3,reason:H!==void 0?String(H):"",wasClean:!0}):new Event("close");Y.dispatchEvent(W),typeof Y.onclose=="function"&&Y.onclose(W)},0)}}const U=function(J,H){const Y=typeof J=="string"?J:String(J),W=T(Y);return!W||!W.messages||W.messages.length===0?new y(J,H):new M(J,H,W)};U.CONNECTING=k.CONNECTING,U.OPEN=k.OPEN,U.CLOSING=k.CLOSING,U.CLOSED=k.CLOSED,window.WebSocket=U}const w=()=>{if(L!=null)return typeof L=="string"?t.D.querySelector(L)||t.D.body:L;const l=n.observeRoot;return l&&t.D.querySelector(l)||t.D.body},A=p?w():null,B=L!=null?w():t.D,q=n.actions,F=n.assertions||[],P={};for(const l of F){const c=l.actionIdx;P[c]||(P[c]=[]),P[c].push(l)}if(t.recordingAssertionDebug&&p&&typeof console<"u"&&console.log){const l=q.map((c,T)=>({i:T,action:c.type+" "+(c.target||""),assertions:(P[T]||[]).length,assertionDetails:(P[T]||[]).map(k=>({type:k.type,index:k.index,text:(k.text||"").slice(0,30)}))}));console.log("[playRecording] assertions by action:",l)}const G={};for(const l of x){const c=l.afterAction;G[c]||(G[c]=[]),G[c].push(l)}const o=[];let a={passed:0,total:0,failures:[]};for(let l=0;l<q.length;l++){const c=q[l];o.push([`${c.type} on ${c.target}`,async()=>{let k=null;const M=B;if(c.target)if(c.listSelector!=null&&c.targetIndex!=null){const z=M.querySelectorAll(c.listSelector)[c.targetIndex];z&&(k=c.target!==c.listSelector?z.querySelector(c.target):z,!k&&c.target!==c.listSelector&&(k=z))}else k=M.querySelector(c.target);return!k&&c.type!=="scroll"?c.type==="blur"||c.type==="focus"?!0:`element not found: ${c.target}`:(c.type==="scroll"?window.scrollTo(0,c.scrollY||0):c.type==="input"||c.type==="change"?(c.value!==void 0&&(k.value=c.value),c.checked!==void 0&&(k.checked=c.checked),k.dispatchEvent(new Event(c.type,{bubbles:!0}))):c.type==="submit"?typeof k.requestSubmit=="function"?k.requestSubmit():k.submit():c.type==="keydown"?k.dispatchEvent(new KeyboardEvent("keydown",{key:c.key||"",code:c.code||"",bubbles:!0,cancelable:!0})):c.type==="focus"?k.focus():c.type==="blur"?k.blur():c.type==="click"?k.click():k.dispatchEvent(new MouseEvent(c.type,{bubbles:!0,cancelable:!0})),C>0&&await t.sleep(C),!0)}]);const T=P[l];p&&T&&T.length>0&&o.push([`assert after ${c.type}`,()=>new Promise(k=>{const M=()=>{const U=t.runRecordingAssertions(n,A,l,{assertions:T,removedElements:n.removedElements,strictAssertions:$,strictRemoved:j});a.passed+=U.passed,a.total+=U.total,a.failures.push(...U.failures),k(U.passed===U.total?!0:U.failures.map(z=>z.selector+": "+z.message).join("; "))};requestAnimationFrame(()=>requestAnimationFrame(M))})]);for(const k of G[l]||[])o.push([`Manual: ${k.label}`,()=>typeof t.testConfirm=="function"?t.testConfirm(k.label,k.items||[]):{ok:!0}])}for(const l of G.end||[])o.push([`Manual: ${l.label}`,()=>typeof t.testConfirm=="function"?t.testConfirm(l.label,l.items||[]):{ok:!0}]);const b=i&&e.onComplete,h=t.test("Recorded playback",...o,{sync:!0},l=>{window.fetch=d,XMLHttpRequest.prototype.open=N,XMLHttpRequest.prototype.send=g,y&&(window.WebSocket=y);const c=p&&F.length>0?a:void 0;if(c?.failures?.length>0){t.tRes[l]=!1;const T=c.failures.map(M=>`${M.selector}: ${M.message}`).join("; "),k=t.tStyled?t.tPre+t.tXx+"Assertions failed: "+T+t.tDc:`
|
|
96
|
-
\u2718 Assertions failed: `+
|
|
95
|
+
`},o.playRecording=(recording,opts={})=>{const isOptions=opts&&typeof opts=="object"&&(opts.runAssertions!==void 0||opts.root!==void 0||opts.manualChecks!==void 0||opts.actionDelay!==void 0||opts.skipWebSocketMock!==void 0||opts.skipNetworkMocks!==void 0||opts.recordingAssertionDebug!==void 0||opts.strictPlay!==void 0||opts.strictAssertions!==void 0||opts.strictNetwork!==void 0||opts.strictWebSocket!==void 0||opts.strictRemoved!==void 0||opts.onComplete!==void 0),mockOverrides=isOptions?opts.mockOverrides||{}:opts,runAssertions=isOptions&&opts.runAssertions,rootOpt=isOptions?opts.root:void 0,manualChecks=isOptions&&opts.manualChecks||[],actionDelay=isOptions&&opts.actionDelay!==void 0?opts.actionDelay:16,skipWebSocketMock=isOptions&&opts.skipWebSocketMock,skipNetworkMocks=isOptions&&opts.skipNetworkMocks;isOptions&&opts.recordingAssertionDebug!==void 0&&(o.recordingAssertionDebug=!!opts.recordingAssertionDebug);const sc=recording.strictCapture||{},strictPlay=isOptions&&opts.strictPlay===!0,strictAssertions=isOptions&&opts.strictAssertions!==void 0?!!opts.strictAssertions:strictPlay?!0:!!sc.assertions,strictNetwork=isOptions&&opts.strictNetwork!==void 0?!!opts.strictNetwork:strictPlay?!0:!!sc.network,strictWebSocket=isOptions&&opts.strictWebSocket!==void 0?!!opts.strictWebSocket:strictPlay?!0:!!sc.websocket,strictRemoved=isOptions&&opts.strictRemoved!==void 0?!!opts.strictRemoved:strictAssertions,parseBodyLikeRecorder=body=>{if(!(body==null||body==="")){if(typeof body=="string")try{return JSON.parse(body)}catch{return body}return body}},mockRequestMatchesLive=(recordedReq,liveBody)=>{const live=parseBodyLikeRecorder(liveBody);return recordedReq===live||recordedReq==null&&live==null?!0:recordedReq==null||live==null?!1:typeof recordedReq=="object"&&typeof live=="object"?JSON.stringify(recordedReq)===JSON.stringify(live):String(recordedReq)===String(live)},normWsData=s=>String(s||"").trim().replace(/\s+/g," "),allMocks=Object.assign({},recording.mocks,mockOverrides),origFetch=window.fetch,origXHROpen=XMLHttpRequest.prototype.open,origXHRSend=XMLHttpRequest.prototype.send;skipNetworkMocks||(window.fetch=(url,fetchOpts={})=>{const key=(fetchOpts.method||"GET").toUpperCase()+":"+url;if(allMocks[key]){const mock=allMocks[key];if(strictNetwork&&o.C(mock,"request")&&!mockRequestMatchesLive(mock.request,fetchOpts.body))return Promise.reject(new Error("[Objs playRecording] strictNetwork: request body does not match recording for "+key));const body=typeof mock.response=="string"?mock.response:JSON.stringify(mock.response);return Promise.resolve(new Response(body,{status:mock.status||200}))}return origFetch(url,fetchOpts)},XMLHttpRequest.prototype.open=function(method,url){return this._oMethod=(method||"GET").toUpperCase(),this._oUrl=url,origXHROpen.apply(this,arguments)},XMLHttpRequest.prototype.send=function(body){const xhr=this,key=(xhr._oMethod||"GET")+":"+(xhr._oUrl||""),mock=allMocks[key];if(mock){if(strictNetwork&&o.C(mock,"request")&&!mockRequestMatchesLive(mock.request,body)){setTimeout(()=>{xhr.readyState=4,xhr.status=0,xhr.statusText="Objs strictNetwork mismatch",xhr.dispatchEvent(new Event("readystatechange")),xhr.dispatchEvent(new Event("error"))},0);return}const respBody=typeof mock.response=="string"?mock.response:JSON.stringify(mock.response);setTimeout(()=>{xhr.readyState=4,xhr.status=mock.status||200,xhr.statusText="OK",xhr.responseText=respBody,xhr.response=respBody,xhr.dispatchEvent(new Event("readystatechange")),xhr.dispatchEvent(new Event("load"))},0);return}return origXHRSend.apply(this,arguments)});let origWebSocket=null;const wsEvents=recording.websocketEvents||[];if(!skipWebSocketMock&&wsEvents.length>0&&wsEvents.some(e=>e.messages&&e.messages.length>0)&&typeof window.WebSocket=="function"){origWebSocket=window.WebSocket;let wsConsumeIdx=0;const normalizeWsUrl=u=>{const s=typeof u=="string"?u:String(u);try{return new URL(s,window.location.href).href}catch{return s}},takeNextRecorded=urlStr=>{const norm=normalizeWsUrl(urlStr);for(let i=wsConsumeIdx;i<wsEvents.length;i++)if(normalizeWsUrl(wsEvents[i].url)===norm)return wsConsumeIdx=i+1,wsEvents[i];for(let i=wsConsumeIdx;i<wsEvents.length;i++)if(String(wsEvents[i].url)===String(urlStr))return wsConsumeIdx=i+1,wsEvents[i];return null},C=origWebSocket;class O_MockWebSocket extends EventTarget{constructor(url,protocols,recorded){super();const urlStr=typeof url=="string"?url:String(url);this.url=urlStr,this.readyState=C.CONNECTING;const p=protocols;this.protocol=Array.isArray(p)?p[0]||"":p?String(p):"",this.extensions="",this.binaryType="blob",this._messages=(recorded.messages||[]).slice(),this._pos=0;const self=this;setTimeout(()=>{self.readyState!==C.CLOSED&&(self.readyState=C.OPEN,self._dispatchOpen(),self._drainInbound())},0)}_dispatchOpen(){const ev=new Event("open");this.dispatchEvent(ev),typeof this.onopen=="function"&&this.onopen(ev)}_dispatchMessage(data){const ev=new MessageEvent("message",{data});this.dispatchEvent(ev),typeof this.onmessage=="function"&&this.onmessage(ev)}_drainInbound(){for(;this._pos<this._messages.length&&this._messages[this._pos].dir==="in";){const m=this._messages[this._pos++];this._dispatchMessage(m.data)}}send(data){if(this.readyState!==C.OPEN)throw typeof DOMException<"u"?new DOMException("Still in CONNECTING state.","InvalidStateError"):new Error("InvalidStateError");if(this._pos>=this._messages.length){if(strictWebSocket)throw new Error("[Objs playRecording] strictWebSocket: unexpected send() after recorded frames exhausted");this._drainInbound();return}const next=this._messages[this._pos];if(next.dir==="out"){if(strictWebSocket){const got=typeof data=="string"?data:String(data),exp=String(next.data!=null?next.data:"");if(normWsData(got)!==normWsData(exp))throw new Error("[Objs playRecording] strictWebSocket: outbound frame mismatch")}this._pos++}this._drainInbound()}close(code,reason){if(this.readyState===C.CLOSING||this.readyState===C.CLOSED)return;this.readyState=C.CLOSING;const self=this;setTimeout(()=>{self.readyState=C.CLOSED;const ev=typeof CloseEvent<"u"?new CloseEvent("close",{code:code!==void 0?code:1e3,reason:reason!==void 0?String(reason):"",wasClean:!0}):new Event("close");self.dispatchEvent(ev),typeof self.onclose=="function"&&self.onclose(ev)},0)}}const MockWebSocketCtor=function(url,protocols){const urlStr=typeof url=="string"?url:String(url),rec=takeNextRecorded(urlStr);return!rec||!rec.messages||rec.messages.length===0?new origWebSocket(url,protocols):new O_MockWebSocket(url,protocols,rec)};MockWebSocketCtor.CONNECTING=C.CONNECTING,MockWebSocketCtor.OPEN=C.OPEN,MockWebSocketCtor.CLOSING=C.CLOSING,MockWebSocketCtor.CLOSED=C.CLOSED,window.WebSocket=MockWebSocketCtor}const resolveRoot=()=>{if(rootOpt!=null)return typeof rootOpt=="string"?o.D.querySelector(rootOpt)||o.D.body:rootOpt;const sel=recording.observeRoot;return sel&&o.D.querySelector(sel)||o.D.body},rootEl=runAssertions?resolveRoot():null,actionScope=rootOpt!=null?resolveRoot():o.D,actions=recording.actions,assertions=recording.assertions||[],assertionsByAction={};for(const a of assertions){const k=a.actionIdx;assertionsByAction[k]||(assertionsByAction[k]=[]),assertionsByAction[k].push(a)}if(o.recordingAssertionDebug&&runAssertions&&typeof console<"u"&&console.log){const summary=actions.map((act,i)=>({i,action:act.type+" "+(act.target||""),assertions:(assertionsByAction[i]||[]).length,assertionDetails:(assertionsByAction[i]||[]).map(x=>({type:x.type,index:x.index,text:(x.text||"").slice(0,30)}))}));console.log("[playRecording] assertions by action:",summary)}const manualByAction={};for(const mc of manualChecks){const k=mc.afterAction;manualByAction[k]||(manualByAction[k]=[]),manualByAction[k].push(mc)}const testCases=[];let assertionAccum={passed:0,total:0,failures:[]};for(let i=0;i<actions.length;i++){const action=actions[i];testCases.push([`${action.type} on ${action.target}`,async()=>{let el=null;const scope=actionScope;if(action.target)if(action.listSelector!=null&&action.targetIndex!=null){const item=scope.querySelectorAll(action.listSelector)[action.targetIndex];item&&(el=action.target!==action.listSelector?item.querySelector(action.target):item,!el&&action.target!==action.listSelector&&(el=item))}else el=scope.querySelector(action.target);return!el&&action.type!=="scroll"?action.type==="blur"||action.type==="focus"?!0:`element not found: ${action.target}`:(action.type==="scroll"?window.scrollTo(0,action.scrollY||0):action.type==="input"||action.type==="change"?(action.value!==void 0&&(el.value=action.value),action.checked!==void 0&&(el.checked=action.checked),el.dispatchEvent(new Event(action.type,{bubbles:!0}))):action.type==="submit"?typeof el.requestSubmit=="function"?el.requestSubmit():el.submit():action.type==="keydown"?el.dispatchEvent(new KeyboardEvent("keydown",{key:action.key||"",code:action.code||"",bubbles:!0,cancelable:!0})):action.type==="focus"?el.focus():action.type==="blur"?el.blur():action.type==="click"?el.click():el.dispatchEvent(new MouseEvent(action.type,{bubbles:!0,cancelable:!0})),actionDelay>0&&await o.sleep(actionDelay),!0)}]);const asserted=assertionsByAction[i];runAssertions&&asserted&&asserted.length>0&&testCases.push([`assert after ${action.type}`,()=>new Promise(resolve=>{const run=()=>{const r=o.runRecordingAssertions(recording,rootEl,i,{assertions:asserted,removedElements:recording.removedElements,strictAssertions,strictRemoved});assertionAccum.passed+=r.passed,assertionAccum.total+=r.total,assertionAccum.failures.push(...r.failures),resolve(r.passed===r.total?!0:r.failures.map(f=>f.selector+": "+f.message).join("; "))};requestAnimationFrame(()=>requestAnimationFrame(run))})]);for(const mc of manualByAction[i]||[])testCases.push([`Manual: ${mc.label}`,()=>typeof o.testConfirm=="function"?o.testConfirm(mc.label,mc.items||[]):{ok:!0}])}for(const mc of manualByAction.end||[])testCases.push([`Manual: ${mc.label}`,()=>typeof o.testConfirm=="function"?o.testConfirm(mc.label,mc.items||[]):{ok:!0}]);const onComplete=isOptions&&opts.onComplete,testId=o.test("Recorded playback",...testCases,{sync:!0},testId2=>{window.fetch=origFetch,XMLHttpRequest.prototype.open=origXHROpen,XMLHttpRequest.prototype.send=origXHRSend,origWebSocket&&(window.WebSocket=origWebSocket);const assertionResult=runAssertions&&assertions.length>0?assertionAccum:void 0;if(assertionResult?.failures?.length>0){o.tRes[testId2]=!1;const failLines=assertionResult.failures.map(f=>`${f.selector}: ${f.message}`).join("; "),suffix=o.tStyled?o.tPre+o.tXx+"Assertions failed: "+failLines+o.tDc:`
|
|
96
|
+
\u2718 Assertions failed: `+failLines;o.tLog[testId2]=(o.tLog[testId2]||"")+suffix}typeof onComplete=="function"&&onComplete(assertionResult)});return runAssertions?{testId}:testId},o.testOverlay=()=>{const btnId="o-test-overlay-btn",panelId="o-test-overlay-panel";if(o("#"+btnId).el)return;const scrollId="o-test-overlay-scroll",exportBtnId="o-test-export-objs",copyBtnId="o-test-copy-txt",btnBarStyle="padding:6px 10px;background:#334155;color:#e2e8f0;border:none;border-radius:6px;cursor:pointer;font-size:12px;",buildListPlainText=()=>o.tLog.map((log,i)=>(log!=null&&log!==""?String(log):"Test #"+i)+(o.tRes[i]?" \u2713":" \u2717")).join(`
|
|
97
97
|
|
|
98
|
-
`),
|
|
98
|
+
`),updatePanel=()=>{const scroll=o("#"+scrollId);if(!scroll.el)return;let html="";o.tLog.forEach((log,i)=>{const ok=o.tRes[i];html+=`<div style="margin:2px 0;padding:2px 4px;border-radius:3px;background:${ok?"#14532d":"#450a0a"};color:${ok?"#86efac":"#fca5a5"};font-size:11px;white-space:pre-wrap">${log||"Test #"+i}</div>`}),scroll.html(html)},innerHTML=`<div class="o-test-overlay-root" style="display:flex;flex-direction:column;gap:4px;max-height:min(88vh,560px);overflow:hidden;"><div style="display:flex;align-items:center;gap:12px;flex-shrink:0;"><span class="o-test-overlay-summary" style="flex:1;font-size:13px;cursor:grab;">Tests: 0/0</span><button type="button" class="o-test-overlay-toggle" style="${btnBarStyle}">List</button><button type="button" class="o-test-overlay-close" style="padding:4px 8px;background:transparent;color:#94a3b8;border:none;border-radius:4px;cursor:pointer;font-size:16px;line-height:1;" title="Close">\xD7</button></div><div id="${panelId}" style="display:none;flex-direction:column;margin-top:4px;max-height:min(52vh,420px);background:#0a0f1e;border:1px solid #1e293b;border-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.35);overflow:hidden;"><div id="${scrollId}" style="box-sizing:border-box;height:min(48vh,380px);overflow-y:scroll;padding:8px;font-size:11px;user-select:text;cursor:text;"></div><div id="o-test-overlay-footer" style="display:flex;flex-wrap:wrap;gap:8px;padding:8px;border-top:1px solid #1e293b;background:#0f172a;flex-shrink:0;"><button type="button" id="${exportBtnId}" class="o-test-overlay-export-btn" style="${btnBarStyle}">Export (objs)</button><button type="button" id="${copyBtnId}" class="o-test-overlay-export-btn" style="${btnBarStyle}">Copy (txt)</button></div></div></div>`,box=o.overlay({innerHTML,removeExisting:!1,className:"o-test-overlay",id:btnId,excludeDragSelector:".o-test-overlay-close, .o-test-overlay-toggle, #"+panelId+", #"+scrollId+", #o-test-overlay-footer, .o-test-overlay-export-btn"});o("#"+exportBtnId).on("click",()=>{const data=JSON.stringify({results:o.tRes,logs:o.tLog},null,2),blob=new Blob([data],{type:"application/json"}),a=o.D.createElement("a");a.href=URL.createObjectURL(blob),a.download="objs-test-results.json",a.click()}),o("#"+copyBtnId).on("click",()=>{const text=buildListPlainText(),write=()=>{const ta=o.D.createElement("textarea");ta.value=text,ta.setAttribute("readonly",""),ta.style.cssText="position:fixed;left:-9999px;top:0",o.D.body.appendChild(ta),ta.select(),o.D.execCommand("copy"),ta.remove()};typeof navigator<"u"&&navigator.clipboard&&navigator.clipboard.writeText?navigator.clipboard.writeText(text).catch(write):write()});const refreshSummary=()=>{const summary=o(".o-test-overlay-summary");summary.els.length&&summary.innerText(`Tests: ${o.tRes.filter(Boolean).length}/${o.tRes.length}`)};box.first(".o-test-overlay-toggle").on("click",()=>{const panel=o("#"+panelId);if(!panel.el)return;panel.el.style.display!=="none"?panel.el.style.display="none":(panel.el.style.display="flex",updatePanel())}),box.first(".o-test-overlay-close").on("click",()=>{box._overlayCleanup()}),o.testOverlay.showPanel=()=>{const panel=o("#"+panelId);panel.el&&(panel.el.style.display="flex",updatePanel(),refreshSummary())},o._testOverlayBase||(o._testOverlayBase=o.test),o.test=(...args)=>{const id=o._testOverlayBase(...args),origFn=o.tFns[id];return o.tFns[id]=n=>{typeof origFn=="function"&&origFn(n);const panel=o("#"+panelId);panel.el&&panel.el.style.display!=="none"&&updatePanel(),refreshSummary()},id}},o.overlay=(opts={})=>{const{innerHTML,onClose,timeout,excludeDragSelector,removeExisting=!0,className="o-overlay-common",id}=opts;if(removeExisting)o("."+className).remove();else if(id&&o("#"+id).el)return o("#"+id);const overlayStyle={position:"fixed",left:"50%",bottom:"50px",transform:"translateX(-50%)","z-index":"999999",width:"fit-content","max-width":"min(90vw, 420px)","font-family":"system-ui,sans-serif","user-select":"text"},countdownId="o-overlay-countdown",barHtml='<div class="o-overlay-bar" style="display:flex;flex-direction:column;align-items:stretch;padding:10px 14px;background:#1e293b;color:#e2e8f0;border:1px solid #334155;border-radius:8px;font-size:14px;min-width:200px;max-height:90vh;overflow-y:auto;">'+innerHTML+(timeout?`<div id="${countdownId}" style="margin-top:6px;font-size:11px;color:#94a3b8;"></div>`:"")+"</div>",box=o.initState({tag:"div",className,id:id||void 0,style:"position:fixed;left:50%;bottom:50px;transform:translateX(-50%);z-index:999999;width:fit-content;max-width:min(90vw,420px);font-family:system-ui,sans-serif;user-select:text;",html:barHtml}).appendInside("body"),applyStyle=()=>box.css(overlayStyle);let drag=null;const onMove=e=>{drag&&(overlayStyle.left=drag.left+(e.clientX-drag.startX)+"px",overlayStyle.top=drag.top+(e.clientY-drag.startY)+"px",delete overlayStyle.bottom,overlayStyle.transform="none",applyStyle())},onUp=()=>{drag&&(delete overlayStyle.cursor,applyStyle()),drag=null};box.on("mousedown",e=>{if(excludeDragSelector&&e.target.closest(excludeDragSelector))return;const r=box.el.getBoundingClientRect();drag={startX:e.clientX,startY:e.clientY,left:r.left,top:r.top},overlayStyle.cursor="grabbing",applyStyle()}),o.D.addEventListener("mousemove",onMove),o.D.addEventListener("mouseup",onUp);let timerId;const cleanup=()=>{o.D.removeEventListener("mousemove",onMove),o.D.removeEventListener("mouseup",onUp),timerId&&clearInterval(timerId),box.remove()};if(timeout&&timeout>0){let remaining=Math.ceil(timeout/1e3);const cd=o("#"+countdownId);cd.el&&(cd.el.textContent=remaining?`Continue in ${remaining}s`:""),timerId=setInterval(()=>{remaining-=1,cd.el&&(cd.el.textContent=remaining>0?`Continue in ${remaining}s`:""),remaining<=0&&(clearInterval(timerId),timerId=null,cleanup(),typeof onClose=="function"&&onClose({ok:!1,errors:["timeout"]}))},1e3)}return box._overlayCleanup=cleanup,box._overlayOnClose=onClose,box},o.testConfirm=(label,items=[],opts={})=>new Promise(resolve=>{const btnLabel=opts.confirm||"Continue",hasCheckboxes=items.length>0,btnBg=hasCheckboxes?"#dc2626":"#2563eb",itemIds=items.map((_,idx)=>"o-tc-cb-"+idx),itemsHtml=hasCheckboxes?`<style>.o-tc-item-cb{appearance:none;-webkit-appearance:none;width:16px;height:16px;border:2px solid #ef4444;border-radius:3px;background:#fef2f2;flex-shrink:0;cursor:pointer;}.o-tc-item-cb:checked{border-color:#22c55e;background:#22c55e;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-size:12px 12px;background-position:center;}</style><ul class="o-tc-list" style="margin:8px 0 0;padding:0;list-style:none;font-size:13px;color:#cbd5e1;cursor:grab;">`+items.map((i,idx)=>`<li style="margin-bottom:4px;"><label for="${itemIds[idx]}" style="display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none;"><input type="checkbox" id="${itemIds[idx]}" class="o-tc-item-cb"> <span>${i}</span></label></li>`).join("")+"</ul>":"",innerHTML=`<div style="display:flex;align-items:center;gap:12px;"><span class="o-tc-label" style="flex:1;cursor:grab;">${label}: Paused</span><button type="button" class="o-tc-ok" style="padding:6px 14px;background:${btnBg};color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;font-size:13px;flex-shrink:0;">${btnLabel}</button></div>`+itemsHtml,box=o.overlay({innerHTML,timeout:opts.timeout,excludeDragSelector:".o-tc-ok",onClose:r=>resolve(r||{ok:!0})}),okBtnStyles={padding:"6px 14px",background:hasCheckboxes?"#dc2626":"#2563eb",color:"#fff",border:"none","border-radius":"6px","font-weight":"600",cursor:"pointer","font-size":"13px","flex-shrink":"0"};if(hasCheckboxes){const okBtn=box.first(".o-tc-ok"),cbs=o(".o-overlay-common .o-tc-item-cb"),updateBtn=()=>{const allChecked=cbs.length>0&&cbs.els.every(el=>el.checked);okBtn.css({...okBtnStyles,background:allChecked?"#16a34a":"#dc2626"})};cbs.on("change",updateBtn)}box.first(".o-tc-ok").on("click",()=>{let unchecked=[];if(hasCheckboxes){const cbsList=o(".o-overlay-common .o-tc-item-cb");cbsList.els.length&&cbsList.els.forEach((el,idx)=>{!el.checked&&items[idx]!==void 0&&unchecked.push(items[idx])})}box._overlayCleanup(),resolve(unchecked.length===0?{ok:!0}:{ok:!1,errors:unchecked})})});
|
|
99
99
|
|
|
100
100
|
export { o };
|
|
101
101
|
export default o;
|