@kalamba/sdk 0.19.0 → 0.23.0

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/dist/plugins.cjs CHANGED
@@ -2,4 +2,4 @@
2
2
  * BSD 3-Clause License
3
3
  * Copyright (c) 2025, Kalamba Games Limited
4
4
  */
5
- "use strict";var ai=Object.defineProperty;var ft=s=>{throw TypeError(s)};var ni=(s,t,e)=>t in s?ai(s,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):s[t]=e;var b=(s,t,e)=>ni(s,typeof t!="symbol"?t+"":t,e),yt=(s,t,e)=>t.has(s)||ft("Cannot "+e);var k=(s,t,e)=>(yt(s,t,"read from private field"),e?e.call(s):t.get(s)),M=(s,t,e)=>t.has(s)?ft("Cannot add the same private member more than once"):t instanceof WeakSet?t.add(s):t.set(s,e),v=(s,t,e,i)=>(yt(s,t,"write to private field"),i?i.call(s,e):t.set(s,e),e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const He=require("./errors-BXO3dlhS.cjs"),ze=require("./encoders-DVHzIpWT.cjs"),gt=require("./v4-CoqWKwnX.cjs");function x(s,t){return(e,...i)=>{console.log(`[%c${s}\x1B[m] %s`,t,e,...i)}}function Wt(s,t){return Math.round(s*100/t)}class D{constructor(t,e){b(this,"config");b(this,"sdkConfig");this.config=t,this.sdkConfig=e}on(t,e,i){const a=function(r){r.data.message!==`kalamba:wrapper-casino:${t}`&&r.data.message!==`kalamba:wrapper:${t}`||e(r.data.payload)};window.addEventListener("message",a,i)}send(t,...[e]){window.postMessage({message:`kalamba:casino:${t}`,payload:e})}}const oi=x("BasicPlugin","color:#000000;font-weight:bold;");class ri extends D{constructor(...t){super(...t),this.registerToSdkEvents(),this.registerFromSdkEvents(),oi("configured")}registerToSdkEvents(){window.addEventListener("message",t=>{try{const{type:e,payload:i}=t.data;switch(e){case"doAudioSettings":this.send("settings",{music:i==null?void 0:i.musicEnabled,sounds:i==null?void 0:i.soundEnabled});return;case"doBalanceUpdate":const{currency:a,coinValueInCents:d}=this.sdkConfig.api;i.currency===a&&typeof i.balanceInCurrency=="number"?this.send("balance",{balance:Wt(i.balanceInCurrency,d)}):(i.balanceInCoins,this.send("balance",{balance:i.balanceInCoins}));return;case"doGamePause":this.send("freeze");return;case"doGameResume":this.send("unfreeze");return;case"doGameSuspend":this.send("suspend");return;default:return}}catch{}})}registerFromSdkEvents(){this.on("close",()=>{if(this.sdkConfig.api.homeUrl)try{window.top.location=this.sdkConfig.api.homeUrl}catch{window.location=this.sdkConfig.api.homeUrl}else try{window.top.history.back()}catch{window.history.back()}})}}const E=x("▼ DebuggingPlugin IN ▼","color:#444444;font-weight:bold;"),ci=x("▲ DebuggingPlugin OUT ▲","color:#444444;font-weight:bold;");class di extends D{constructor(...t){super(...t),this.registerDebugToSdkEvents(),this.registerSdkToDebugEvents()}registerDebugToSdkEvents(){window.DebuggingPlugin={balance:t=>this._send("balance",t),bet:t=>this._send("bet",t),choice:t=>this._send("choice",t),close:t=>this._send("close",t),help:t=>this._send("help",t),history:t=>this._send("history",t),freeze:t=>this._send("freeze",t),paytable:t=>this._send("paytable",t),settings:t=>this._send("settings",t),suspend:t=>this._send("suspend",t),unfreeze:t=>this._send("unfreeze",t)}}registerSdkToDebugEvents(){this.on("autoplay",t=>E("autoplay",t)),this.on("balance",t=>E("balance",t)),this.on("bet",t=>E("bet",t)),this.on("cashier",t=>E("cashier",t)),this.on("choice",t=>E("choice",t)),this.on("close",t=>E("close",t)),this.on("error",t=>E("error",t)),this.on("loadEnd",t=>E("loadEnd",t)),this.on("loadProgress",t=>E("loadProgress",t)),this.on("loadStart",t=>E("loadStart",t)),this.on("playCycleStart",t=>E("playCycleStart",t)),this.on("playCycleEnd",t=>E("playCycleEnd",t)),this.on("playEnd",t=>E("playEnd",t)),this.on("playError",t=>E("playError",t)),this.on("playReady",t=>E("playReady",t)),this.on("playStart",t=>E("playStart",t)),this.on("settings",t=>E("settings",t))}_send(...t){ci(...t),this.send(...t)}}const li=x("GigPlugin","color:#000000;font-weight:bold;");class ui extends D{constructor(...t){super(...t),this.registerToSdkEvents(),this.registerFromSdkEvents(),li("configured")}postMessage(t){const e={event:t};window.top.postMessage(e,"*")}registerToSdkEvents(){window.addEventListener("message",t=>{try{const{data:e}=t;switch(e){case"STOP_AUTO_PLAY":this.send("suspend");return;case"BLOCK_BETS":this.send("freeze");return;case"UNBLOCK_BETS":this.send("unfreeze");return;default:return}}catch{}})}registerFromSdkEvents(){this.on("close",()=>{if(this.sdkConfig.api.homeUrl)try{window.top.location=this.sdkConfig.api.homeUrl}catch{window.location=this.sdkConfig.api.homeUrl}else try{window.top.history.back()}catch{window.history.back()}}),this.on("playReady",()=>{this.postMessage("GAME_READY")})}}const hi=x("OryxPlugin","color:#000000;font-weight:bold;");class gi extends D{constructor(...t){super(...t),this.registerToSdkEvents(),this.registerFromSdkEvents(),hi("configured")}registerToSdkEvents(){window.addEventListener("message",t=>{try{const{type:e,param:i}=t.data;switch(e){case"doBalanceUpdate":this.send("balance",{balance:i});return;case"doGamePause":this.send("freeze");return;case"doGameResume":this.send("unfreeze");return;case"doGameSuspend":this.send("suspend");return;default:return}}catch{}})}registerFromSdkEvents(){let t=0;this.on("close",()=>{window.top.postMessage({wpgaction:"close"},"*"),window.parent.postMessage({wpgaction:"close.parent"},"*")}),this.on("balance",({balance:e})=>{t!==e&&(t=e,window.top.postMessage({param:{},wpgaction:"balance"},"*"),window.parent.postMessage({param:{},wpgaction:"balance.parent"},"*"))}),this.on("loadStart",()=>{window.top.postMessage({wpgaction:"loadStart"},"*"),window.parent.postMessage({wpgaction:"loadStart.parent"},"*")}),this.on("loadEnd",()=>{window.top.postMessage({wpgaction:"loadEnd"},"*"),window.parent.postMessage({wpgaction:"loadEnd.parent"},"*")}),this.on("playStart",()=>{window.top.postMessage({wpgaction:"gameSpinStart"},"*"),window.parent.postMessage({wpgaction:"gameSpinStart.parent"},"*")}),this.on("playEnd",()=>{window.top.postMessage({wpgaction:"gameSpinEnd"},"*"),window.parent.postMessage({wpgaction:"gameSpinEnd.parent"},"*")}),this.on("cashier",({type:e})=>{switch(e){case"BALANCE_LOW":window.top.postMessage({wpgaction:"cashier"},"*"),window.parent.postMessage({wpgaction:"cashier.parent"},"*");break;case"BALANCE_INSUFFICIENT":window.top.postMessage({wpgaction:"errorOutOfMoney"},"*"),window.parent.postMessage({wpgaction:"errorOutOfMoney.parent"},"*");break}})}}const We=x("PariplayPlugin","color:#000000;font-weight:bold;");function je(s){try{window.top.location=s}catch{window.location=s}}function $e(s,t){return new Promise(function(i,a){const d=new XMLHttpRequest;d.onload=function(){d.status>=200&&d.status<300?i(d.responseText):a(d.responseText)},d.open(s,t),d.send()})}function Ke(){}function pi(s){return s.filter(function(e){return e.messageType.toUpperCase()==="DATA"})}function Qe(s){return s.filter(function(e){return["NOTIFICATION","POPUP"].includes(e.messageType.toUpperCase())})}function jt(s){try{return JSON.parse(s.text)}catch{return{}}}function wi(s){return s.map(jt).filter(Boolean).find(function(e){return e.betId!=null&&e.winId!=null})||{}}function mi(s){return s.map(jt).filter(Boolean).find(function(e){return e.TotalBet!=null&&e.TotalWin!=null})||{}}class bi extends D{constructor(...t){super(...t),this.registerToSdkEvents(),this.registerFromSdkEvents(),We("configured")}postMessage(t,e){const i={lang:this.sdkConfig.ui.language,sender:this.sdkConfig.api.game,type:t};e!=null&&(i.data=e),We("postMessage",i),window.parent.postMessage(i,"*")}coinsToCurrency(t){return t*this.sdkConfig.api.coinValueInCents/100}handleContinueButton(t,e){t.link&&$e("GET",t.link),e()}handleLinkButton(t,e){switch(t.linkType.toUpperCase()){case"AJAX":$e("GET",t.link),e();return;case"AJAXRESPONSE":$e("GET",t.link).then(()=>{e()});return;case"REDIRECT":je(t.link),e();return}}handleQuitButton(t,e){this.send("close"),e()}handleCashierButton(t,e){this.send("cashier",{type:"ON_DEMAND"}),e()}handleHistoryButton(t,e){this.send("history",{source:"casino"}),e()}get buttonActions(){return{CASHIER:this.handleCashierButton,CONTINUE:this.handleContinueButton,HISTORY:this.handleHistoryButton,LINK:this.handleLinkButton,QUIT:this.handleQuitButton}}processInfoUiMessages(t){return t.reduce((e,i)=>e.then(()=>new Promise(a=>{const d=Object.assign({},i,{buttons:i.buttons.filter(r=>r.action.toUpperCase()==="CASHIER"?!!this.sdkConfig.api.cashierUrl:!0).map(r=>Object.assign({},r,{onRelease:()=>{const g=i.messageType.toUpperCase()==="POPUP"?Ke:a,h=this.buttonActions[r.action.toUpperCase()];h?h(r,g):g()}}))});We("showMessage",d)}).catch(Ke)),Promise.resolve()).then(()=>{}).catch(Ke)}registerToSdkEvents(){window.addEventListener("message",t=>{try{const{type:e}=t.data;switch(e){case"pause":case"disableSpin":this.send("freeze");return;case"resume":case"enableSpin":this.send("unfreeze");return;case"stopAutobet":this.send("suspend");return;default:return}}catch{}})}registerFromSdkEvents(){let t=0;this.on("openGameResponse",e=>{let i;try{const a=JSON.parse(JSON.parse(atob(this.sdkConfig.api.integrationData.token.split(".")[1])).token),d=JSON.parse(a.integrationSpecificAttributes.sessionData||"{}");i={ClientToken:a.integrationSpecificAttributes.clientToken,CurrencyCode:a.currency,PlayerTokenId:a.user,SessionData:d}}catch{i=void 0}this.postMessage("gameDataLoaded",{LoadGameData:i,success:!0});try{const a=Qe(e.contract.uiMessages);this.processInfoUiMessages(a)}catch{}}),this.on("balance",({balance:e})=>{t!==e&&(t=e,this.postMessage("balance",{amount:this.coinsToCurrency(e)}))}),this.on("close",()=>{if(this.sdkConfig.api.homeUrl)if(this.sdkConfig.api.homeUrl==="(back)")try{window.top.history.back()}catch{window.history.back()}else this.sdkConfig.api.homeUrl==="(api)"?this.postMessage("quit"):je(this.sdkConfig.api.homeUrl)}),this.on("playEnd",e=>{this.postMessage("roundEnded",{balanceAfter:this.coinsToCurrency(e.contract.balance.coins),win:this.coinsToCurrency(e.contract.win.round)});try{const i=Qe(e.contract.uiMessages);this.processInfoUiMessages(i)}catch{}}),this.on("playError",e=>{this.postMessage("ticketReceived",{ErrorCode:e.type==="error"?e.data.code:"TIMEOUT",ErrorMessage:"ERROR",Status:{ErrCode:e.type==="error"?e.data.code:"TIMEOUT"}})}),this.on("playResponse",e=>{this.postMessage("roundStarted",{balanceBefore:this.coinsToCurrency(e.contract.balance.coins+e.contract.bet.lastPaid.base*e.contract.bet.lastPaid.multiplier)});const i=["BaseGame","PaidSpin"].includes(e.contract.stateType.thisRound),a=pi(e.contract.uiMessages),d=Qe(e.contract.uiMessages),r=wi(a),g=mi(a);this.postMessage("ticketReceived",{Balance:this.coinsToCurrency(e.contract.balance.coins),BetAmount:i?this.coinsToCurrency(e.contract.bet.lastPaid.base*e.contract.bet.lastPaid.multiplier):0,CreditTransactionId:r.betId,DebitTransactionId:r.winId,Message:d,SessionData:g,Status:{ErrCode:0},WinAmount:this.coinsToCurrency(e.contract.win.round)})}),this.on("playStart",e=>{e.bet&&this.postMessage("roundStart",{totalBet:this.coinsToCurrency(e.bet.base*e.bet.multiplier)})}),this.on("loadEnd",()=>{this.postMessage("gameReady")}),this.on("loadStart",()=>{this.postMessage("onAppFrameReady")}),this.on("cashier",()=>{this.sdkConfig.api.cashierUrl&&(this.sdkConfig.api.cashierUrl==="(api)"?this.postMessage("cashier"):je(this.sdkConfig.api.cashierUrl))})}}const we=x("RelaxFEIMPlugin","color:#000000;font-weight:bold;");class fi extends D{constructor(...e){super(...e);b(this,"VERSION","1.17.0");const i=document.createElement("script");i.src=`https://d3nsdzdtjbr5ml.cloudfront.net/casino/relaxlibs/feim/${this.VERSION}/rlxfeim.min.js`,i.onload=()=>{we("loaded"),window.FEIM.configure({p2pConfig:{currency:this.sdkConfig.api.currency,launchParams:{homeurl:"homeUrl"}}}),we("configured"),this.registerToSdkEvents(),this.registerFromSdkEvents()},document.body.appendChild(i)}registerToSdkEvents(){window.FEIM.on.errorMessageDismissed(()=>this.send("unfreeze")),window.FEIM.on.errorMessageDisplayed(()=>this.send("freeze")),window.FEIM.on.exitingGame(()=>we("!!! NOT IMPLEMENTED: exitingGame !!!")),window.FEIM.on.freeze(()=>this.send("freeze")),window.FEIM.on.initialized(()=>we("!!! NOT IMPLEMENTED: initialized !!!")),window.FEIM.on.pauseAutoPlay(()=>this.send("suspend")),window.FEIM.on.refreshBalance(()=>we("!!! NOT IMPLEMENTED: refreshBalance !!!")),window.FEIM.on.toggleGameHelp(()=>{this.send("help",{})}),window.FEIM.on.togglePaytable(()=>{this.send("paytable",{})}),window.FEIM.on.unfreeze(()=>this.send("unfreeze")),window.FEIM.on.updateSettings(({payload:[e]})=>this.send("settings",{sounds:e.sounds,fastPlay:e.fastPlay}))}registerFromSdkEvents(){this.on("autoplay",({action:e})=>{switch(e){case"start":window.FEIM.send.autoPlayStarted();break;case"stop":window.FEIM.send.autoPlayFinished();break}}),this.on("balance",({balance:e})=>{window.FEIM.send.balanceUpdate(e)}),this.on("bet",({base:e,multiplier:i})=>{window.FEIM.send.betUpdate(e*i)}),this.on("error",e=>{const i="message"in e?e.message:"Unknown error";window.FEIM.send.errorMessage(i)}),this.on("close",()=>{window.FEIM.send.exitGame()}),this.on("loadEnd",()=>{window.FEIM.send.gameLoadCompleted()}),this.on("loadProgress",({progress:e})=>{window.FEIM.send.gameLoadProgress(e)}),this.on("loadStart",()=>{window.FEIM.send.gameLoadStarted()}),this.on("cashier",()=>{window.FEIM.send.openQuickDeposit()}),this.on("playCycleEnd",e=>{const i={balance:e.contract.balance.coins,bet:e.contract.bet.lastPaid.base*e.contract.bet.lastPaid.multiplier,win:{win:e.contract.win.total}};window.FEIM.send.roundFinished(i)}),this.on("playResponse",e=>{const i={balance:e.contract.balance.coins,playResponse:e.data};window.FEIM.send.roundStarted(i)}),this.on("history",()=>{window.FEIM.send.showHistory()}),this.on("settings",e=>{window.FEIM.send.updateSettings(e)})}}const Xe=x("TukoPlugin","color:#000000;font-weight:bold;");class yi extends D{constructor(...e){super(...e);b(this,"PING_INTERVAL",1e4);const a=new URLSearchParams(window.location.search).get("pingCallbackUrl");a&&window.setInterval(()=>{this.ping(a)},this.PING_INTERVAL),this.registerToSdkEvents(),this.registerFromSdkEvents(),Xe("configured")}ping(e){const i=new XMLHttpRequest;i.onreadystatechange=function(){i.readyState===XMLHttpRequest.DONE&&(i.status===0||i.status>=200&&i.status<400?Xe("ping ok",i):Xe("ping error",i))},i.open("GET",e),i.send()}registerToSdkEvents(){window.addEventListener("message",e=>{try{const{type:i,payload:a}=e.data;switch(i){case"doAudioSettings":this.send("settings",{music:a==null?void 0:a.musicEnabled,sounds:a==null?void 0:a.soundEnabled});return;case"doBalanceUpdate":const{currency:d,coinValueInCents:r}=this.sdkConfig.api;a.currency===d&&typeof a.balanceInCurrency=="number"?this.send("balance",{balance:Wt(a.balanceInCurrency,r)}):(a.balanceInCoins,this.send("balance",{balance:a.balanceInCoins}));return;case"doGamePause":this.send("freeze");return;case"doGameResume":this.send("unfreeze");return;case"doGameSuspend":this.send("suspend");return;default:return}}catch{}})}registerFromSdkEvents(){this.on("close",()=>{if(this.sdkConfig.api.homeUrl)try{window.top.location=this.sdkConfig.api.homeUrl}catch{window.location=this.sdkConfig.api.homeUrl}else try{window.top.history.back()}catch{window.history.back()}})}}const kt=x("QuantaPlugin","color:#000000;font-weight:bold;");class ki extends D{constructor(...t){super(...t),this.registerFromSdkEvents(),kt("configured")}postMessage(t){const e={event:t};kt("QuantaPlugin::postMessage",e),window.parent.postMessage(e,"*")}registerFromSdkEvents(){this.on("close",()=>{this.postMessage("GameClosed")}),this.on("loadEnd",()=>{this.postMessage("GameLoaded")}),this.on("playCycleStart",()=>{this.postMessage("RoundStarted")}),this.on("playCycleEnd",()=>{this.postMessage("RoundEnded")}),this.on("playError",()=>{this.postMessage("RoundEnded")})}}var vi="2.0.3",dt=500,vt="user-agent",le="",Et="?",_e="function",j="undefined",ue="object",lt="string",S="browser",B="cpu",U="device",O="engine",A="os",te="result",l="name",n="type",c="vendor",u="version",T="architecture",Se="major",o="model",Ce="console",w="mobile",f="tablet",y="smarttv",R="wearable",Je="xr",Me="embedded",me="inapp",pt="brands",Y="formFactors",wt="fullVersionList",ie="platform",mt="platformVersion",Ve="bitness",$="sec-ch-ua",Ei=$+"-full-version-list",Ci=$+"-arch",Mi=$+"-"+Ve,Si=$+"-form-factors",Ti=$+"-"+w,Ii=$+"-"+o,$t=$+"-"+ie,Pi=$t+"-version",Kt=[pt,wt,w,o,ie,mt,T,Y,Ve],xe="Amazon",Z="Apple",Ct="ASUS",Mt="BlackBerry",J="Google",St="Huawei",Tt="Lenovo",It="Honor",Re="LG",Ye="Microsoft",Ze="Motorola",et="Nvidia",Pt="OnePlus",tt="OPPO",be="Samsung",At="Sharp",fe="Sony",it="Xiaomi",st="Zebra",Ot="Chrome",xt="Chromium",V="Chromecast",Ai="Edge",ye="Firefox",ke="Opera",at="Facebook",Rt="Sogou",ee="Mobile ",ve=" Browser",ut="Windows",Oi=typeof window!==j,I=Oi&&window.navigator?window.navigator:void 0,q=I&&I.userAgentData?I.userAgentData:void 0,xi=function(s,t){var e={},i=t;if(!Be(t)){i={};for(var a in t)for(var d in t[a])i[d]=t[a][d].concat(i[d]?i[d]:[])}for(var r in s)e[r]=i[r]&&i[r].length%2===0?i[r].concat(s[r]):s[r];return e},qe=function(s){for(var t={},e=0;e<s.length;e++)t[s[e].toUpperCase()]=s[e];return t},ht=function(s,t){if(typeof s===ue&&s.length>0){for(var e in s)if(F(s[e])==F(t))return!0;return!1}return ge(s)?F(t).indexOf(F(s))!==-1:!1},Be=function(s,t){for(var e in s)return/^(browser|cpu|device|engine|os)$/.test(e)||(t?Be(s[e]):!1)},ge=function(s){return typeof s===lt},nt=function(s){if(s){for(var t=[],e=he(/\\?\"/g,s).split(","),i=0;i<e.length;i++)if(e[i].indexOf(";")>-1){var a=Te(e[i]).split(";v=");t[i]={brand:a[0],version:a[1]}}else t[i]=Te(e[i]);return t}},F=function(s){return ge(s)?s.toLowerCase():s},ot=function(s){return ge(s)?he(/[^\d\.]/g,s).split(".")[0]:void 0},N=function(s){for(var t in s){var e=s[t];typeof e==ue&&e.length==2?this[e[0]]=e[1]:this[e]=void 0}return this},he=function(s,t){return ge(t)?t.replace(s,le):t},Ee=function(s){return he(/\\?\"/g,s)},Te=function(s,t){if(ge(s))return s=he(/^\s\s*/,s),typeof t===j?s:s.substring(0,dt)},rt=function(s,t){if(!(!s||!t))for(var e=0,i,a,d,r,g,h;e<t.length&&!g;){var p=t[e],m=t[e+1];for(i=a=0;i<p.length&&!g&&p[i];)if(g=p[i++].exec(s),g)for(d=0;d<m.length;d++)h=g[++a],r=m[d],typeof r===ue&&r.length>0?r.length===2?typeof r[1]==_e?this[r[0]]=r[1].call(this,h):this[r[0]]=r[1]:r.length===3?typeof r[1]===_e&&!(r[1].exec&&r[1].test)?this[r[0]]=h?r[1].call(this,h,r[2]):void 0:this[r[0]]=h?h.replace(r[1],r[2]):void 0:r.length===4&&(this[r[0]]=h?r[3].call(this,h.replace(r[1],r[2])):void 0):this[r]=h||void 0;e+=2}},z=function(s,t){for(var e in t)if(typeof t[e]===ue&&t[e].length>0){for(var i=0;i<t[e].length;i++)if(ht(t[e][i],s))return e===Et?void 0:e}else if(ht(t[e],s))return e===Et?void 0:e;return t.hasOwnProperty("*")?t["*"]:s},Ut={ME:"4.90","NT 3.11":"NT3.51","NT 4.0":"NT4.0",2e3:"NT 5.0",XP:["NT 5.1","NT 5.2"],Vista:"NT 6.0",7:"NT 6.1",8:"NT 6.2","8.1":"NT 6.3",10:["NT 6.4","NT 10.0"],RT:"ARM"},Lt={embedded:"Automotive",mobile:"Mobile",tablet:["Tablet","EInk"],smarttv:"TV",wearable:"Watch",xr:["VR","XR"],"?":["Desktop","Unknown"],"*":void 0},_t={browser:[[/\b(?:crmo|crios)\/([\w\.]+)/i],[u,[l,ee+"Chrome"]],[/edg(?:e|ios|a)?\/([\w\.]+)/i],[u,[l,"Edge"]],[/(opera mini)\/([-\w\.]+)/i,/(opera [mobiletab]{3,6})\b.+version\/([-\w\.]+)/i,/(opera)(?:.+version\/|[\/ ]+)([\w\.]+)/i],[l,u],[/opios[\/ ]+([\w\.]+)/i],[u,[l,ke+" Mini"]],[/\bop(?:rg)?x\/([\w\.]+)/i],[u,[l,ke+" GX"]],[/\bopr\/([\w\.]+)/i],[u,[l,ke]],[/\bb[ai]*d(?:uhd|[ub]*[aekoprswx]{5,6})[\/ ]?([\w\.]+)/i],[u,[l,"Baidu"]],[/\b(?:mxbrowser|mxios|myie2)\/?([-\w\.]*)\b/i],[u,[l,"Maxthon"]],[/(kindle)\/([\w\.]+)/i,/(lunascape|maxthon|netfront|jasmine|blazer|sleipnir)[\/ ]?([\w\.]*)/i,/(avant|iemobile|slim(?:browser|boat|jet))[\/ ]?([\d\.]*)/i,/(?:ms|\()(ie) ([\w\.]+)/i,/(flock|rockmelt|midori|epiphany|silk|skyfire|ovibrowser|bolt|iron|vivaldi|iridium|phantomjs|bowser|qupzilla|falkon|rekonq|puffin|brave|whale(?!.+naver)|qqbrowserlite|duckduckgo|klar|helio|(?=comodo_)?dragon|otter|dooble|(?:lg |qute)browser)\/([-\w\.]+)/i,/(heytap|ovi|115|surf)browser\/([\d\.]+)/i,/(ecosia|weibo)(?:__| \w+@)([\d\.]+)/i],[l,u],[/quark(?:pc)?\/([-\w\.]+)/i],[u,[l,"Quark"]],[/\bddg\/([\w\.]+)/i],[u,[l,"DuckDuckGo"]],[/(?:\buc? ?browser|(?:juc.+)ucweb)[\/ ]?([\w\.]+)/i],[u,[l,"UCBrowser"]],[/microm.+\bqbcore\/([\w\.]+)/i,/\bqbcore\/([\w\.]+).+microm/i,/micromessenger\/([\w\.]+)/i],[u,[l,"WeChat"]],[/konqueror\/([\w\.]+)/i],[u,[l,"Konqueror"]],[/trident.+rv[: ]([\w\.]{1,9})\b.+like gecko/i],[u,[l,"IE"]],[/ya(?:search)?browser\/([\w\.]+)/i],[u,[l,"Yandex"]],[/slbrowser\/([\w\.]+)/i],[u,[l,"Smart "+Tt+ve]],[/(avast|avg)\/([\w\.]+)/i],[[l,/(.+)/,"$1 Secure"+ve],u],[/\bfocus\/([\w\.]+)/i],[u,[l,ye+" Focus"]],[/\bopt\/([\w\.]+)/i],[u,[l,ke+" Touch"]],[/coc_coc\w+\/([\w\.]+)/i],[u,[l,"Coc Coc"]],[/dolfin\/([\w\.]+)/i],[u,[l,"Dolphin"]],[/coast\/([\w\.]+)/i],[u,[l,ke+" Coast"]],[/miuibrowser\/([\w\.]+)/i],[u,[l,"MIUI"+ve]],[/fxios\/([\w\.-]+)/i],[u,[l,ee+ye]],[/\bqihoobrowser\/?([\w\.]*)/i],[u,[l,"360"]],[/\b(qq)\/([\w\.]+)/i],[[l,/(.+)/,"$1Browser"],u],[/(oculus|sailfish|huawei|vivo|pico)browser\/([\w\.]+)/i],[[l,/(.+)/,"$1"+ve],u],[/samsungbrowser\/([\w\.]+)/i],[u,[l,be+" Internet"]],[/metasr[\/ ]?([\d\.]+)/i],[u,[l,Rt+" Explorer"]],[/(sogou)mo\w+\/([\d\.]+)/i],[[l,Rt+" Mobile"],u],[/(electron)\/([\w\.]+) safari/i,/(tesla)(?: qtcarbrowser|\/(20\d\d\.[-\w\.]+))/i,/m?(qqbrowser|2345(?=browser|chrome|explorer))\w*[\/ ]?v?([\w\.]+)/i],[l,u],[/(lbbrowser|rekonq)/i],[l],[/ome\/([\w\.]+) \w* ?(iron) saf/i,/ome\/([\w\.]+).+qihu (360)[es]e/i],[u,l],[/((?:fban\/fbios|fb_iab\/fb4a)(?!.+fbav)|;fbav\/([\w\.]+);)/i],[[l,at],u,[n,me]],[/(Klarna)\/([\w\.]+)/i,/(kakao(?:talk|story))[\/ ]([\w\.]+)/i,/(naver)\(.*?(\d+\.[\w\.]+).*\)/i,/(daum)apps[\/ ]([\w\.]+)/i,/safari (line)\/([\w\.]+)/i,/\b(line)\/([\w\.]+)\/iab/i,/(alipay)client\/([\w\.]+)/i,/(twitter)(?:and| f.+e\/([\w\.]+))/i,/(instagram|snapchat)[\/ ]([-\w\.]+)/i],[l,u,[n,me]],[/\bgsa\/([\w\.]+) .*safari\//i],[u,[l,"GSA"],[n,me]],[/musical_ly(?:.+app_?version\/|_)([\w\.]+)/i],[u,[l,"TikTok"],[n,me]],[/\[(linkedin)app\]/i],[l,[n,me]],[/(chromium)[\/ ]([-\w\.]+)/i],[l,u],[/headlesschrome(?:\/([\w\.]+)| )/i],[u,[l,Ot+" Headless"]],[/ wv\).+(chrome)\/([\w\.]+)/i],[[l,Ot+" WebView"],u],[/droid.+ version\/([\w\.]+)\b.+(?:mobile safari|safari)/i],[u,[l,"Android"+ve]],[/chrome\/([\w\.]+) mobile/i],[u,[l,ee+"Chrome"]],[/(chrome|omniweb|arora|[tizenoka]{5} ?browser)\/v?([\w\.]+)/i],[l,u],[/version\/([\w\.\,]+) .*mobile(?:\/\w+ | ?)safari/i],[u,[l,ee+"Safari"]],[/iphone .*mobile(?:\/\w+ | ?)safari/i],[[l,ee+"Safari"]],[/version\/([\w\.\,]+) .*(safari)/i],[u,l],[/webkit.+?(mobile ?safari|safari)(\/[\w\.]+)/i],[l,[u,"1"]],[/(webkit|khtml)\/([\w\.]+)/i],[l,u],[/(?:mobile|tablet);.*(firefox)\/([\w\.-]+)/i],[[l,ee+ye],u],[/(navigator|netscape\d?)\/([-\w\.]+)/i],[[l,"Netscape"],u],[/(wolvic|librewolf)\/([\w\.]+)/i],[l,u],[/mobile vr; rv:([\w\.]+)\).+firefox/i],[u,[l,ye+" Reality"]],[/ekiohf.+(flow)\/([\w\.]+)/i,/(swiftfox)/i,/(icedragon|iceweasel|camino|chimera|fennec|maemo browser|minimo|conkeror)[\/ ]?([\w\.\+]+)/i,/(seamonkey|k-meleon|icecat|iceape|firebird|phoenix|palemoon|basilisk|waterfox)\/([-\w\.]+)$/i,/(firefox)\/([\w\.]+)/i,/(mozilla)\/([\w\.]+) .+rv\:.+gecko\/\d+/i,/(amaya|dillo|doris|icab|ladybird|lynx|mosaic|netsurf|obigo|polaris|w3m|(?:go|ice|up)[\. ]?browser)[-\/ ]?v?([\w\.]+)/i,/\b(links) \(([\w\.]+)/i],[l,[u,/_/g,"."]],[/(cobalt)\/([\w\.]+)/i],[l,[u,/[^\d\.]+./,le]]],cpu:[[/\b((amd|x|x86[-_]?|wow|win)64)\b/i],[[T,"amd64"]],[/(ia32(?=;))/i,/\b((i[346]|x)86)(pc)?\b/i],[[T,"ia32"]],[/\b(aarch64|arm(v?[89]e?l?|_?64))\b/i],[[T,"arm64"]],[/\b(arm(v[67])?ht?n?[fl]p?)\b/i],[[T,"armhf"]],[/( (ce|mobile); ppc;|\/[\w\.]+arm\b)/i],[[T,"arm"]],[/((ppc|powerpc)(64)?)( mac|;|\))/i],[[T,/ower/,le,F]],[/ sun4\w[;\)]/i],[[T,"sparc"]],[/\b(avr32|ia64(?=;)|68k(?=\))|\barm(?=v([1-7]|[5-7]1)l?|;|eabi)|(irix|mips|sparc)(64)?\b|pa-risc)/i],[[T,F]]],device:[[/\b(sch-i[89]0\d|shw-m380s|sm-[ptx]\w{2,4}|gt-[pn]\d{2,4}|sgh-t8[56]9|nexus 10)/i],[o,[c,be],[n,f]],[/\b((?:s[cgp]h|gt|sm)-(?![lr])\w+|sc[g-]?[\d]+a?|galaxy nexus)/i,/samsung[- ]((?!sm-[lr])[-\w]+)/i,/sec-(sgh\w+)/i],[o,[c,be],[n,w]],[/(?:\/|\()(ip(?:hone|od)[\w, ]*)(?:\/|;)/i],[o,[c,Z],[n,w]],[/\((ipad);[-\w\),; ]+apple/i,/applecoremedia\/[\w\.]+ \((ipad)/i,/\b(ipad)\d\d?,\d\d?[;\]].+ios/i],[o,[c,Z],[n,f]],[/(macintosh);/i],[o,[c,Z]],[/\b(sh-?[altvz]?\d\d[a-ekm]?)/i],[o,[c,At],[n,w]],[/\b((?:brt|eln|hey2?|gdi|jdn)-a?[lnw]09|(?:ag[rm]3?|jdn2|kob2)-a?[lw]0[09]hn)(?: bui|\)|;)/i],[o,[c,It],[n,f]],[/honor([-\w ]+)[;\)]/i],[o,[c,It],[n,w]],[/\b((?:ag[rs][2356]?k?|bah[234]?|bg[2o]|bt[kv]|cmr|cpn|db[ry]2?|jdn2|got|kob2?k?|mon|pce|scm|sht?|[tw]gr|vrd)-[ad]?[lw][0125][09]b?|605hw|bg2-u03|(?:gem|fdr|m2|ple|t1)-[7a]0[1-4][lu]|t1-a2[13][lw]|mediapad[\w\. ]*(?= bui|\)))\b(?!.+d\/s)/i],[o,[c,St],[n,f]],[/(?:huawei)([-\w ]+)[;\)]/i,/\b(nexus 6p|\w{2,4}e?-[atu]?[ln][\dx][012359c][adn]?)\b(?!.+d\/s)/i],[o,[c,St],[n,w]],[/oid[^\)]+; (2[\dbc]{4}(182|283|rp\w{2})[cgl]|m2105k81a?c)(?: bui|\))/i,/\b((?:red)?mi[-_ ]?pad[\w- ]*)(?: bui|\))/i],[[o,/_/g," "],[c,it],[n,f]],[/\b(poco[\w ]+|m2\d{3}j\d\d[a-z]{2})(?: bui|\))/i,/\b; (\w+) build\/hm\1/i,/\b(hm[-_ ]?note?[_ ]?(?:\d\w)?) bui/i,/\b(redmi[\-_ ]?(?:note|k)?[\w_ ]+)(?: bui|\))/i,/oid[^\)]+; (m?[12][0-389][01]\w{3,6}[c-y])( bui|; wv|\))/i,/\b(mi[-_ ]?(?:a\d|one|one[_ ]plus|note lte|max|cc)?[_ ]?(?:\d?\w?)[_ ]?(?:plus|se|lite|pro)?)(?: bui|\))/i,/ ([\w ]+) miui\/v?\d/i],[[o,/_/g," "],[c,it],[n,w]],[/; (\w+) bui.+ oppo/i,/\b(cph[12]\d{3}|p(?:af|c[al]|d\w|e[ar])[mt]\d0|x9007|a101op)\b/i],[o,[c,tt],[n,w]],[/\b(opd2(\d{3}a?))(?: bui|\))/i],[o,[c,z,{OnePlus:["304","403","203"],"*":tt}],[n,f]],[/(vivo (5r?|6|8l?|go|one|s|x[il]?[2-4]?)[\w\+ ]*)(?: bui|\))/i],[o,[c,"BLU"],[n,w]],[/; vivo (\w+)(?: bui|\))/i,/\b(v[12]\d{3}\w?[at])(?: bui|;)/i],[o,[c,"Vivo"],[n,w]],[/\b(rmx[1-3]\d{3})(?: bui|;|\))/i],[o,[c,"Realme"],[n,w]],[/\b(milestone|droid(?:[2-4x]| (?:bionic|x2|pro|razr))?:?( 4g)?)\b[\w ]+build\//i,/\bmot(?:orola)?[- ](\w*)/i,/((?:moto(?! 360)[\w\(\) ]+|xt\d{3,4}|nexus 6)(?= bui|\)))/i],[o,[c,Ze],[n,w]],[/\b(mz60\d|xoom[2 ]{0,2}) build\//i],[o,[c,Ze],[n,f]],[/((?=lg)?[vl]k\-?\d{3}) bui| 3\.[-\w; ]{10}lg?-([06cv9]{3,4})/i],[o,[c,Re],[n,f]],[/(lm(?:-?f100[nv]?|-[\w\.]+)(?= bui|\))|nexus [45])/i,/\blg[-e;\/ ]+(?!.*(?:browser|netcast|android tv|watch))(\w+)/i,/\blg-?([\d\w]+) bui/i],[o,[c,Re],[n,w]],[/(ideatab[-\w ]+|602lv|d-42a|a101lv|a2109a|a3500-hv|s[56]000|pb-6505[my]|tb-?x?\d{3,4}(?:f[cu]|xu|[av])|yt\d?-[jx]?\d+[lfmx])( bui|;|\)|\/)/i,/lenovo ?(b[68]0[08]0-?[hf]?|tab(?:[\w- ]+?)|tb[\w-]{6,7})( bui|;|\)|\/)/i],[o,[c,Tt],[n,f]],[/(nokia) (t[12][01])/i],[c,o,[n,f]],[/(?:maemo|nokia).*(n900|lumia \d+|rm-\d+)/i,/nokia[-_ ]?(([-\w\. ]*))/i],[[o,/_/g," "],[n,w],[c,"Nokia"]],[/(pixel (c|tablet))\b/i],[o,[c,J],[n,f]],[/droid.+; (pixel[\daxl ]{0,6})(?: bui|\))/i],[o,[c,J],[n,w]],[/droid.+; (a?\d[0-2]{2}so|[c-g]\d{4}|so[-gl]\w+|xq-a\w[4-7][12])(?= bui|\).+chrome\/(?![1-6]{0,1}\d\.))/i],[o,[c,fe],[n,w]],[/sony tablet [ps]/i,/\b(?:sony)?sgp\w+(?: bui|\))/i],[[o,"Xperia Tablet"],[c,fe],[n,f]],[/ (kb2005|in20[12]5|be20[12][59])\b/i,/(?:one)?(?:plus)? (a\d0\d\d)(?: b|\))/i],[o,[c,Pt],[n,w]],[/(alexa)webm/i,/(kf[a-z]{2}wi|aeo(?!bc)\w\w)( bui|\))/i,/(kf[a-z]+)( bui|\)).+silk\//i],[o,[c,xe],[n,f]],[/((?:sd|kf)[0349hijorstuw]+)( bui|\)).+silk\//i],[[o,/(.+)/g,"Fire Phone $1"],[c,xe],[n,w]],[/(playbook);[-\w\),; ]+(rim)/i],[o,c,[n,f]],[/\b((?:bb[a-f]|st[hv])100-\d)/i,/\(bb10; (\w+)/i],[o,[c,Mt],[n,w]],[/(?:\b|asus_)(transfo[prime ]{4,10} \w+|eeepc|slider \w+|nexus 7|padfone|p00[cj])/i],[o,[c,Ct],[n,f]],[/ (z[bes]6[027][012][km][ls]|zenfone \d\w?)\b/i],[o,[c,Ct],[n,w]],[/(nexus 9)/i],[o,[c,"HTC"],[n,f]],[/(htc)[-;_ ]{1,2}([\w ]+(?=\)| bui)|\w+)/i,/(zte)[- ]([\w ]+?)(?: bui|\/|\))/i,/(alcatel|geeksphone|nexian|panasonic(?!(?:;|\.))|sony(?!-bra))[-_ ]?([-\w]*)/i],[c,[o,/_/g," "],[n,w]],[/tcl (xess p17aa)/i,/droid [\w\.]+; ((?:8[14]9[16]|9(?:0(?:48|60|8[01])|1(?:3[27]|66)|2(?:6[69]|9[56])|466))[gqswx])(_\w(\w|\w\w))?(\)| bui)/i],[o,[c,"TCL"],[n,f]],[/droid [\w\.]+; (418(?:7d|8v)|5087z|5102l|61(?:02[dh]|25[adfh]|27[ai]|56[dh]|59k|65[ah])|a509dl|t(?:43(?:0w|1[adepqu])|50(?:6d|7[adju])|6(?:09dl|10k|12b|71[efho]|76[hjk])|7(?:66[ahju]|67[hw]|7[045][bh]|71[hk]|73o|76[ho]|79w|81[hks]?|82h|90[bhsy]|99b)|810[hs]))(_\w(\w|\w\w))?(\)| bui)/i],[o,[c,"TCL"],[n,w]],[/(itel) ((\w+))/i],[[c,F],o,[n,z,{tablet:["p10001l","w7001"],"*":"mobile"}]],[/droid.+; ([ab][1-7]-?[0178a]\d\d?)/i],[o,[c,"Acer"],[n,f]],[/droid.+; (m[1-5] note) bui/i,/\bmz-([-\w]{2,})/i],[o,[c,"Meizu"],[n,w]],[/; ((?:power )?armor(?:[\w ]{0,8}))(?: bui|\))/i],[o,[c,"Ulefone"],[n,w]],[/; (energy ?\w+)(?: bui|\))/i,/; energizer ([\w ]+)(?: bui|\))/i],[o,[c,"Energizer"],[n,w]],[/; cat (b35);/i,/; (b15q?|s22 flip|s48c|s62 pro)(?: bui|\))/i],[o,[c,"Cat"],[n,w]],[/((?:new )?andromax[\w- ]+)(?: bui|\))/i],[o,[c,"Smartfren"],[n,w]],[/droid.+; (a(?:015|06[35]|142p?))/i],[o,[c,"Nothing"],[n,w]],[/; (x67 5g|tikeasy \w+|ac[1789]\d\w+)( b|\))/i,/archos ?(5|gamepad2?|([\w ]*[t1789]|hello) ?\d+[\w ]*)( b|\))/i],[o,[c,"Archos"],[n,f]],[/archos ([\w ]+)( b|\))/i,/; (ac[3-6]\d\w{2,8})( b|\))/i],[o,[c,"Archos"],[n,w]],[/(imo) (tab \w+)/i,/(infinix) (x1101b?)/i],[c,o,[n,f]],[/(blackberry|benq|palm(?=\-)|sonyericsson|acer|asus(?! zenw)|dell|jolla|meizu|motorola|polytron|infinix|tecno|micromax|advan)[-_ ]?([-\w]*)/i,/; (blu|hmd|imo|tcl)[_ ]([\w\+ ]+?)(?: bui|\)|; r)/i,/(hp) ([\w ]+\w)/i,/(microsoft); (lumia[\w ]+)/i,/(lenovo)[-_ ]?([-\w ]+?)(?: bui|\)|\/)/i,/(oppo) ?([\w ]+) bui/i],[c,o,[n,w]],[/(kobo)\s(ereader|touch)/i,/(hp).+(touchpad(?!.+tablet)|tablet)/i,/(kindle)\/([\w\.]+)/i],[c,o,[n,f]],[/(surface duo)/i],[o,[c,Ye],[n,f]],[/droid [\d\.]+; (fp\du?)(?: b|\))/i],[o,[c,"Fairphone"],[n,w]],[/((?:tegranote|shield t(?!.+d tv))[\w- ]*?)(?: b|\))/i],[o,[c,et],[n,f]],[/(sprint) (\w+)/i],[c,o,[n,w]],[/(kin\.[onetw]{3})/i],[[o,/\./g," "],[c,Ye],[n,w]],[/droid.+; ([c6]+|et5[16]|mc[239][23]x?|vc8[03]x?)\)/i],[o,[c,st],[n,f]],[/droid.+; (ec30|ps20|tc[2-8]\d[kx])\)/i],[o,[c,st],[n,w]],[/smart-tv.+(samsung)/i],[c,[n,y]],[/hbbtv.+maple;(\d+)/i],[[o,/^/,"SmartTV"],[c,be],[n,y]],[/tcast.+(lg)e?. ([-\w]+)/i],[c,o,[n,y]],[/(nux; netcast.+smarttv|lg (netcast\.tv-201\d|android tv))/i],[[c,Re],[n,y]],[/(apple) ?tv/i],[c,[o,Z+" TV"],[n,y]],[/crkey.*devicetype\/chromecast/i],[[o,V+" Third Generation"],[c,J],[n,y]],[/crkey.*devicetype\/([^/]*)/i],[[o,/^/,"Chromecast "],[c,J],[n,y]],[/fuchsia.*crkey/i],[[o,V+" Nest Hub"],[c,J],[n,y]],[/crkey/i],[[o,V],[c,J],[n,y]],[/(portaltv)/i],[o,[c,at],[n,y]],[/droid.+aft(\w+)( bui|\))/i],[o,[c,xe],[n,y]],[/(shield \w+ tv)/i],[o,[c,et],[n,y]],[/\(dtv[\);].+(aquos)/i,/(aquos-tv[\w ]+)\)/i],[o,[c,At],[n,y]],[/(bravia[\w ]+)( bui|\))/i],[o,[c,fe],[n,y]],[/(mi(tv|box)-?\w+) bui/i],[o,[c,it],[n,y]],[/Hbbtv.*(technisat) (.*);/i],[c,o,[n,y]],[/\b(roku)[\dx]*[\)\/]((?:dvp-)?[\d\.]*)/i,/hbbtv\/\d+\.\d+\.\d+ +\([\w\+ ]*; *([\w\d][^;]*);([^;]*)/i],[[c,Te],[o,Te],[n,y]],[/droid.+; ([\w- ]+) (?:android tv|smart[- ]?tv)/i],[o,[n,y]],[/\b(android tv|smart[- ]?tv|opera tv|tv; rv:)\b/i],[[n,y]],[/(ouya)/i,/(nintendo) (\w+)/i],[c,o,[n,Ce]],[/droid.+; (shield)( bui|\))/i],[o,[c,et],[n,Ce]],[/(playstation \w+)/i],[o,[c,fe],[n,Ce]],[/\b(xbox(?: one)?(?!; xbox))[\); ]/i],[o,[c,Ye],[n,Ce]],[/\b(sm-[lr]\d\d[0156][fnuw]?s?|gear live)\b/i],[o,[c,be],[n,R]],[/((pebble))app/i,/(asus|google|lg|oppo) ((pixel |zen)?watch[\w ]*)( bui|\))/i],[c,o,[n,R]],[/(ow(?:19|20)?we?[1-3]{1,3})/i],[o,[c,tt],[n,R]],[/(watch)(?: ?os[,\/]|\d,\d\/)[\d\.]+/i],[o,[c,Z],[n,R]],[/(opwwe\d{3})/i],[o,[c,Pt],[n,R]],[/(moto 360)/i],[o,[c,Ze],[n,R]],[/(smartwatch 3)/i],[o,[c,fe],[n,R]],[/(g watch r)/i],[o,[c,Re],[n,R]],[/droid.+; (wt63?0{2,3})\)/i],[o,[c,st],[n,R]],[/droid.+; (glass) \d/i],[o,[c,J],[n,Je]],[/(pico) (4|neo3(?: link|pro)?)/i],[c,o,[n,Je]],[/(quest( \d| pro)?s?).+vr/i],[o,[c,at],[n,Je]],[/(tesla)(?: qtcarbrowser|\/[-\w\.]+)/i],[c,[n,Me]],[/(aeobc)\b/i],[o,[c,xe],[n,Me]],[/(homepod).+mac os/i],[o,[c,Z],[n,Me]],[/windows iot/i],[[n,Me]],[/droid .+?; ([^;]+?)(?: bui|; wv\)|\) applew).+?(mobile|vr|\d) safari/i],[o,[n,z,{mobile:"Mobile",xr:"VR","*":f}]],[/\b((tablet|tab)[;\/]|focus\/\d(?!.+mobile))/i],[[n,f]],[/(phone|mobile(?:[;\/]| [ \w\/\.]*safari)|pda(?=.+windows ce))/i],[[n,w]],[/droid .+?; ([\w\. -]+)( bui|\))/i],[o,[c,"Generic"]]],engine:[[/windows.+ edge\/([\w\.]+)/i],[u,[l,Ai+"HTML"]],[/(arkweb)\/([\w\.]+)/i],[l,u],[/webkit\/537\.36.+chrome\/(?!27)([\w\.]+)/i],[u,[l,"Blink"]],[/(presto)\/([\w\.]+)/i,/(webkit|trident|netfront|netsurf|amaya|lynx|w3m|goanna|servo)\/([\w\.]+)/i,/ekioh(flow)\/([\w\.]+)/i,/(khtml|tasman|links)[\/ ]\(?([\w\.]+)/i,/(icab)[\/ ]([23]\.[\d\.]+)/i,/\b(libweb)/i],[l,u],[/ladybird\//i],[[l,"LibWeb"]],[/rv\:([\w\.]{1,9})\b.+(gecko)/i],[u,l]],os:[[/microsoft (windows) (vista|xp)/i],[l,u],[/(windows (?:phone(?: os)?|mobile|iot))[\/ ]?([\d\.\w ]*)/i],[l,[u,z,Ut]],[/windows nt 6\.2; (arm)/i,/windows[\/ ]([ntce\d\. ]+\w)(?!.+xbox)/i,/(?:win(?=3|9|n)|win 9x )([nt\d\.]+)/i],[[u,z,Ut],[l,ut]],[/[adehimnop]{4,7}\b(?:.*os ([\w]+) like mac|; opera)/i,/(?:ios;fbsv\/|iphone.+ios[\/ ])([\d\.]+)/i,/cfnetwork\/.+darwin/i],[[u,/_/g,"."],[l,"iOS"]],[/(mac os x) ?([\w\. ]*)/i,/(macintosh|mac_powerpc\b)(?!.+haiku)/i],[[l,"macOS"],[u,/_/g,"."]],[/android ([\d\.]+).*crkey/i],[u,[l,V+" Android"]],[/fuchsia.*crkey\/([\d\.]+)/i],[u,[l,V+" Fuchsia"]],[/crkey\/([\d\.]+).*devicetype\/smartspeaker/i],[u,[l,V+" SmartSpeaker"]],[/linux.*crkey\/([\d\.]+)/i],[u,[l,V+" Linux"]],[/crkey\/([\d\.]+)/i],[u,[l,V]],[/droid ([\w\.]+)\b.+(android[- ]x86|harmonyos)/i],[u,l],[/(ubuntu) ([\w\.]+) like android/i],[[l,/(.+)/,"$1 Touch"],u],[/(android|bada|blackberry|kaios|maemo|meego|openharmony|qnx|rim tablet os|sailfish|series40|symbian|tizen|webos)\w*[-\/\.; ]?([\d\.]*)/i],[l,u],[/\(bb(10);/i],[u,[l,Mt]],[/(?:symbian ?os|symbos|s60(?=;)|series ?60)[-\/ ]?([\w\.]*)/i],[u,[l,"Symbian"]],[/mozilla\/[\d\.]+ \((?:mobile|tablet|tv|mobile; [\w ]+); rv:.+ gecko\/([\w\.]+)/i],[u,[l,ye+" OS"]],[/web0s;.+rt(tv)/i,/\b(?:hp)?wos(?:browser)?\/([\w\.]+)/i],[u,[l,"webOS"]],[/watch(?: ?os[,\/]|\d,\d\/)([\d\.]+)/i],[u,[l,"watchOS"]],[/(cros) [\w]+(?:\)| ([\w\.]+)\b)/i],[[l,"Chrome OS"],u],[/panasonic;(viera)/i,/(netrange)mmh/i,/(nettv)\/(\d+\.[\w\.]+)/i,/(nintendo|playstation) (\w+)/i,/(xbox); +xbox ([^\);]+)/i,/(pico) .+os([\w\.]+)/i,/\b(joli|palm)\b ?(?:os)?\/?([\w\.]*)/i,/(mint)[\/\(\) ]?(\w*)/i,/(mageia|vectorlinux)[; ]/i,/([kxln]?ubuntu|debian|suse|opensuse|gentoo|arch(?= linux)|slackware|fedora|mandriva|centos|pclinuxos|red ?hat|zenwalk|linpus|raspbian|plan 9|minix|risc os|contiki|deepin|manjaro|elementary os|sabayon|linspire)(?: gnu\/linux)?(?: enterprise)?(?:[- ]linux)?(?:-gnu)?[-\/ ]?(?!chrom|package)([-\w\.]*)/i,/(hurd|linux)(?: arm\w*| x86\w*| ?)([\w\.]*)/i,/(gnu) ?([\w\.]*)/i,/\b([-frentopcghs]{0,5}bsd|dragonfly)[\/ ]?(?!amd|[ix346]{1,2}86)([\w\.]*)/i,/(haiku) (\w+)/i],[l,u],[/(sunos) ?([\w\.\d]*)/i],[[l,"Solaris"],u],[/((?:open)?solaris)[-\/ ]?([\w\.]*)/i,/(aix) ((\d)(?=\.|\)| )[\w\.])*/i,/\b(beos|os\/2|amigaos|morphos|openvms|fuchsia|hp-ux|serenityos)/i,/(unix) ?([\w\.]*)/i],[l,u]]},Ue=function(){var s={init:{},isIgnore:{},isIgnoreRgx:{},toString:{}};return N.call(s.init,[[S,[l,u,Se,n]],[B,[T]],[U,[n,o,c]],[O,[l,u]],[A,[l,u]]]),N.call(s.isIgnore,[[S,[u,Se]],[O,[u]],[A,[u]]]),N.call(s.isIgnoreRgx,[[S,/ ?browser$/i],[A,/ ?os$/i]]),N.call(s.toString,[[S,[l,u]],[B,[T]],[U,[c,o]],[O,[l,u]],[A,[l,u]]]),s}(),Ri=function(s,t){var e=Ue.init[t],i=Ue.isIgnore[t]||0,a=Ue.isIgnoreRgx[t]||0,d=Ue.toString[t]||0;function r(){N.call(this,e)}return r.prototype.getItem=function(){return s},r.prototype.withClientHints=function(){return q?q.getHighEntropyValues(Kt).then(function(g){return s.setCH(new Qt(g,!1)).parseCH().get()}):s.parseCH().get()},r.prototype.withFeatureCheck=function(){return s.detectFeature().get()},t!=te&&(r.prototype.is=function(g){var h=!1;for(var p in this)if(this.hasOwnProperty(p)&&!ht(i,p)&&F(a?he(a,this[p]):this[p])==F(a?he(a,g):g)){if(h=!0,g!=j)break}else if(g==j&&h){h=!h;break}return h},r.prototype.toString=function(){var g=le;for(var h in d)typeof this[d[h]]!==j&&(g+=(g?" ":le)+this[d[h]]);return g||j}),q||(r.prototype.then=function(g){var h=this,p=function(){for(var C in h)h.hasOwnProperty(C)&&(this[C]=h[C])};p.prototype={is:r.prototype.is,toString:r.prototype.toString};var m=new p;return g(m),m}),new r};function Qt(s,t){if(s=s||{},N.call(this,Kt),t)N.call(this,[[pt,nt(s[$])],[wt,nt(s[Ei])],[w,/\?1/.test(s[Ti])],[o,Ee(s[Ii])],[ie,Ee(s[$t])],[mt,Ee(s[Pi])],[T,Ee(s[Ci])],[Y,nt(s[Si])],[Ve,Ee(s[Mi])]]);else for(var e in s)this.hasOwnProperty(e)&&typeof s[e]!==j&&(this[e]=s[e])}function Bt(s,t,e,i){return this.get=function(a){return a?this.data.hasOwnProperty(a)?this.data[a]:void 0:this.data},this.set=function(a,d){return this.data[a]=d,this},this.setCH=function(a){return this.uaCH=a,this},this.detectFeature=function(){if(I&&I.userAgent==this.ua)switch(this.itemType){case S:I.brave&&typeof I.brave.isBrave==_e&&this.set(l,"Brave");break;case U:!this.get(n)&&q&&q[w]&&this.set(n,w),this.get(o)=="Macintosh"&&I&&typeof I.standalone!==j&&I.maxTouchPoints&&I.maxTouchPoints>2&&this.set(o,"iPad").set(n,f);break;case A:!this.get(l)&&q&&q[ie]&&this.set(l,q[ie]);break;case te:var a=this.data,d=function(r){return a[r].getItem().detectFeature().get()};this.set(S,d(S)).set(B,d(B)).set(U,d(U)).set(O,d(O)).set(A,d(A))}return this},this.parseUA=function(){return this.itemType!=te&&rt.call(this.data,this.ua,this.rgxMap),this.itemType==S&&this.set(Se,ot(this.get(u))),this},this.parseCH=function(){var a=this.uaCH,d=this.rgxMap;switch(this.itemType){case S:case O:var r=a[wt]||a[pt],g;if(r)for(var h in r){var p=r[h].brand||r[h],m=r[h].version;this.itemType==S&&!/not.a.brand/i.test(p)&&(!g||/chrom/i.test(g)&&p!=xt)&&(p=z(p,{Chrome:"Google Chrome",Edge:"Microsoft Edge","Chrome WebView":"Android WebView","Chrome Headless":"HeadlessChrome","Huawei Browser":"HuaweiBrowser","MIUI Browser":"Miui Browser","Opera Mobi":"OperaMobile",Yandex:"YaBrowser"}),this.set(l,p).set(u,m).set(Se,ot(m)),g=p),this.itemType==O&&p==xt&&this.set(u,m)}break;case B:var C=a[T];C&&(C&&a[Ve]=="64"&&(C+="64"),rt.call(this.data,C+";",d));break;case U:if(a[w]&&this.set(n,w),a[o]&&(this.set(o,a[o]),!this.get(n)||!this.get(c))){var P={};rt.call(P,"droid 9; "+a[o]+")",d),!this.get(n)&&P.type&&this.set(n,P.type),!this.get(c)&&P.vendor&&this.set(c,P.vendor)}if(a[Y]){var G;if(typeof a[Y]!="string")for(var pe=0;!G&&pe<a[Y].length;)G=z(a[Y][pe++],Lt);else G=z(a[Y],Lt);this.set(n,G)}break;case A:var _=a[ie];if(_){var K=a[mt];_==ut&&(K=parseInt(ot(K),10)>=13?"11":"10"),this.set(l,_).set(u,K)}this.get(l)==ut&&a[o]=="Xbox"&&this.set(l,"Xbox").set(u,void 0);break;case te:var Q=this.data,H=function(Oe){return Q[Oe].getItem().setCH(a).parseCH().get()};this.set(S,H(S)).set(B,H(B)).set(U,H(U)).set(O,H(O)).set(A,H(A))}return this},N.call(this,[["itemType",s],["ua",t],["uaCH",i],["rgxMap",e],["data",Ri(this,s)]]),this}function L(s,t,e){if(typeof s===ue?(Be(s,!0)?(typeof t===ue&&(e=t),t=s):(e=s,t=void 0),s=void 0):typeof s===lt&&!Be(t,!0)&&(e=t,t=void 0),e&&typeof e.append===_e){var i={};e.forEach(function(h,p){i[p]=h}),e=i}if(!(this instanceof L))return new L(s,t,e).getResult();var a=typeof s===lt?s:e&&e[vt]?e[vt]:I&&I.userAgent?I.userAgent:le,d=new Qt(e,!0),r=t?xi(_t,t):_t,g=function(h){return h==te?function(){return new Bt(h,a,r,d).set("ua",a).set(S,this.getBrowser()).set(B,this.getCPU()).set(U,this.getDevice()).set(O,this.getEngine()).set(A,this.getOS()).get()}:function(){return new Bt(h,a,r[h],d).parseUA().get()}};return N.call(this,[["getBrowser",g(S)],["getCPU",g(B)],["getDevice",g(U)],["getEngine",g(O)],["getOS",g(A)],["getResult",g(te)],["getUA",function(){return a}],["setUA",function(h){return ge(h)&&(a=h.length>dt?Te(h,dt):h),this}]]).setUA(a),this}L.VERSION=vi;L.BROWSER=qe([l,u,Se,n]);L.CPU=qe([T]);L.DEVICE=qe([o,c,n,Ce,w,y,f,R,Me]);L.ENGINE=L.OS=qe([l,u]);class Xt{constructor(t,e){b(this,"config");b(this,"sdkConfig");this.config=t,this.sdkConfig=e}on(t,e,i){const a=function(r){r.data.message!==`kalamba:wrapper-rgs:${t}`&&r.data.message!==`kalamba:wrapper:${t}`||e(r.data.payload)};window.addEventListener("message",a,i)}send(t,...[e]){window.postMessage({message:`kalamba:rgs:${t}`,payload:e})}}class Ui{constructor(t){b(this,"socket",null);b(this,"webSocketUrl");b(this,"eventListeners",{close:[],error:[],message:[]});b(this,"connect",async()=>{const t=new WebSocket(this.webSocketUrl);return t.addEventListener("message",this.handleMessage),new Promise(e=>{t.addEventListener("open",i=>{this.handleOpen(i),e(this.socket)},{once:!0})})});b(this,"send",t=>{if(this.socket==null)throw new Error("Cannot send message, the WebSocket connection is not open");this.socket.send(t)});b(this,"close",()=>{if(this.socket==null)throw new Error("Cannot close the WebSocket connection that is not open");this.socket.close()});b(this,"handleClose",t=>{this.eventListeners.close.forEach(e=>{e(t)}),this.socket.removeEventListener("message",this.handleMessage),this.socket.removeEventListener("close",this.handleClose),this.socket.removeEventListener("error",this.handleError),this.socket=null});b(this,"handleError",t=>{this.eventListeners.error.forEach(e=>{e(t)})});b(this,"handleMessage",t=>{this.eventListeners.message.forEach(e=>{e(t)})});b(this,"handleOpen",t=>{const e=t.target;e.addEventListener("close",this.handleClose),e.addEventListener("error",this.handleError),this.socket=e});this.webSocketUrl=t}addEventListener(t,e){this.eventListeners[t].push(e)}removeEventListener(t,e){const i=this.eventListeners[t].indexOf(e);i!==-1&&this.eventListeners[t].splice(i,1)}}function Le(s){return JSON.parse(s==null?void 0:s.data)}function Li(s){var t;return((t=s==null?void 0:s.header)==null?void 0:t.name)==="Ping"}function Ft(s){var t;return((t=s==null?void 0:s.header)==null?void 0:t.name)==="RealityCheck"}function Fe(s){return s.header.name==="GameEvent"}function _i(s){return Fe(s)&&s.body.event==="OPEN_GAME"}function Nt(s){return s.header.code!==1}function Bi(s){return Fe(s)&&s.body.event.includes("_RESULT")}var se,Ie;class Fi extends Ui{constructor(e,i){const a=new URL(e.apiUrl);a.searchParams.set("cageCode",e.cageCode),a.searchParams.set("gameCode",e.gameCode),a.searchParams.set("operatorCode",e.operatorCode),a.searchParams.set("playMode",e.playMode),a.searchParams.set("token",e.token),a.searchParams.set("username",e.username);super(a.toString());b(this,"cId",0);b(this,"mId",0);b(this,"seqId",0);b(this,"gameCode");M(this,se);M(this,Ie);b(this,"onMessage",e=>{const i=Le(e);(Fe(i)||Li(i)||Ft(i))&&this.sendAcknowledgement(i),Ft(i)&&this.handleRealityCheck(i)});this.eventListeners.realityCheck=[],this.gameCode=e.gameCode,v(this,se,i.requestTimeoutMs),v(this,Ie,i.gameVersion??"unknown"),this.addEventListener("message",this.onMessage)}handleRealityCheck(e){this.eventListeners.realityCheck.forEach(i=>{i(e.body)})}addEventListener(e,i){super.addEventListener(e,i)}removeEventListener(e,i){super.removeEventListener(e,i)}buildHeader(e,i=null){return{cId:i??++this.cId,code:i!==null?1:void 0,mId:++this.mId,name:e}}buildPayload(e,i){return JSON.stringify({body:i,header:e})}getBodyExtras(e){return{action:e,seqId:++this.seqId}}request(e,i){const a=this.buildPayload(e,i);return new Promise((d,r)=>{setTimeout(()=>r({type:"timeout"}),k(this,se));const g=h=>{const p=Le(h);try{e.cId===p.header.cId&&(this.removeEventListener("message",g),p.header.code===1?d(p):r({message:p,type:"error"}))}catch{r({message:p,type:"error"})}};this.addEventListener("message",g),this.send(a)})}freeRounds(e){const i=this.buildHeader("ActivateFreeRound");return this.request(i,e).then(a=>a.body).catch(a=>{var d;throw{data:(d=a==null?void 0:a.message)==null?void 0:d.body,type:a.type}})}async authenticate(e=!1){const i=this.buildHeader("Authenticate"),a={clientType:3,version:k(this,Ie),reconnect:e};return this.request(i,a).then(d=>d.body).catch(d=>{var r;throw{data:(r=d==null?void 0:d.message)==null?void 0:r.body,type:d.type}})}async openGame(){const e=this.buildHeader("OpenGame"),i={gameCode:this.gameCode};return new Promise((a,d)=>{const r=g=>{const h=Le(g);_i(h)?(this.removeEventListener("message",r),a(h.body)):Nt(h)&&d({data:h.body,type:"error"})};this.addEventListener("message",r),this.request(e,i).catch(g=>{var h;return d({data:(h=g==null?void 0:g.message)==null?void 0:h.body,type:g.type})})})}sendAcknowledgement(e){const{name:i,cId:a}=e.header,d=this.buildHeader(i,a),r=this.buildPayload(d,{});this.send(r)}sendAction(e,i){const a=this.buildHeader("GameAction"),d={...this.getBodyExtras(e),data:i};return new Promise((r,g)=>{const h=p=>{const m=Le(p);Fe(m)&&d.seqId===m.body.correlationSeqId&&(this.removeEventListener("message",h),Bi(m)?r(m.body):Nt(m)&&g({data:m.body,type:"error"}))};this.addEventListener("message",h),this.request(a,d).catch(p=>{var m;return g({data:(m=p==null?void 0:p.message)==null?void 0:m.body,type:p.type})})})}setRequestTimeoutMs(e){v(this,se,e)}}se=new WeakMap,Ie=new WeakMap;const Ni={CA_BC:"CA",CA_ON:"CA",GER:"DE",US_CT:"US",US_MI:"US",US_NJ:"US",USA:"US"};function Dt(s){return!s||s==="NOT_APPLICABLE"?null:Ni[s]??s}function Jt(s){const t=s.contract;return t?{contract:{balance:{coins:t.balance,version:t.balanceVersion},coinValueInCents:t.coinValueInCents,country:t.countryCode,currency:t.currencyCode,jurisdiction:Dt(t.jurisdictionCode),uiMessages:t.uiMessages,username:t.username}}:{contract:{balance:{coins:s.balance,version:s.balanceVersion},coinValueInCents:s.coinValueInCents,country:s.countryCode,currency:s.currencyCode,jurisdiction:Dt(s.jurisdictionCode),uiMessages:s.uiMessages,username:s.username}}}function Yt(s){var t,e;return{code:((t=s.data)==null?void 0:t.code)??He.RgsErrorCode.UNKNOWN,details:(e=s.data)==null?void 0:e.details}}function Zt(s,t,e){const i=t.contract;if(!i){const a=t.data;return{contract:{bet:{available:a.additionalConfigData.availableMultipliersPerBaseBet,default:{base:a.additionalConfigData.defaultBet.baseBet,multiplier:a.additionalConfigData.defaultBet.betMultiplier},max:a.additionalConfigData.maxAllowedOverallBetInCoins??null,last:a.gameState.betFromCurrentRound?{base:a.gameState.betFromCurrentRound.baseBet,multiplier:a.gameState.betFromCurrentRound.betMultiplier}:null,lastPaid:a.gameState.lastPlacedMainGameBet?{base:a.gameState.lastPlacedMainGameBet.baseBet,multiplier:a.gameState.lastPlacedMainGameBet.betMultiplier}:null},balance:{coins:t.balance,version:t.balanceVersion},freeRounds:(a.FREE_ROUNDS??[]).map(d=>({conf:{base:d.conf.baseBet,multiplier:d.conf.betMultiplier,numAwarded:d.conf.numAwarded},data:{numPlayed:d.data.numPlayed,win:d.data.winAmount,numLeft:d.data.numLeft},id:d.id,rejectable:d.rejectable,skippable:d.skippable,status:d.status,type:d.type})),gameModel:a.additionalConfigData.gameModelFile,metaData:a.gameConfigData.metaData,roundId:a.gameState.cycleId,serverTime:t.balanceVersion,sessionId:a.gameState.sessionId,stateType:{thisRound:a.gameState.stateTypeThisRound,nextRound:a.gameState.stateTypeNextRound},uiMessages:s.uiMessages,win:{max:a.maxWin??null,round:a.gameState.totalWinFromCurrentRound,total:a.gameState.totalWinFromCurrentGameCycle}},data:a}}return{contract:{bet:{available:i.availableMultipliersPerBaseBet,default:{base:i.defaultBet.baseBet,multiplier:i.defaultBet.betMultiplier},max:i.maxBetInCoins??null,last:i.lastBet?{base:i.lastBet.baseBet,multiplier:i.lastBet.betMultiplier}:null,lastPaid:i.lastMainGameBet?{base:i.lastMainGameBet.baseBet,multiplier:i.lastMainGameBet.betMultiplier}:null},balance:{coins:i.balanceInCoins,version:i.balanceVersion},freeRounds:(i.freeRounds??[]).map(a=>({conf:{base:a.conf.baseBet,multiplier:a.conf.betMultiplier,numAwarded:a.conf.numAwarded},data:{numPlayed:a.data.numPlayed,win:a.data.winAmount,numLeft:a.data.numLeft},id:a.id,rejectable:a.rejectable,skippable:a.skippable,status:a.status,type:a.type})),gameModel:i.gameModelFile,metaData:i.metaData,roundId:i.roundId,serverTime:i.serverTime,sessionId:i.sessionId,stateType:{thisRound:i.stateTypeThisRound,nextRound:i.stateTypeNextRound},uiMessages:s.contract.uiMessages.concat(i.uiMessages),win:{max:i.maxWinInCoins??null,round:i.roundWin,total:i.totalWin}},data:e?e(t.opaqueGameServerToUi):t.opaqueGameServerToUi}}function ei(s){var t,e;return{code:((t=s.data)==null?void 0:t.code)??He.RgsErrorCode.UNKNOWN,details:(e=s.data)==null?void 0:e.details}}function ti(s,t){const e=s.contract;if(!e){const i=s.data;return{contract:{bet:{last:i.gameState.betFromCurrentRound?{base:i.gameState.betFromCurrentRound.baseBet,multiplier:i.gameState.betFromCurrentRound.betMultiplier}:null,lastPaid:{base:(i.gameState.lastPlacedMainGameBet??i.gameState.betFromCurrentRound).baseBet,multiplier:(i.gameState.lastPlacedMainGameBet??i.gameState.betFromCurrentRound).betMultiplier}},balance:{coins:s.balance,version:s.balanceVersion},freeRounds:(i.FREE_ROUNDS??[]).map(a=>({conf:{base:a.conf.baseBet,multiplier:a.conf.betMultiplier,numAwarded:a.conf.numAwarded},data:{numPlayed:a.data.numPlayed,win:a.data.winAmount,numLeft:a.data.numLeft},id:a.id,rejectable:a.rejectable,skippable:a.skippable,status:a.status,type:a.type})),serverTime:s.balanceVersion,roundId:i.gameState.cycleId,stateType:{thisRound:i.gameState.stateTypeThisRound,nextRound:i.gameState.stateTypeNextRound},uiMessages:i.uiMessages,win:{round:i.gameState.totalWinFromCurrentRound,total:i.gameState.totalWinFromCurrentGameCycle}},data:i}}return{contract:{bet:{last:e.lastBet?{base:e.lastBet.baseBet,multiplier:e.lastBet.betMultiplier}:null,lastPaid:{base:e.lastMainGameBet.baseBet,multiplier:e.lastMainGameBet.betMultiplier}},balance:{coins:e.balanceInCoins,version:e.balanceVersion},freeRounds:(e.freeRounds??[]).map(i=>({conf:{base:i.conf.baseBet,multiplier:i.conf.betMultiplier,numAwarded:i.conf.numAwarded},data:{numPlayed:i.data.numPlayed,win:i.data.winAmount,numLeft:i.data.numLeft},id:i.id,rejectable:i.rejectable,skippable:i.skippable,status:i.status,type:i.type})),serverTime:e.serverTime,roundId:e.roundId,stateType:{thisRound:e.stateTypeThisRound,nextRound:e.stateTypeNextRound},uiMessages:e.uiMessages,win:{round:e.roundWin,total:e.totalWin}},data:t?t(s.opaqueGameServerToUi):s.opaqueGameServerToUi}}function ii(s){var t,e;return{code:((t=s.data)==null?void 0:t.code)??He.RgsErrorCode.UNKNOWN,details:(e=s.data)==null?void 0:e.details}}const Di={parseAuthenticateResponse:Jt,parseAuthenticateError:Yt,parseOpenGameResponse:Zt,parseOpenGameError:ei,parsePlayResponse:ti,parsePlayError:ii},Gi={bul:"bg",chi:"zh",zho:"zh",hrv:"hr",cze:"cs",dan:"da",dut:"nl",eng:"en",est:"et",fin:"fi",fra:"fr",ger:"de",gre:"el",hun:"hu",ind:"id",ita:"it",jpn:"ja",kor:"ko",nor:"no",pol:"pl",por:"pt",rum:"ro",rus:"ru",srp:"sr",slo:"sk",spa:"es",swe:"sv",tha:"th",tur:"tr",ukr:"uk",vie:"vi"},{device:Hi}=L(navigator.userAgent),Vi=x("KalambaBullseyePlugin","color:#000000;font-weight:bold;");class qi extends Xt{constructor(...e){super(...e);b(this,"socket");b(this,"error");this.on("openGame",async()=>{try{this.error=void 0;const i=await this.openGame();this.send("openGameResponse",i)}catch(i){this.error=i,this.send("openGameError",i)}}),this.on("play",async i=>{try{this.error=void 0;const a=await this.play(i);this.send("playResponse",a)}catch(a){this.error=a,this.send("playError",a)}}),this.on("freeRounds",async i=>{try{this.error=void 0,await this.socket.freeRounds(i),this.send("freeRoundsResponse",i)}catch(a){this.error=a,this.send("freeRoundsError",a)}}),this.on("configured",i=>{this.socket.setRequestTimeoutMs(i.ui.requestTimeoutMs)}),this.registerFromSdkEvents()}initialize(e){this.socket=new Fi(e,{gameVersion:this.config.gameVersion,requestTimeoutMs:this.sdkConfig.ui.requestTimeoutMs}),["fireboltroulette"].includes(e.gameCode)||(this.socket.addEventListener("close",i=>{i.code===1008?this.error||this.send("error",{type:"CLOSE",messageCode:"TOO_MANY_OPEN_GAMES",messageKey:"RgsError.TOO_MANY_OPEN_GAMES"}):i.code===1011?this.error||this.send("error",{type:"CLOSE",messageCode:"UNKNOWN",messageKey:"RgsError.UNKNOWN"}):this.reconnect()}),["mobile","tablet"].includes(Hi.type??"")&&document.addEventListener("visibilitychange",async()=>{document.hidden||(this.socket.socket?this.socket.socket&&[WebSocket.CONNECTING,WebSocket.OPEN].includes(this.socket.socket.readyState)&&this.socket.close():this.reconnect())})),this.socket.addEventListener("error",i=>Vi("error",i)),this.socket.addEventListener("realityCheck",i=>{this.send("realityCheck",i)})}async reconnect(){try{await this.socket.connect(),await this.socket.authenticate(!0),await this.socket.openGame()}catch{this.send("error",{type:"CLOSE",messageCode:"CONNECTION_ERROR",messageKey:"RgsError.CONNECTION_ERROR"})}}async openGame(){var H,Oe;const e=new URLSearchParams(window.location.search),i=e.get("apiUrl"),a=e.get("cageCode"),d=e.get("gameCode"),r=e.get("operatorCode"),g=e.get("playMode"),h=e.get("token"),p=e.get("username"),m=e.get("gameHistoryUrl"),C=e.get("homeUrl")??void 0,P=e.get("cashierUrl")??void 0;this.initialize({apiUrl:i,cageCode:a,gameCode:d,operatorCode:r,playMode:g,token:h,username:p});try{await this.socket.connect()}catch{throw{type:"error",data:{code:He.RgsErrorCode.CONNECTION_ERROR}}}let G;try{G=await this.socket.authenticate()}catch(X){throw{type:X.type,data:X.type==="error"?Yt(X.data):void 0}}let pe;try{pe=await this.socket.openGame()}catch(X){throw{type:X.type,data:X.type==="error"?ei(X.data):void 0}}const _=Jt(G),K=Zt(G,pe,this.config.dataDecoder&&ze.decoders[this.config.dataDecoder]);this.sdkConfig.api={...this.sdkConfig.api,brand:a,game:d,integration:r,jurisdiction:_.contract.jurisdiction,playMode:g,user:_.contract.username,integrationData:{token:h},country:_.contract.country,currency:_.contract.currency,coinValueInCents:_.contract.coinValueInCents,gameHistoryUrl:m,homeUrl:C,cashierUrl:P,backendSessionId:K.contract.sessionId,lastRoundId:K.contract.roundId};const Q=(Oe=(H=e.get("languageCode"))==null?void 0:H.split("_"))==null?void 0:Oe[0];return Q&&(this.sdkConfig.ui.language=Q.length===3?Gi[Q]??Q:Q),K}async play(e){for(;!this.socket.socket;)await new Promise(P=>setTimeout(()=>P(),500));const{contract:{bet:i,forcedOutcomes:a,...d},extra:r,payloadToInject:g,actionType:h}=e,p=this.config.dataEncoder&&ze.encoders[this.config.dataEncoder],m={bet:i?{baseBet:i.base,betMultiplier:i.multiplier}:void 0,forcedOutcomes:a,...d,...g,opaqueUiToGameServer:p?p(r):r};let C;try{C=await this.socket.sendAction(h,m)}catch(P){throw{type:P.type,data:P.type==="error"?ii(P.data):void 0}}return ti(C,this.config.dataDecoder&&ze.decoders[this.config.dataDecoder])}registerFromSdkEvents(){this.on("history",()=>{const{api:{game:e,integration:i,integrationData:a,jurisdiction:d,user:r,gameHistoryUrl:g},ui:{language:h}}=this.sdkConfig,p=r.replace(/^user_/,"").replace(new RegExp(`_${i}$`),""),m=new URL(window.location.href);m.hostname=m.hostname.replace(/^v\./,"").replace(/^play\./,"history."),m.pathname=m.pathname.replace(/(\/[0-9]+\.[0-9]+\.[0-9]+)?\/wrapper\.html/,"/list/index.html"),m.search="",m.searchParams.set("apiUrl",new URL(g).origin),m.searchParams.set("gameCode",e),d&&m.searchParams.set("jurisdiction",d),m.searchParams.set("operatorCode",i),m.searchParams.set("token",a.token),m.searchParams.set("username",p),m.searchParams.set("languageCode",h),this.config.gameHistoryUrl&&m.searchParams.set("gameHistoryUrl",this.config.gameHistoryUrl),window.open(m.toString(),"_blank")})}}class si{constructor(t,e,i){b(this,"trackers");b(this,"config");b(this,"sdkConfig");this.trackers=t,this.config=e,this.sdkConfig=i}on(t,e,i){const a=function(r){r.data.message!==`kalamba:wrapper-telemetry:${t}`&&r.data.message!==`kalamba:wrapper:${t}`||e(r.data.payload)};window.addEventListener("message",a,i)}track(t,e){this.trackers.forEach(i=>i.track(t,e))}}function Gt(s){return s.reduce((t,e)=>t+e,0)}function zi(s){const t=s.length,e=Gt(s)/t,i=s.map(d=>Math.pow(d-e,2)),a=Gt(i)/t;return Math.sqrt(a)}class Ht{constructor(){b(this,"rafId",-1);b(this,"startTime",0);b(this,"stopTime",0);b(this,"frames",[]);b(this,"calculateFPS",()=>{const t=Math.floor((this.stopTime-this.startTime)/1e3);return this.frames.map(e=>Math.floor((e-this.startTime)/1e3)).reduce((e,i,a,d)=>(d[a]!==d[a-1]?e.push(1):e[e.length-1]++,e),[]).slice(0,t)});b(this,"getReport",()=>{const t=this.calculateFPS(),e=Math.floor(this.frames.length/((this.stopTime-this.startTime)/1e3)),i=t.length>0?Math.max(...t):e,a=t.length>0?Math.min(...t):e,d=t.length>0?zi(t):0;return{fpsAvg:e,fpsMax:i,fpsMin:a,fpsStdDev:d}});b(this,"start",()=>{this.startTime=Date.now(),this.frames=[],this.trackFrames()});b(this,"stop",()=>{cancelAnimationFrame(this.rafId),this.stopTime=Date.now()});b(this,"trackFrames",()=>{this.frames.push(Date.now()),this.rafId=requestAnimationFrame(this.trackFrames)})}}const Wi="landscape",ji="portrait";function $i(){try{const s=document.createElement("canvas");return!!window.WebGLRenderingContext&&(s.getContext("webgl")||s.getContext("experimental-webgl"))instanceof WebGLRenderingContext}catch{return!1}}async function Ki(){if(!window.createImageBitmap)return!1;const e=await(await fetch("data:image/webp;base64,UklGRiQAAABXRUJQVlA4IBgAAAAwAQCdASoCAAEAAQAcJaQAA3AA/v3AgAA=")).blob();try{return await createImageBitmap(e),!0}catch{return!1}}function ct(){return window.innerWidth>=window.innerHeight?Wi:ji}var Ne,ae,ne,oe,Pe,De,Ae,Ge;class Qi extends si{constructor(...e){super(...e);b(this,"FPS_SAMPLE_INTERVAL",1e4);M(this,Ne,0);M(this,ae);M(this,ne);M(this,oe);M(this,Pe,!1);M(this,De,!1);M(this,Ae,"");M(this,Ge,[]);v(this,ne,{}),v(this,oe,this.deviceInfo()),v(this,ae,this.config.gameVersion),this.on("state",({balance:i})=>{v(this,Ne,i)}),this.on("autoplay",({action:i})=>{["start","resume"].includes(i)?v(this,Pe,!0):v(this,Pe,!1)}),this.on("settings",({fastPlay:i})=>{i!==void 0&&v(this,De,i)}),this.registerEvents()}async registerEvents(){k(this,oe).then(e=>{this.track("Device Information",e)}),this.on("loadStart",()=>{this.track("Game Loading",{progress:0,step:"initial"})}),this.on("loadProgress",e=>{this.track("Game Loading",{progress:e.progress})}),this.on("loadEnd",()=>{this.track("Game Loading",{progress:100,step:"complete"})}),this.on("error",e=>{this.track("System Message",{systemMessageText:e.messageCode,systemMessageType:e.type})}),this.on("openGameResponse",async e=>{v(this,Ae,e.contract.stateType.nextRound),v(this,ne,{balanceInCoins:e.contract.balance.coins,clientVersion:k(this,ae),coinValueInCents:this.sdkConfig.api.coinValueInCents,coinValueInCentsFloat:this.sdkConfig.api.coinValueInCents,currency:this.sdkConfig.api.currency,defaultBaseBet:e.contract.bet.default.base,defaultBetMultiplier:e.contract.bet.default.multiplier,environment:"release",gameCode:this.sdkConfig.api.game,gameCodeServer:this.sdkConfig.api.game,gameModelFile:e.contract.gameModel,jurisdiction:this.sdkConfig.api.jurisdiction,languageCode:this.sdkConfig.ui.language,operatorName:"kalamba",partnerId:this.sdkConfig.api.brand,partnerParentId:this.sdkConfig.api.integration,platform:"WEB",playMode:this.sdkConfig.api.playMode,referrer:window.location.hostname,rootTrackingSessionID:this.sdkConfig.api.sessionId,backendSessionID:this.sdkConfig.api.backendSessionId,serverVersion:e.contract.metaData.version}),this.track("Game Open",k(this,ne))}),this.on("playCycleEnd",async e=>{const i=await k(this,oe),{base:a,multiplier:d}=e.contract.bet.lastPaid??{},r=e.contract.balance.coins,g=e.contract.bet.lastPaid.base*e.contract.bet.lastPaid.multiplier,h=e.contract.win.total,p=h-g,m="spin",C=e.contract.roundId;this.track("Betting Activity",{balance:r-p,balanceAfter:r,baseBet:a,betMultiplier:d,betType:m,gameVersion:k(this,ae),coinValueInCents:this.sdkConfig.api.coinValueInCents,coinValueInCentsFloat:this.sdkConfig.api.coinValueInCents,currency:this.sdkConfig.api.currency,environment:"release",gameCode:this.sdkConfig.api.game,gameCodeServer:this.sdkConfig.api.game,isMobile:i.isMobile,netResult:p,operatorName:"kalamba",orientation:ct(),partnerId:this.sdkConfig.api.brand,partnerParentId:this.sdkConfig.api.integration,platform:"WEB",playMode:this.sdkConfig.api.playMode,roundId:C,roundTypes:["BaseGame"],totalBet:g,totalWin:h}),v(this,Ge,[])}),this.on("telemetry.click",e=>{this.track("UI Interaction",{action:"click",...this.getExtraUiInteractionData(),...e})}),this.on("telemetry.orientationChange",()=>{this.track("UI Interaction",{action:"orientationChange",...this.getExtraUiInteractionData()})}),this.reportFpsSample(),this.reportFpsRound()}reportFpsSample(){const e=new Ht,i=()=>{e.stop();const d=e.getReport();this.track("FPS Performance",{...d,fpsType:"sample"}),a()},a=async()=>{e.start(),setTimeout(i,this.FPS_SAMPLE_INTERVAL)};a()}reportFpsRound(){const e=new Ht;this.on("playCycleStart",()=>{e.start()}),this.on("playCycleEnd",()=>{e.stop();const i=e.getReport();this.track("FPS Performance",{...i,fpsType:"playCycleStart->playCycleEnd"})})}getExtraUiInteractionData(){return{orientation:ct(),stateType:k(this,Ae)}}async deviceInfo(){var g;const{browser:e,device:i,os:a}=L(navigator.userAgent),d=$i(),r=await Ki();return{browserName:e.name,browserVersion:e.version,connection:(g=navigator.connection)==null?void 0:g.effectiveType,deviceName:i.model,deviceType:i.type,isMobile:["mobile","tablet"].includes(i.type??""),isWebGLSupported:d,isWebPSupported:r,manufacturer:i.vendor,operatingSystem:a.name,operatingSystemVersion:a.version,orientation:ct(),pixelRatio:window.devicePixelRatio,screenHeight:window.screen.height,screenSize:`${window.screen.width}x${window.screen.height}`,screenWidth:window.screen.width,timezoneOffsetMinutes:new Date().getTimezoneOffset(),windowHeight:window.innerHeight,windowSize:`${window.innerWidth}x${window.innerHeight}`,windowWidth:window.innerWidth}}}Ne=new WeakMap,ae=new WeakMap,ne=new WeakMap,oe=new WeakMap,Pe=new WeakMap,De=new WeakMap,Ae=new WeakMap,Ge=new WeakMap;var Xi=gt.requireNoop();const Vt=gt.getDefaultExportFromCjs(Xi);class bt{constructor(t,e){b(this,"config");b(this,"sdkConfig");this.config=t,this.sdkConfig=e}}const qt=25,zt=1e4;var re,ce,de,W;class Ji extends bt{constructor(...e){super(...e);M(this,re,"https://europe-west3-stargazer-328808.cloudfunctions.net/collect-events");M(this,ce);M(this,de);M(this,W,[]);b(this,"processQueueForced");v(this,ce,new Date().getTime()),v(this,W,[]),this.processQueueForced=this.processQueue.bind(this,!0),this.schedule(),fetch(k(this,re),{method:"OPTIONS"}).catch(Vt),this.subscribe()}subscribe(){window.addEventListener("beforeunload",this.processQueueForced,!1),window.addEventListener("pagehide",this.processQueueForced,!1),window.addEventListener("visibilitychange",this.processQueueForced,!1)}schedule(){k(this,de)&&clearTimeout(k(this,de)),v(this,de,window.setTimeout(()=>this.processQueue(),zt))}send(e){v(this,ce,new Date().getTime());try{navigator.sendBeacon(k(this,re),JSON.stringify(e))}catch{fetch(k(this,re),{body:JSON.stringify(e),method:"POST",headers:{"Content-Type":"application/json"},keepalive:!0}).catch(Vt)}this.schedule()}addToQueue(e){k(this,W).push(e),this.processQueue()}processQueue(e=!1){if(!(this.sdkConfig==null||!this.sdkConfig.ui.feature.allowTelemetry)&&!(!e&&k(this,W).length<qt&&new Date().getTime()-k(this,ce)<zt))for(;k(this,W).length;){const i=k(this,W).splice(0,qt).map(a=>({...a,sessionID:this.sdkConfig.api.sessionId,userID:this.sdkConfig.api.user}));this.send(i)}}track(e,i){this.addToQueue({eventName:e,eventParams:i,eventTimestamp:new Date().getTime(),eventUUID:gt.v4()})}}re=new WeakMap,ce=new WeakMap,de=new WeakMap,W=new WeakMap;const Yi=x("LoggingTracker","color:#000000;font-weight:bold;");class Zi extends bt{track(t,e){Yi(`@${this.sdkConfig.api.user}`,`[${t}]`,e)}}exports.BasicPlugin=ri;exports.CasinoPlugin=D;exports.DebuggingPlugin=di;exports.GigPlugin=ui;exports.KalambaBullseyeParsers=Di;exports.KalambaBullseyePlugin=qi;exports.KalambaStargazerPlugin=Qi;exports.KalambaStargazerTracker=Ji;exports.LoggingTracker=Zi;exports.OryxPlugin=gi;exports.PariplayPlugin=bi;exports.QuantaPlugin=ki;exports.RelaxFEIMPlugin=fi;exports.RgsPlugin=Xt;exports.TelemetryPlugin=si;exports.Tracker=bt;exports.TukoPlugin=yi;
5
+ "use strict";var rs=Object.defineProperty;var ft=i=>{throw TypeError(i)};var cs=(i,t,e)=>t in i?rs(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e;var b=(i,t,e)=>cs(i,typeof t!="symbol"?t+"":t,e),yt=(i,t,e)=>t.has(i)||ft("Cannot "+e);var k=(i,t,e)=>(yt(i,t,"read from private field"),e?e.call(i):t.get(i)),M=(i,t,e)=>t.has(i)?ft("Cannot add the same private member more than once"):t instanceof WeakSet?t.add(i):t.set(i,e),v=(i,t,e,s)=>(yt(i,t,"write to private field"),s?s.call(i,e):t.set(i,e),e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const He=require("./errors-BXO3dlhS.cjs"),qe=require("./encoders-DVHzIpWT.cjs"),gt=require("./v4-CoqWKwnX.cjs");function A(i,t){return(e,...s)=>{console.log(`[%c${i}\x1B[m] %s`,t,e,...s)}}function Kt(i,t){return Math.round(i*100/t)}class U{constructor(t,e){b(this,"config");b(this,"sdkConfig");this.config=t,this.sdkConfig=e}on(t,e,s){const a=function(c){c.data.message!==`kalamba:wrapper-casino:${t}`&&c.data.message!==`kalamba:wrapper:${t}`||e(c.data.payload)};window.addEventListener("message",a,s)}send(t,...[e]){window.postMessage({message:`kalamba:casino:${t}`,payload:e})}}const ds=A("BasicPlugin","color:#000000;font-weight:bold;");class ls extends U{constructor(...t){super(...t),this.registerToSdkEvents(),this.registerFromSdkEvents(),ds("configured")}registerToSdkEvents(){window.addEventListener("message",t=>{try{const{type:e,payload:s}=t.data;switch(e){case"doAudioSettings":this.send("settings",{music:s==null?void 0:s.musicEnabled,sounds:s==null?void 0:s.soundEnabled});return;case"doBalanceUpdate":const{currency:a,coinValueInCents:r}=this.sdkConfig.api;s.currency===a&&typeof s.balanceInCurrency=="number"?this.send("balance",{balance:Kt(s.balanceInCurrency,r)}):(s.balanceInCoins,this.send("balance",{balance:s.balanceInCoins}));return;case"doGamePause":this.send("freeze");return;case"doGameResume":this.send("unfreeze");return;case"doGameSuspend":this.send("suspend");return;default:return}}catch{}})}registerFromSdkEvents(){this.on("close",()=>{if(this.sdkConfig.api.homeUrl)try{window.top.location=this.sdkConfig.api.homeUrl}catch{window.location=this.sdkConfig.api.homeUrl}else try{window.top.history.back()}catch{window.history.back()}})}}const E=A("▼ DebuggingPlugin IN ▼","color:#444444;font-weight:bold;"),us=A("▲ DebuggingPlugin OUT ▲","color:#444444;font-weight:bold;");class hs extends U{constructor(...t){super(...t),this.registerDebugToSdkEvents(),this.registerSdkToDebugEvents()}registerDebugToSdkEvents(){window.DebuggingPlugin={balance:t=>this._send("balance",t),bet:t=>this._send("bet",t),choice:t=>this._send("choice",t),close:t=>this._send("close",t),help:t=>this._send("help",t),history:t=>this._send("history",t),freeze:t=>this._send("freeze",t),paytable:t=>this._send("paytable",t),settings:t=>this._send("settings",t),suspend:t=>this._send("suspend",t),unfreeze:t=>this._send("unfreeze",t)}}registerSdkToDebugEvents(){this.on("autoplay",t=>E("autoplay",t)),this.on("balance",t=>E("balance",t)),this.on("bet",t=>E("bet",t)),this.on("cashier",t=>E("cashier",t)),this.on("choice",t=>E("choice",t)),this.on("close",t=>E("close",t)),this.on("error",t=>E("error",t)),this.on("loadEnd",t=>E("loadEnd",t)),this.on("loadProgress",t=>E("loadProgress",t)),this.on("loadStart",t=>E("loadStart",t)),this.on("playCycleStart",t=>E("playCycleStart",t)),this.on("playCycleEnd",t=>E("playCycleEnd",t)),this.on("playEnd",t=>E("playEnd",t)),this.on("playError",t=>E("playError",t)),this.on("playReady",t=>E("playReady",t)),this.on("playStart",t=>E("playStart",t)),this.on("settings",t=>E("settings",t))}_send(...t){us.apply(null,t),this.send.apply(this,t)}}const kt=A("GigPlugin","color:#000000;font-weight:bold;");class gs extends U{constructor(...t){super(...t),this.registerToSdkEvents(),this.registerFromSdkEvents(),kt("configured")}postMessage(t){const e={event:t};kt("postMessage",e),window.top.postMessage(e,"*")}registerToSdkEvents(){window.addEventListener("message",t=>{try{const{data:e}=t;switch(e){case"STOP_AUTO_PLAY":this.send("suspend");return;case"BLOCK_BETS":this.send("freeze");return;case"UNBLOCK_BETS":this.send("unfreeze");return;default:return}}catch{}})}registerFromSdkEvents(){this.on("close",()=>{if(this.sdkConfig.api.homeUrl)try{window.top.location=this.sdkConfig.api.homeUrl}catch{window.location=this.sdkConfig.api.homeUrl}else try{window.top.history.back()}catch{window.history.back()}}),this.on("playReady",()=>{this.postMessage("GAME_READY")})}}const ps=A("OryxPlugin","color:#000000;font-weight:bold;");class ws extends U{constructor(...t){super(...t),this.registerToSdkEvents(),this.registerFromSdkEvents(),ps("configured")}registerToSdkEvents(){window.addEventListener("message",t=>{try{const{type:e,param:s}=t.data;switch(e){case"doBalanceUpdate":this.send("balance",{balance:s});return;case"doGamePause":this.send("freeze");return;case"doGameResume":this.send("unfreeze");return;case"doGameSuspend":this.send("suspend");return;default:return}}catch{}})}registerFromSdkEvents(){let t=0;this.on("close",()=>{window.top.postMessage({wpgaction:"close"},"*"),window.parent.postMessage({wpgaction:"close.parent"},"*")}),this.on("balance",({balance:e})=>{t!==e&&(t=e,window.top.postMessage({param:{},wpgaction:"balance"},"*"),window.parent.postMessage({param:{},wpgaction:"balance.parent"},"*"))}),this.on("loadStart",()=>{window.top.postMessage({wpgaction:"loadStart"},"*"),window.parent.postMessage({wpgaction:"loadStart.parent"},"*")}),this.on("loadEnd",()=>{window.top.postMessage({wpgaction:"loadEnd"},"*"),window.parent.postMessage({wpgaction:"loadEnd.parent"},"*")}),this.on("playStart",()=>{window.top.postMessage({wpgaction:"gameSpinStart"},"*"),window.parent.postMessage({wpgaction:"gameSpinStart.parent"},"*")}),this.on("playEnd",()=>{window.top.postMessage({wpgaction:"gameSpinEnd"},"*"),window.parent.postMessage({wpgaction:"gameSpinEnd.parent"},"*")}),this.on("cashier",({type:e})=>{switch(e){case"BALANCE_LOW":window.top.postMessage({wpgaction:"cashier"},"*"),window.parent.postMessage({wpgaction:"cashier.parent"},"*");break;case"BALANCE_INSUFFICIENT":window.top.postMessage({wpgaction:"errorOutOfMoney"},"*"),window.parent.postMessage({wpgaction:"errorOutOfMoney.parent"},"*");break}})}}const We=A("PariplayPlugin","color:#000000;font-weight:bold;");function je(i){try{window.top.location=i}catch{window.location=i}}function $e(i,t){return new Promise(function(s,a){const r=new XMLHttpRequest;r.onload=function(){r.status>=200&&r.status<300?s(r.responseText):a(r.responseText)},r.open(i,t),r.send()})}function Ke(){}function ms(i){return i.filter(function(e){return e.messageType.toUpperCase()==="DATA"})}function Qe(i){return i.filter(function(e){return["NOTIFICATION","POPUP"].includes(e.messageType.toUpperCase())})}function Qt(i){try{return JSON.parse(i.text)}catch{return{}}}function bs(i){return i.map(Qt).filter(Boolean).find(function(e){return e.betId!=null&&e.winId!=null})||{}}function fs(i){return i.map(Qt).filter(Boolean).find(function(e){return e.TotalBet!=null&&e.TotalWin!=null})||{}}class ys extends U{constructor(...t){super(...t),this.registerToSdkEvents(),this.registerFromSdkEvents(),We("configured")}postMessage(t,e){const s={lang:this.sdkConfig.ui.language,sender:this.sdkConfig.api.game,type:t};e!=null&&(s.data=e),We("postMessage",s),window.parent.postMessage(s,"*")}coinsToCurrency(t){return t*this.sdkConfig.api.coinValueInCents/100}handleContinueButton(t,e){t.link&&$e("GET",t.link),e()}handleLinkButton(t,e){switch(t.linkType.toUpperCase()){case"AJAX":$e("GET",t.link),e();return;case"AJAXRESPONSE":$e("GET",t.link).then(()=>{e()});return;case"REDIRECT":je(t.link),e();return}}handleQuitButton(t,e){this.send("close"),e()}handleCashierButton(t,e){this.send("cashier",{type:"ON_DEMAND"}),e()}handleHistoryButton(t,e){this.send("history",{source:"casino"}),e()}get buttonActions(){return{CASHIER:this.handleCashierButton,CONTINUE:this.handleContinueButton,HISTORY:this.handleHistoryButton,LINK:this.handleLinkButton,QUIT:this.handleQuitButton}}processInfoUiMessages(t){return t.reduce((e,s)=>e.then(()=>new Promise(a=>{const r=Object.assign({},s,{buttons:s.buttons.filter(c=>c.action.toUpperCase()==="CASHIER"?!!this.sdkConfig.api.cashierUrl:!0).map(c=>Object.assign({},c,{onRelease:()=>{const g=s.messageType.toUpperCase()==="POPUP"?Ke:a,h=this.buttonActions[c.action.toUpperCase()];h?h(c,g):g()}}))});We("showMessage",r)}).catch(Ke)),Promise.resolve()).then(()=>{}).catch(Ke)}registerToSdkEvents(){window.addEventListener("message",t=>{try{const{type:e}=t.data;switch(e){case"pause":case"disableSpin":this.send("freeze");return;case"resume":case"enableSpin":this.send("unfreeze");return;case"stopAutobet":this.send("suspend");return;default:return}}catch{}})}registerFromSdkEvents(){let t=0;this.on("openGameResponse",e=>{let s;try{const a=JSON.parse(JSON.parse(atob(this.sdkConfig.api.integrationData.token.split(".")[1])).token),r=JSON.parse(a.integrationSpecificAttributes.sessionData||"{}");s={ClientToken:a.integrationSpecificAttributes.clientToken,CurrencyCode:a.currency,PlayerTokenId:a.user,SessionData:r}}catch{s=void 0}this.postMessage("gameDataLoaded",{LoadGameData:s,success:!0});try{const a=Qe(e.contract.uiMessages);this.processInfoUiMessages(a)}catch{}}),this.on("balance",({balance:e})=>{t!==e&&(t=e,this.postMessage("balance",{amount:this.coinsToCurrency(e)}))}),this.on("close",()=>{if(this.sdkConfig.api.homeUrl)if(this.sdkConfig.api.homeUrl==="(back)")try{window.top.history.back()}catch{window.history.back()}else this.sdkConfig.api.homeUrl==="(api)"?this.postMessage("quit"):je(this.sdkConfig.api.homeUrl)}),this.on("playEnd",e=>{this.postMessage("roundEnded",{balanceAfter:this.coinsToCurrency(e.contract.balance.coins),win:this.coinsToCurrency(e.contract.win.round)});try{const s=Qe(e.contract.uiMessages);this.processInfoUiMessages(s)}catch{}}),this.on("playError",e=>{this.postMessage("ticketReceived",{ErrorCode:e.type==="error"?e.data.code:"TIMEOUT",ErrorMessage:"ERROR",Status:{ErrCode:e.type==="error"?e.data.code:"TIMEOUT"}})}),this.on("playResponse",e=>{this.postMessage("roundStarted",{balanceBefore:this.coinsToCurrency(e.contract.balance.coins+e.contract.bet.lastPaid.base*e.contract.bet.lastPaid.multiplier)});const s=["BaseGame","PaidSpin"].includes(e.contract.stateType.thisRound),a=ms(e.contract.uiMessages),r=Qe(e.contract.uiMessages),c=bs(a),g=fs(a);this.postMessage("ticketReceived",{Balance:this.coinsToCurrency(e.contract.balance.coins),BetAmount:s?this.coinsToCurrency(e.contract.bet.lastPaid.base*e.contract.bet.lastPaid.multiplier):0,CreditTransactionId:c.betId,DebitTransactionId:c.winId,Message:r,SessionData:g,Status:{ErrCode:0},WinAmount:this.coinsToCurrency(e.contract.win.round)})}),this.on("playStart",e=>{e.bet&&this.postMessage("roundStart",{totalBet:this.coinsToCurrency(e.bet.base*e.bet.multiplier)})}),this.on("loadEnd",()=>{this.postMessage("gameReady")}),this.on("loadStart",()=>{this.postMessage("onAppFrameReady")}),this.on("cashier",()=>{this.sdkConfig.api.cashierUrl&&(this.sdkConfig.api.cashierUrl==="(api)"?this.postMessage("cashier"):je(this.sdkConfig.api.cashierUrl))})}}const we=A("RelaxFEIMPlugin","color:#000000;font-weight:bold;");class ks extends U{constructor(...e){super(...e);b(this,"VERSION","1.17.0");const s=document.createElement("script");s.src=`https://d3nsdzdtjbr5ml.cloudfront.net/casino/relaxlibs/feim/${this.VERSION}/rlxfeim.min.js`,s.onload=()=>{we("loaded"),window.FEIM.configure({p2pConfig:{currency:this.sdkConfig.api.currency,launchParams:{homeurl:"homeUrl"}}}),we("configured"),this.registerToSdkEvents(),this.registerFromSdkEvents()},document.body.appendChild(s)}registerToSdkEvents(){window.FEIM.on.errorMessageDismissed(()=>this.send("unfreeze")),window.FEIM.on.errorMessageDisplayed(()=>this.send("freeze")),window.FEIM.on.exitingGame(()=>we("!!! NOT IMPLEMENTED: exitingGame !!!")),window.FEIM.on.freeze(()=>this.send("freeze")),window.FEIM.on.initialized(()=>we("!!! NOT IMPLEMENTED: initialized !!!")),window.FEIM.on.pauseAutoPlay(()=>this.send("suspend")),window.FEIM.on.refreshBalance(()=>we("!!! NOT IMPLEMENTED: refreshBalance !!!")),window.FEIM.on.toggleGameHelp(()=>{this.send("help")}),window.FEIM.on.togglePaytable(()=>{this.send("paytable")}),window.FEIM.on.unfreeze(()=>this.send("unfreeze")),window.FEIM.on.updateSettings(({payload:[e]})=>this.send("settings",{sounds:e.sounds,fastPlay:e.fastPlay}))}registerFromSdkEvents(){this.on("autoplay",({action:e})=>{switch(e){case"start":window.FEIM.send.autoPlayStarted();break;case"stop":window.FEIM.send.autoPlayFinished();break}}),this.on("balance",({balance:e})=>{window.FEIM.send.balanceUpdate(e)}),this.on("bet",({base:e,multiplier:s})=>{window.FEIM.send.betUpdate(e*s)}),this.on("error",e=>{const s="message"in e?e.message:"Unknown error";window.FEIM.send.errorMessage(s)}),this.on("close",()=>{window.FEIM.send.exitGame()}),this.on("loadEnd",()=>{window.FEIM.send.gameLoadCompleted()}),this.on("loadProgress",({progress:e})=>{window.FEIM.send.gameLoadProgress(e)}),this.on("loadStart",()=>{window.FEIM.send.gameLoadStarted()}),this.on("cashier",()=>{window.FEIM.send.openQuickDeposit()}),this.on("playCycleEnd",e=>{const s={balance:e.contract.balance.coins,bet:e.contract.bet.lastPaid.base*e.contract.bet.lastPaid.multiplier,win:{win:e.contract.win.total}};window.FEIM.send.roundFinished(s)}),this.on("playResponse",e=>{const s={balance:e.contract.balance.coins,playResponse:e.data};window.FEIM.send.roundStarted(s)}),this.on("history",()=>{window.FEIM.send.showHistory()}),this.on("settings",e=>{window.FEIM.send.updateSettings(e)})}}const Xe=A("TukoPlugin","color:#000000;font-weight:bold;");class vs extends U{constructor(...e){super(...e);b(this,"PING_INTERVAL",1e4);const a=new URLSearchParams(window.location.search).get("pingCallbackUrl");a&&window.setInterval(()=>{this.ping(a)},this.PING_INTERVAL),this.registerToSdkEvents(),this.registerFromSdkEvents(),Xe("configured")}ping(e){const s=new XMLHttpRequest;s.onreadystatechange=function(){s.readyState===XMLHttpRequest.DONE&&(s.status===0||s.status>=200&&s.status<400?Xe("ping ok",s):Xe("ping error",s))},s.open("GET",e),s.send()}registerToSdkEvents(){window.addEventListener("message",e=>{try{const{type:s,payload:a}=e.data;switch(s){case"doAudioSettings":this.send("settings",{music:a==null?void 0:a.musicEnabled,sounds:a==null?void 0:a.soundEnabled});return;case"doBalanceUpdate":const{currency:r,coinValueInCents:c}=this.sdkConfig.api;a.currency===r&&typeof a.balanceInCurrency=="number"?this.send("balance",{balance:Kt(a.balanceInCurrency,c)}):(a.balanceInCoins,this.send("balance",{balance:a.balanceInCoins}));return;case"doGamePause":this.send("freeze");return;case"doGameResume":this.send("unfreeze");return;case"doGameSuspend":this.send("suspend");return;default:return}}catch{}})}registerFromSdkEvents(){this.on("close",()=>{if(this.sdkConfig.api.homeUrl)try{window.top.location=this.sdkConfig.api.homeUrl}catch{window.location=this.sdkConfig.api.homeUrl}else try{window.top.history.back()}catch{window.history.back()}})}}const vt=A("QuantaPlugin","color:#000000;font-weight:bold;");class Es extends U{constructor(...t){super(...t),this.registerFromSdkEvents(),vt("configured")}postMessage(t){const e={event:t};vt("postMessage",e),window.parent.postMessage(e,"*")}registerFromSdkEvents(){this.on("close",()=>{this.postMessage("GameClosed")}),this.on("loadEnd",()=>{this.postMessage("GameLoaded")}),this.on("playCycleStart",()=>{this.postMessage("RoundStarted")}),this.on("playCycleEnd",()=>{this.postMessage("RoundEnded")}),this.on("playError",()=>{this.postMessage("RoundEnded")})}}const Et=A("SoftSwissPlugin","color:#000000;font-weight:bold;");class Cs extends U{constructor(...t){super(...t),this.registerFromSdkEvents(),Et("configured")}postMessage(t,e){const s={event:t,payload:e};Et("postMessage",s),window.top.postMessage(s,"*")}registerFromSdkEvents(){this.on("loadStart",()=>{this.postMessage("gameLoadStarted")}),this.on("loadProgress",({progress:t})=>{this.postMessage("gameLoadProgress",{progress:t})}),this.on("loadEnd",()=>{this.postMessage("gameLoadCompleted")}),this.on("playCycleStart",()=>{this.postMessage("gameAnimationStart")}),this.on("playCycleEnd",t=>{this.postMessage("winUpdate",{win:t.contract.win.total}),this.postMessage("gameAnimationCompleted")}),this.on("playError",()=>{this.postMessage("gameAnimationCompleted")}),this.on("balance",({balance:t})=>{this.postMessage("balanceUpdate",{balance:t})}),this.on("bet",t=>{this.postMessage("stakeUpdate",{bet:t})})}}const Ct=A("EveryMatrixPlugin","color:#000000;font-weight:bold;");class Ms extends U{constructor(...t){super(...t),this.registerToSdkEvents(),this.registerFromSdkEvents(),Ct("configured")}postMessage(t,e){const s={name:t,sender:"game",data:e};Ct("postMessage",s),window.top.postMessage(s,"*")}registerToSdkEvents(){window.addEventListener("message",t=>{try{const{name:e,sender:s}=t.data;if(s!=="emwindow")return;switch(e){case"updateBalance":this.send("getBalance");return;case"togglePaytable":this.send("paytable");return;case"stopAutoplay":this.send("suspend");return;case"showHelp":this.send("help",{show:!0});return;default:return}}catch{}})}registerFromSdkEvents(){this.on("loadProgress",({progress:t})=>{this.postMessage("loadProgress",{progress:t})}),this.on("loadEnd",()=>{this.postMessage("loadCompleted")}),this.on("settings",t=>{(t!=null&&t.music||t!=null&&t.sounds)&&this.postMessage("audioToggle")}),this.on("playCycleStart",()=>{this.postMessage("roundStart")}),this.on("playCycleEnd",()=>{this.postMessage("roundEnd")}),this.on("playError",()=>{this.postMessage("errorMessage")}),this.on("error",()=>{this.postMessage("errorMessage")}),this.on("close",()=>{this.postMessage("close")}),this.on("bet",()=>{this.postMessage("stakeUpdate")})}}var Ss="2.0.3",dt=500,Mt="user-agent",le="",St="?",Be="function",j="undefined",ue="object",lt="string",S="browser",F="cpu",L="device",x="engine",O="os",te="result",l="name",n="type",d="vendor",u="version",T="architecture",Se="major",o="model",Ce="console",w="mobile",f="tablet",y="smarttv",R="wearable",Je="xr",Me="embedded",me="inapp",pt="brands",Y="formFactors",wt="fullVersionList",se="platform",mt="platformVersion",Ve="bitness",$="sec-ch-ua",Ts=$+"-full-version-list",Is=$+"-arch",Ps=$+"-"+Ve,As=$+"-form-factors",Os=$+"-"+w,xs=$+"-"+o,Xt=$+"-"+se,Us=Xt+"-version",Jt=[pt,wt,w,o,se,mt,T,Y,Ve],xe="Amazon",Z="Apple",Tt="ASUS",It="BlackBerry",J="Google",Pt="Huawei",At="Lenovo",Ot="Honor",Ue="LG",Ye="Microsoft",Ze="Motorola",et="Nvidia",xt="OnePlus",tt="OPPO",be="Samsung",Ut="Sharp",fe="Sony",st="Xiaomi",it="Zebra",Rt="Chrome",Lt="Chromium",V="Chromecast",Rs="Edge",ye="Firefox",ke="Opera",at="Facebook",Bt="Sogou",ee="Mobile ",ve=" Browser",ut="Windows",Ls=typeof window!==j,I=Ls&&window.navigator?window.navigator:void 0,z=I&&I.userAgentData?I.userAgentData:void 0,Bs=function(i,t){var e={},s=t;if(!_e(t)){s={};for(var a in t)for(var r in t[a])s[r]=t[a][r].concat(s[r]?s[r]:[])}for(var c in i)e[c]=s[c]&&s[c].length%2===0?s[c].concat(i[c]):i[c];return e},ze=function(i){for(var t={},e=0;e<i.length;e++)t[i[e].toUpperCase()]=i[e];return t},ht=function(i,t){if(typeof i===ue&&i.length>0){for(var e in i)if(N(i[e])==N(t))return!0;return!1}return ge(i)?N(t).indexOf(N(i))!==-1:!1},_e=function(i,t){for(var e in i)return/^(browser|cpu|device|engine|os)$/.test(e)||(t?_e(i[e]):!1)},ge=function(i){return typeof i===lt},nt=function(i){if(i){for(var t=[],e=he(/\\?\"/g,i).split(","),s=0;s<e.length;s++)if(e[s].indexOf(";")>-1){var a=Te(e[s]).split(";v=");t[s]={brand:a[0],version:a[1]}}else t[s]=Te(e[s]);return t}},N=function(i){return ge(i)?i.toLowerCase():i},ot=function(i){return ge(i)?he(/[^\d\.]/g,i).split(".")[0]:void 0},D=function(i){for(var t in i){var e=i[t];typeof e==ue&&e.length==2?this[e[0]]=e[1]:this[e]=void 0}return this},he=function(i,t){return ge(t)?t.replace(i,le):t},Ee=function(i){return he(/\\?\"/g,i)},Te=function(i,t){if(ge(i))return i=he(/^\s\s*/,i),typeof t===j?i:i.substring(0,dt)},rt=function(i,t){if(!(!i||!t))for(var e=0,s,a,r,c,g,h;e<t.length&&!g;){var p=t[e],m=t[e+1];for(s=a=0;s<p.length&&!g&&p[s];)if(g=p[s++].exec(i),g)for(r=0;r<m.length;r++)h=g[++a],c=m[r],typeof c===ue&&c.length>0?c.length===2?typeof c[1]==Be?this[c[0]]=c[1].call(this,h):this[c[0]]=c[1]:c.length===3?typeof c[1]===Be&&!(c[1].exec&&c[1].test)?this[c[0]]=h?c[1].call(this,h,c[2]):void 0:this[c[0]]=h?h.replace(c[1],c[2]):void 0:c.length===4&&(this[c[0]]=h?c[3].call(this,h.replace(c[1],c[2])):void 0):this[c]=h||void 0;e+=2}},q=function(i,t){for(var e in t)if(typeof t[e]===ue&&t[e].length>0){for(var s=0;s<t[e].length;s++)if(ht(t[e][s],i))return e===St?void 0:e}else if(ht(t[e],i))return e===St?void 0:e;return t.hasOwnProperty("*")?t["*"]:i},_t={ME:"4.90","NT 3.11":"NT3.51","NT 4.0":"NT4.0",2e3:"NT 5.0",XP:["NT 5.1","NT 5.2"],Vista:"NT 6.0",7:"NT 6.1",8:"NT 6.2","8.1":"NT 6.3",10:["NT 6.4","NT 10.0"],RT:"ARM"},Ft={embedded:"Automotive",mobile:"Mobile",tablet:["Tablet","EInk"],smarttv:"TV",wearable:"Watch",xr:["VR","XR"],"?":["Desktop","Unknown"],"*":void 0},Nt={browser:[[/\b(?:crmo|crios)\/([\w\.]+)/i],[u,[l,ee+"Chrome"]],[/edg(?:e|ios|a)?\/([\w\.]+)/i],[u,[l,"Edge"]],[/(opera mini)\/([-\w\.]+)/i,/(opera [mobiletab]{3,6})\b.+version\/([-\w\.]+)/i,/(opera)(?:.+version\/|[\/ ]+)([\w\.]+)/i],[l,u],[/opios[\/ ]+([\w\.]+)/i],[u,[l,ke+" Mini"]],[/\bop(?:rg)?x\/([\w\.]+)/i],[u,[l,ke+" GX"]],[/\bopr\/([\w\.]+)/i],[u,[l,ke]],[/\bb[ai]*d(?:uhd|[ub]*[aekoprswx]{5,6})[\/ ]?([\w\.]+)/i],[u,[l,"Baidu"]],[/\b(?:mxbrowser|mxios|myie2)\/?([-\w\.]*)\b/i],[u,[l,"Maxthon"]],[/(kindle)\/([\w\.]+)/i,/(lunascape|maxthon|netfront|jasmine|blazer|sleipnir)[\/ ]?([\w\.]*)/i,/(avant|iemobile|slim(?:browser|boat|jet))[\/ ]?([\d\.]*)/i,/(?:ms|\()(ie) ([\w\.]+)/i,/(flock|rockmelt|midori|epiphany|silk|skyfire|ovibrowser|bolt|iron|vivaldi|iridium|phantomjs|bowser|qupzilla|falkon|rekonq|puffin|brave|whale(?!.+naver)|qqbrowserlite|duckduckgo|klar|helio|(?=comodo_)?dragon|otter|dooble|(?:lg |qute)browser)\/([-\w\.]+)/i,/(heytap|ovi|115|surf)browser\/([\d\.]+)/i,/(ecosia|weibo)(?:__| \w+@)([\d\.]+)/i],[l,u],[/quark(?:pc)?\/([-\w\.]+)/i],[u,[l,"Quark"]],[/\bddg\/([\w\.]+)/i],[u,[l,"DuckDuckGo"]],[/(?:\buc? ?browser|(?:juc.+)ucweb)[\/ ]?([\w\.]+)/i],[u,[l,"UCBrowser"]],[/microm.+\bqbcore\/([\w\.]+)/i,/\bqbcore\/([\w\.]+).+microm/i,/micromessenger\/([\w\.]+)/i],[u,[l,"WeChat"]],[/konqueror\/([\w\.]+)/i],[u,[l,"Konqueror"]],[/trident.+rv[: ]([\w\.]{1,9})\b.+like gecko/i],[u,[l,"IE"]],[/ya(?:search)?browser\/([\w\.]+)/i],[u,[l,"Yandex"]],[/slbrowser\/([\w\.]+)/i],[u,[l,"Smart "+At+ve]],[/(avast|avg)\/([\w\.]+)/i],[[l,/(.+)/,"$1 Secure"+ve],u],[/\bfocus\/([\w\.]+)/i],[u,[l,ye+" Focus"]],[/\bopt\/([\w\.]+)/i],[u,[l,ke+" Touch"]],[/coc_coc\w+\/([\w\.]+)/i],[u,[l,"Coc Coc"]],[/dolfin\/([\w\.]+)/i],[u,[l,"Dolphin"]],[/coast\/([\w\.]+)/i],[u,[l,ke+" Coast"]],[/miuibrowser\/([\w\.]+)/i],[u,[l,"MIUI"+ve]],[/fxios\/([\w\.-]+)/i],[u,[l,ee+ye]],[/\bqihoobrowser\/?([\w\.]*)/i],[u,[l,"360"]],[/\b(qq)\/([\w\.]+)/i],[[l,/(.+)/,"$1Browser"],u],[/(oculus|sailfish|huawei|vivo|pico)browser\/([\w\.]+)/i],[[l,/(.+)/,"$1"+ve],u],[/samsungbrowser\/([\w\.]+)/i],[u,[l,be+" Internet"]],[/metasr[\/ ]?([\d\.]+)/i],[u,[l,Bt+" Explorer"]],[/(sogou)mo\w+\/([\d\.]+)/i],[[l,Bt+" Mobile"],u],[/(electron)\/([\w\.]+) safari/i,/(tesla)(?: qtcarbrowser|\/(20\d\d\.[-\w\.]+))/i,/m?(qqbrowser|2345(?=browser|chrome|explorer))\w*[\/ ]?v?([\w\.]+)/i],[l,u],[/(lbbrowser|rekonq)/i],[l],[/ome\/([\w\.]+) \w* ?(iron) saf/i,/ome\/([\w\.]+).+qihu (360)[es]e/i],[u,l],[/((?:fban\/fbios|fb_iab\/fb4a)(?!.+fbav)|;fbav\/([\w\.]+);)/i],[[l,at],u,[n,me]],[/(Klarna)\/([\w\.]+)/i,/(kakao(?:talk|story))[\/ ]([\w\.]+)/i,/(naver)\(.*?(\d+\.[\w\.]+).*\)/i,/(daum)apps[\/ ]([\w\.]+)/i,/safari (line)\/([\w\.]+)/i,/\b(line)\/([\w\.]+)\/iab/i,/(alipay)client\/([\w\.]+)/i,/(twitter)(?:and| f.+e\/([\w\.]+))/i,/(instagram|snapchat)[\/ ]([-\w\.]+)/i],[l,u,[n,me]],[/\bgsa\/([\w\.]+) .*safari\//i],[u,[l,"GSA"],[n,me]],[/musical_ly(?:.+app_?version\/|_)([\w\.]+)/i],[u,[l,"TikTok"],[n,me]],[/\[(linkedin)app\]/i],[l,[n,me]],[/(chromium)[\/ ]([-\w\.]+)/i],[l,u],[/headlesschrome(?:\/([\w\.]+)| )/i],[u,[l,Rt+" Headless"]],[/ wv\).+(chrome)\/([\w\.]+)/i],[[l,Rt+" WebView"],u],[/droid.+ version\/([\w\.]+)\b.+(?:mobile safari|safari)/i],[u,[l,"Android"+ve]],[/chrome\/([\w\.]+) mobile/i],[u,[l,ee+"Chrome"]],[/(chrome|omniweb|arora|[tizenoka]{5} ?browser)\/v?([\w\.]+)/i],[l,u],[/version\/([\w\.\,]+) .*mobile(?:\/\w+ | ?)safari/i],[u,[l,ee+"Safari"]],[/iphone .*mobile(?:\/\w+ | ?)safari/i],[[l,ee+"Safari"]],[/version\/([\w\.\,]+) .*(safari)/i],[u,l],[/webkit.+?(mobile ?safari|safari)(\/[\w\.]+)/i],[l,[u,"1"]],[/(webkit|khtml)\/([\w\.]+)/i],[l,u],[/(?:mobile|tablet);.*(firefox)\/([\w\.-]+)/i],[[l,ee+ye],u],[/(navigator|netscape\d?)\/([-\w\.]+)/i],[[l,"Netscape"],u],[/(wolvic|librewolf)\/([\w\.]+)/i],[l,u],[/mobile vr; rv:([\w\.]+)\).+firefox/i],[u,[l,ye+" Reality"]],[/ekiohf.+(flow)\/([\w\.]+)/i,/(swiftfox)/i,/(icedragon|iceweasel|camino|chimera|fennec|maemo browser|minimo|conkeror)[\/ ]?([\w\.\+]+)/i,/(seamonkey|k-meleon|icecat|iceape|firebird|phoenix|palemoon|basilisk|waterfox)\/([-\w\.]+)$/i,/(firefox)\/([\w\.]+)/i,/(mozilla)\/([\w\.]+) .+rv\:.+gecko\/\d+/i,/(amaya|dillo|doris|icab|ladybird|lynx|mosaic|netsurf|obigo|polaris|w3m|(?:go|ice|up)[\. ]?browser)[-\/ ]?v?([\w\.]+)/i,/\b(links) \(([\w\.]+)/i],[l,[u,/_/g,"."]],[/(cobalt)\/([\w\.]+)/i],[l,[u,/[^\d\.]+./,le]]],cpu:[[/\b((amd|x|x86[-_]?|wow|win)64)\b/i],[[T,"amd64"]],[/(ia32(?=;))/i,/\b((i[346]|x)86)(pc)?\b/i],[[T,"ia32"]],[/\b(aarch64|arm(v?[89]e?l?|_?64))\b/i],[[T,"arm64"]],[/\b(arm(v[67])?ht?n?[fl]p?)\b/i],[[T,"armhf"]],[/( (ce|mobile); ppc;|\/[\w\.]+arm\b)/i],[[T,"arm"]],[/((ppc|powerpc)(64)?)( mac|;|\))/i],[[T,/ower/,le,N]],[/ sun4\w[;\)]/i],[[T,"sparc"]],[/\b(avr32|ia64(?=;)|68k(?=\))|\barm(?=v([1-7]|[5-7]1)l?|;|eabi)|(irix|mips|sparc)(64)?\b|pa-risc)/i],[[T,N]]],device:[[/\b(sch-i[89]0\d|shw-m380s|sm-[ptx]\w{2,4}|gt-[pn]\d{2,4}|sgh-t8[56]9|nexus 10)/i],[o,[d,be],[n,f]],[/\b((?:s[cgp]h|gt|sm)-(?![lr])\w+|sc[g-]?[\d]+a?|galaxy nexus)/i,/samsung[- ]((?!sm-[lr])[-\w]+)/i,/sec-(sgh\w+)/i],[o,[d,be],[n,w]],[/(?:\/|\()(ip(?:hone|od)[\w, ]*)(?:\/|;)/i],[o,[d,Z],[n,w]],[/\((ipad);[-\w\),; ]+apple/i,/applecoremedia\/[\w\.]+ \((ipad)/i,/\b(ipad)\d\d?,\d\d?[;\]].+ios/i],[o,[d,Z],[n,f]],[/(macintosh);/i],[o,[d,Z]],[/\b(sh-?[altvz]?\d\d[a-ekm]?)/i],[o,[d,Ut],[n,w]],[/\b((?:brt|eln|hey2?|gdi|jdn)-a?[lnw]09|(?:ag[rm]3?|jdn2|kob2)-a?[lw]0[09]hn)(?: bui|\)|;)/i],[o,[d,Ot],[n,f]],[/honor([-\w ]+)[;\)]/i],[o,[d,Ot],[n,w]],[/\b((?:ag[rs][2356]?k?|bah[234]?|bg[2o]|bt[kv]|cmr|cpn|db[ry]2?|jdn2|got|kob2?k?|mon|pce|scm|sht?|[tw]gr|vrd)-[ad]?[lw][0125][09]b?|605hw|bg2-u03|(?:gem|fdr|m2|ple|t1)-[7a]0[1-4][lu]|t1-a2[13][lw]|mediapad[\w\. ]*(?= bui|\)))\b(?!.+d\/s)/i],[o,[d,Pt],[n,f]],[/(?:huawei)([-\w ]+)[;\)]/i,/\b(nexus 6p|\w{2,4}e?-[atu]?[ln][\dx][012359c][adn]?)\b(?!.+d\/s)/i],[o,[d,Pt],[n,w]],[/oid[^\)]+; (2[\dbc]{4}(182|283|rp\w{2})[cgl]|m2105k81a?c)(?: bui|\))/i,/\b((?:red)?mi[-_ ]?pad[\w- ]*)(?: bui|\))/i],[[o,/_/g," "],[d,st],[n,f]],[/\b(poco[\w ]+|m2\d{3}j\d\d[a-z]{2})(?: bui|\))/i,/\b; (\w+) build\/hm\1/i,/\b(hm[-_ ]?note?[_ ]?(?:\d\w)?) bui/i,/\b(redmi[\-_ ]?(?:note|k)?[\w_ ]+)(?: bui|\))/i,/oid[^\)]+; (m?[12][0-389][01]\w{3,6}[c-y])( bui|; wv|\))/i,/\b(mi[-_ ]?(?:a\d|one|one[_ ]plus|note lte|max|cc)?[_ ]?(?:\d?\w?)[_ ]?(?:plus|se|lite|pro)?)(?: bui|\))/i,/ ([\w ]+) miui\/v?\d/i],[[o,/_/g," "],[d,st],[n,w]],[/; (\w+) bui.+ oppo/i,/\b(cph[12]\d{3}|p(?:af|c[al]|d\w|e[ar])[mt]\d0|x9007|a101op)\b/i],[o,[d,tt],[n,w]],[/\b(opd2(\d{3}a?))(?: bui|\))/i],[o,[d,q,{OnePlus:["304","403","203"],"*":tt}],[n,f]],[/(vivo (5r?|6|8l?|go|one|s|x[il]?[2-4]?)[\w\+ ]*)(?: bui|\))/i],[o,[d,"BLU"],[n,w]],[/; vivo (\w+)(?: bui|\))/i,/\b(v[12]\d{3}\w?[at])(?: bui|;)/i],[o,[d,"Vivo"],[n,w]],[/\b(rmx[1-3]\d{3})(?: bui|;|\))/i],[o,[d,"Realme"],[n,w]],[/\b(milestone|droid(?:[2-4x]| (?:bionic|x2|pro|razr))?:?( 4g)?)\b[\w ]+build\//i,/\bmot(?:orola)?[- ](\w*)/i,/((?:moto(?! 360)[\w\(\) ]+|xt\d{3,4}|nexus 6)(?= bui|\)))/i],[o,[d,Ze],[n,w]],[/\b(mz60\d|xoom[2 ]{0,2}) build\//i],[o,[d,Ze],[n,f]],[/((?=lg)?[vl]k\-?\d{3}) bui| 3\.[-\w; ]{10}lg?-([06cv9]{3,4})/i],[o,[d,Ue],[n,f]],[/(lm(?:-?f100[nv]?|-[\w\.]+)(?= bui|\))|nexus [45])/i,/\blg[-e;\/ ]+(?!.*(?:browser|netcast|android tv|watch))(\w+)/i,/\blg-?([\d\w]+) bui/i],[o,[d,Ue],[n,w]],[/(ideatab[-\w ]+|602lv|d-42a|a101lv|a2109a|a3500-hv|s[56]000|pb-6505[my]|tb-?x?\d{3,4}(?:f[cu]|xu|[av])|yt\d?-[jx]?\d+[lfmx])( bui|;|\)|\/)/i,/lenovo ?(b[68]0[08]0-?[hf]?|tab(?:[\w- ]+?)|tb[\w-]{6,7})( bui|;|\)|\/)/i],[o,[d,At],[n,f]],[/(nokia) (t[12][01])/i],[d,o,[n,f]],[/(?:maemo|nokia).*(n900|lumia \d+|rm-\d+)/i,/nokia[-_ ]?(([-\w\. ]*))/i],[[o,/_/g," "],[n,w],[d,"Nokia"]],[/(pixel (c|tablet))\b/i],[o,[d,J],[n,f]],[/droid.+; (pixel[\daxl ]{0,6})(?: bui|\))/i],[o,[d,J],[n,w]],[/droid.+; (a?\d[0-2]{2}so|[c-g]\d{4}|so[-gl]\w+|xq-a\w[4-7][12])(?= bui|\).+chrome\/(?![1-6]{0,1}\d\.))/i],[o,[d,fe],[n,w]],[/sony tablet [ps]/i,/\b(?:sony)?sgp\w+(?: bui|\))/i],[[o,"Xperia Tablet"],[d,fe],[n,f]],[/ (kb2005|in20[12]5|be20[12][59])\b/i,/(?:one)?(?:plus)? (a\d0\d\d)(?: b|\))/i],[o,[d,xt],[n,w]],[/(alexa)webm/i,/(kf[a-z]{2}wi|aeo(?!bc)\w\w)( bui|\))/i,/(kf[a-z]+)( bui|\)).+silk\//i],[o,[d,xe],[n,f]],[/((?:sd|kf)[0349hijorstuw]+)( bui|\)).+silk\//i],[[o,/(.+)/g,"Fire Phone $1"],[d,xe],[n,w]],[/(playbook);[-\w\),; ]+(rim)/i],[o,d,[n,f]],[/\b((?:bb[a-f]|st[hv])100-\d)/i,/\(bb10; (\w+)/i],[o,[d,It],[n,w]],[/(?:\b|asus_)(transfo[prime ]{4,10} \w+|eeepc|slider \w+|nexus 7|padfone|p00[cj])/i],[o,[d,Tt],[n,f]],[/ (z[bes]6[027][012][km][ls]|zenfone \d\w?)\b/i],[o,[d,Tt],[n,w]],[/(nexus 9)/i],[o,[d,"HTC"],[n,f]],[/(htc)[-;_ ]{1,2}([\w ]+(?=\)| bui)|\w+)/i,/(zte)[- ]([\w ]+?)(?: bui|\/|\))/i,/(alcatel|geeksphone|nexian|panasonic(?!(?:;|\.))|sony(?!-bra))[-_ ]?([-\w]*)/i],[d,[o,/_/g," "],[n,w]],[/tcl (xess p17aa)/i,/droid [\w\.]+; ((?:8[14]9[16]|9(?:0(?:48|60|8[01])|1(?:3[27]|66)|2(?:6[69]|9[56])|466))[gqswx])(_\w(\w|\w\w))?(\)| bui)/i],[o,[d,"TCL"],[n,f]],[/droid [\w\.]+; (418(?:7d|8v)|5087z|5102l|61(?:02[dh]|25[adfh]|27[ai]|56[dh]|59k|65[ah])|a509dl|t(?:43(?:0w|1[adepqu])|50(?:6d|7[adju])|6(?:09dl|10k|12b|71[efho]|76[hjk])|7(?:66[ahju]|67[hw]|7[045][bh]|71[hk]|73o|76[ho]|79w|81[hks]?|82h|90[bhsy]|99b)|810[hs]))(_\w(\w|\w\w))?(\)| bui)/i],[o,[d,"TCL"],[n,w]],[/(itel) ((\w+))/i],[[d,N],o,[n,q,{tablet:["p10001l","w7001"],"*":"mobile"}]],[/droid.+; ([ab][1-7]-?[0178a]\d\d?)/i],[o,[d,"Acer"],[n,f]],[/droid.+; (m[1-5] note) bui/i,/\bmz-([-\w]{2,})/i],[o,[d,"Meizu"],[n,w]],[/; ((?:power )?armor(?:[\w ]{0,8}))(?: bui|\))/i],[o,[d,"Ulefone"],[n,w]],[/; (energy ?\w+)(?: bui|\))/i,/; energizer ([\w ]+)(?: bui|\))/i],[o,[d,"Energizer"],[n,w]],[/; cat (b35);/i,/; (b15q?|s22 flip|s48c|s62 pro)(?: bui|\))/i],[o,[d,"Cat"],[n,w]],[/((?:new )?andromax[\w- ]+)(?: bui|\))/i],[o,[d,"Smartfren"],[n,w]],[/droid.+; (a(?:015|06[35]|142p?))/i],[o,[d,"Nothing"],[n,w]],[/; (x67 5g|tikeasy \w+|ac[1789]\d\w+)( b|\))/i,/archos ?(5|gamepad2?|([\w ]*[t1789]|hello) ?\d+[\w ]*)( b|\))/i],[o,[d,"Archos"],[n,f]],[/archos ([\w ]+)( b|\))/i,/; (ac[3-6]\d\w{2,8})( b|\))/i],[o,[d,"Archos"],[n,w]],[/(imo) (tab \w+)/i,/(infinix) (x1101b?)/i],[d,o,[n,f]],[/(blackberry|benq|palm(?=\-)|sonyericsson|acer|asus(?! zenw)|dell|jolla|meizu|motorola|polytron|infinix|tecno|micromax|advan)[-_ ]?([-\w]*)/i,/; (blu|hmd|imo|tcl)[_ ]([\w\+ ]+?)(?: bui|\)|; r)/i,/(hp) ([\w ]+\w)/i,/(microsoft); (lumia[\w ]+)/i,/(lenovo)[-_ ]?([-\w ]+?)(?: bui|\)|\/)/i,/(oppo) ?([\w ]+) bui/i],[d,o,[n,w]],[/(kobo)\s(ereader|touch)/i,/(hp).+(touchpad(?!.+tablet)|tablet)/i,/(kindle)\/([\w\.]+)/i],[d,o,[n,f]],[/(surface duo)/i],[o,[d,Ye],[n,f]],[/droid [\d\.]+; (fp\du?)(?: b|\))/i],[o,[d,"Fairphone"],[n,w]],[/((?:tegranote|shield t(?!.+d tv))[\w- ]*?)(?: b|\))/i],[o,[d,et],[n,f]],[/(sprint) (\w+)/i],[d,o,[n,w]],[/(kin\.[onetw]{3})/i],[[o,/\./g," "],[d,Ye],[n,w]],[/droid.+; ([c6]+|et5[16]|mc[239][23]x?|vc8[03]x?)\)/i],[o,[d,it],[n,f]],[/droid.+; (ec30|ps20|tc[2-8]\d[kx])\)/i],[o,[d,it],[n,w]],[/smart-tv.+(samsung)/i],[d,[n,y]],[/hbbtv.+maple;(\d+)/i],[[o,/^/,"SmartTV"],[d,be],[n,y]],[/tcast.+(lg)e?. ([-\w]+)/i],[d,o,[n,y]],[/(nux; netcast.+smarttv|lg (netcast\.tv-201\d|android tv))/i],[[d,Ue],[n,y]],[/(apple) ?tv/i],[d,[o,Z+" TV"],[n,y]],[/crkey.*devicetype\/chromecast/i],[[o,V+" Third Generation"],[d,J],[n,y]],[/crkey.*devicetype\/([^/]*)/i],[[o,/^/,"Chromecast "],[d,J],[n,y]],[/fuchsia.*crkey/i],[[o,V+" Nest Hub"],[d,J],[n,y]],[/crkey/i],[[o,V],[d,J],[n,y]],[/(portaltv)/i],[o,[d,at],[n,y]],[/droid.+aft(\w+)( bui|\))/i],[o,[d,xe],[n,y]],[/(shield \w+ tv)/i],[o,[d,et],[n,y]],[/\(dtv[\);].+(aquos)/i,/(aquos-tv[\w ]+)\)/i],[o,[d,Ut],[n,y]],[/(bravia[\w ]+)( bui|\))/i],[o,[d,fe],[n,y]],[/(mi(tv|box)-?\w+) bui/i],[o,[d,st],[n,y]],[/Hbbtv.*(technisat) (.*);/i],[d,o,[n,y]],[/\b(roku)[\dx]*[\)\/]((?:dvp-)?[\d\.]*)/i,/hbbtv\/\d+\.\d+\.\d+ +\([\w\+ ]*; *([\w\d][^;]*);([^;]*)/i],[[d,Te],[o,Te],[n,y]],[/droid.+; ([\w- ]+) (?:android tv|smart[- ]?tv)/i],[o,[n,y]],[/\b(android tv|smart[- ]?tv|opera tv|tv; rv:)\b/i],[[n,y]],[/(ouya)/i,/(nintendo) (\w+)/i],[d,o,[n,Ce]],[/droid.+; (shield)( bui|\))/i],[o,[d,et],[n,Ce]],[/(playstation \w+)/i],[o,[d,fe],[n,Ce]],[/\b(xbox(?: one)?(?!; xbox))[\); ]/i],[o,[d,Ye],[n,Ce]],[/\b(sm-[lr]\d\d[0156][fnuw]?s?|gear live)\b/i],[o,[d,be],[n,R]],[/((pebble))app/i,/(asus|google|lg|oppo) ((pixel |zen)?watch[\w ]*)( bui|\))/i],[d,o,[n,R]],[/(ow(?:19|20)?we?[1-3]{1,3})/i],[o,[d,tt],[n,R]],[/(watch)(?: ?os[,\/]|\d,\d\/)[\d\.]+/i],[o,[d,Z],[n,R]],[/(opwwe\d{3})/i],[o,[d,xt],[n,R]],[/(moto 360)/i],[o,[d,Ze],[n,R]],[/(smartwatch 3)/i],[o,[d,fe],[n,R]],[/(g watch r)/i],[o,[d,Ue],[n,R]],[/droid.+; (wt63?0{2,3})\)/i],[o,[d,it],[n,R]],[/droid.+; (glass) \d/i],[o,[d,J],[n,Je]],[/(pico) (4|neo3(?: link|pro)?)/i],[d,o,[n,Je]],[/(quest( \d| pro)?s?).+vr/i],[o,[d,at],[n,Je]],[/(tesla)(?: qtcarbrowser|\/[-\w\.]+)/i],[d,[n,Me]],[/(aeobc)\b/i],[o,[d,xe],[n,Me]],[/(homepod).+mac os/i],[o,[d,Z],[n,Me]],[/windows iot/i],[[n,Me]],[/droid .+?; ([^;]+?)(?: bui|; wv\)|\) applew).+?(mobile|vr|\d) safari/i],[o,[n,q,{mobile:"Mobile",xr:"VR","*":f}]],[/\b((tablet|tab)[;\/]|focus\/\d(?!.+mobile))/i],[[n,f]],[/(phone|mobile(?:[;\/]| [ \w\/\.]*safari)|pda(?=.+windows ce))/i],[[n,w]],[/droid .+?; ([\w\. -]+)( bui|\))/i],[o,[d,"Generic"]]],engine:[[/windows.+ edge\/([\w\.]+)/i],[u,[l,Rs+"HTML"]],[/(arkweb)\/([\w\.]+)/i],[l,u],[/webkit\/537\.36.+chrome\/(?!27)([\w\.]+)/i],[u,[l,"Blink"]],[/(presto)\/([\w\.]+)/i,/(webkit|trident|netfront|netsurf|amaya|lynx|w3m|goanna|servo)\/([\w\.]+)/i,/ekioh(flow)\/([\w\.]+)/i,/(khtml|tasman|links)[\/ ]\(?([\w\.]+)/i,/(icab)[\/ ]([23]\.[\d\.]+)/i,/\b(libweb)/i],[l,u],[/ladybird\//i],[[l,"LibWeb"]],[/rv\:([\w\.]{1,9})\b.+(gecko)/i],[u,l]],os:[[/microsoft (windows) (vista|xp)/i],[l,u],[/(windows (?:phone(?: os)?|mobile|iot))[\/ ]?([\d\.\w ]*)/i],[l,[u,q,_t]],[/windows nt 6\.2; (arm)/i,/windows[\/ ]([ntce\d\. ]+\w)(?!.+xbox)/i,/(?:win(?=3|9|n)|win 9x )([nt\d\.]+)/i],[[u,q,_t],[l,ut]],[/[adehimnop]{4,7}\b(?:.*os ([\w]+) like mac|; opera)/i,/(?:ios;fbsv\/|iphone.+ios[\/ ])([\d\.]+)/i,/cfnetwork\/.+darwin/i],[[u,/_/g,"."],[l,"iOS"]],[/(mac os x) ?([\w\. ]*)/i,/(macintosh|mac_powerpc\b)(?!.+haiku)/i],[[l,"macOS"],[u,/_/g,"."]],[/android ([\d\.]+).*crkey/i],[u,[l,V+" Android"]],[/fuchsia.*crkey\/([\d\.]+)/i],[u,[l,V+" Fuchsia"]],[/crkey\/([\d\.]+).*devicetype\/smartspeaker/i],[u,[l,V+" SmartSpeaker"]],[/linux.*crkey\/([\d\.]+)/i],[u,[l,V+" Linux"]],[/crkey\/([\d\.]+)/i],[u,[l,V]],[/droid ([\w\.]+)\b.+(android[- ]x86|harmonyos)/i],[u,l],[/(ubuntu) ([\w\.]+) like android/i],[[l,/(.+)/,"$1 Touch"],u],[/(android|bada|blackberry|kaios|maemo|meego|openharmony|qnx|rim tablet os|sailfish|series40|symbian|tizen|webos)\w*[-\/\.; ]?([\d\.]*)/i],[l,u],[/\(bb(10);/i],[u,[l,It]],[/(?:symbian ?os|symbos|s60(?=;)|series ?60)[-\/ ]?([\w\.]*)/i],[u,[l,"Symbian"]],[/mozilla\/[\d\.]+ \((?:mobile|tablet|tv|mobile; [\w ]+); rv:.+ gecko\/([\w\.]+)/i],[u,[l,ye+" OS"]],[/web0s;.+rt(tv)/i,/\b(?:hp)?wos(?:browser)?\/([\w\.]+)/i],[u,[l,"webOS"]],[/watch(?: ?os[,\/]|\d,\d\/)([\d\.]+)/i],[u,[l,"watchOS"]],[/(cros) [\w]+(?:\)| ([\w\.]+)\b)/i],[[l,"Chrome OS"],u],[/panasonic;(viera)/i,/(netrange)mmh/i,/(nettv)\/(\d+\.[\w\.]+)/i,/(nintendo|playstation) (\w+)/i,/(xbox); +xbox ([^\);]+)/i,/(pico) .+os([\w\.]+)/i,/\b(joli|palm)\b ?(?:os)?\/?([\w\.]*)/i,/(mint)[\/\(\) ]?(\w*)/i,/(mageia|vectorlinux)[; ]/i,/([kxln]?ubuntu|debian|suse|opensuse|gentoo|arch(?= linux)|slackware|fedora|mandriva|centos|pclinuxos|red ?hat|zenwalk|linpus|raspbian|plan 9|minix|risc os|contiki|deepin|manjaro|elementary os|sabayon|linspire)(?: gnu\/linux)?(?: enterprise)?(?:[- ]linux)?(?:-gnu)?[-\/ ]?(?!chrom|package)([-\w\.]*)/i,/(hurd|linux)(?: arm\w*| x86\w*| ?)([\w\.]*)/i,/(gnu) ?([\w\.]*)/i,/\b([-frentopcghs]{0,5}bsd|dragonfly)[\/ ]?(?!amd|[ix346]{1,2}86)([\w\.]*)/i,/(haiku) (\w+)/i],[l,u],[/(sunos) ?([\w\.\d]*)/i],[[l,"Solaris"],u],[/((?:open)?solaris)[-\/ ]?([\w\.]*)/i,/(aix) ((\d)(?=\.|\)| )[\w\.])*/i,/\b(beos|os\/2|amigaos|morphos|openvms|fuchsia|hp-ux|serenityos)/i,/(unix) ?([\w\.]*)/i],[l,u]]},Re=function(){var i={init:{},isIgnore:{},isIgnoreRgx:{},toString:{}};return D.call(i.init,[[S,[l,u,Se,n]],[F,[T]],[L,[n,o,d]],[x,[l,u]],[O,[l,u]]]),D.call(i.isIgnore,[[S,[u,Se]],[x,[u]],[O,[u]]]),D.call(i.isIgnoreRgx,[[S,/ ?browser$/i],[O,/ ?os$/i]]),D.call(i.toString,[[S,[l,u]],[F,[T]],[L,[d,o]],[x,[l,u]],[O,[l,u]]]),i}(),_s=function(i,t){var e=Re.init[t],s=Re.isIgnore[t]||0,a=Re.isIgnoreRgx[t]||0,r=Re.toString[t]||0;function c(){D.call(this,e)}return c.prototype.getItem=function(){return i},c.prototype.withClientHints=function(){return z?z.getHighEntropyValues(Jt).then(function(g){return i.setCH(new Yt(g,!1)).parseCH().get()}):i.parseCH().get()},c.prototype.withFeatureCheck=function(){return i.detectFeature().get()},t!=te&&(c.prototype.is=function(g){var h=!1;for(var p in this)if(this.hasOwnProperty(p)&&!ht(s,p)&&N(a?he(a,this[p]):this[p])==N(a?he(a,g):g)){if(h=!0,g!=j)break}else if(g==j&&h){h=!h;break}return h},c.prototype.toString=function(){var g=le;for(var h in r)typeof this[r[h]]!==j&&(g+=(g?" ":le)+this[r[h]]);return g||j}),z||(c.prototype.then=function(g){var h=this,p=function(){for(var C in h)h.hasOwnProperty(C)&&(this[C]=h[C])};p.prototype={is:c.prototype.is,toString:c.prototype.toString};var m=new p;return g(m),m}),new c};function Yt(i,t){if(i=i||{},D.call(this,Jt),t)D.call(this,[[pt,nt(i[$])],[wt,nt(i[Ts])],[w,/\?1/.test(i[Os])],[o,Ee(i[xs])],[se,Ee(i[Xt])],[mt,Ee(i[Us])],[T,Ee(i[Is])],[Y,nt(i[As])],[Ve,Ee(i[Ps])]]);else for(var e in i)this.hasOwnProperty(e)&&typeof i[e]!==j&&(this[e]=i[e])}function Dt(i,t,e,s){return this.get=function(a){return a?this.data.hasOwnProperty(a)?this.data[a]:void 0:this.data},this.set=function(a,r){return this.data[a]=r,this},this.setCH=function(a){return this.uaCH=a,this},this.detectFeature=function(){if(I&&I.userAgent==this.ua)switch(this.itemType){case S:I.brave&&typeof I.brave.isBrave==Be&&this.set(l,"Brave");break;case L:!this.get(n)&&z&&z[w]&&this.set(n,w),this.get(o)=="Macintosh"&&I&&typeof I.standalone!==j&&I.maxTouchPoints&&I.maxTouchPoints>2&&this.set(o,"iPad").set(n,f);break;case O:!this.get(l)&&z&&z[se]&&this.set(l,z[se]);break;case te:var a=this.data,r=function(c){return a[c].getItem().detectFeature().get()};this.set(S,r(S)).set(F,r(F)).set(L,r(L)).set(x,r(x)).set(O,r(O))}return this},this.parseUA=function(){return this.itemType!=te&&rt.call(this.data,this.ua,this.rgxMap),this.itemType==S&&this.set(Se,ot(this.get(u))),this},this.parseCH=function(){var a=this.uaCH,r=this.rgxMap;switch(this.itemType){case S:case x:var c=a[wt]||a[pt],g;if(c)for(var h in c){var p=c[h].brand||c[h],m=c[h].version;this.itemType==S&&!/not.a.brand/i.test(p)&&(!g||/chrom/i.test(g)&&p!=Lt)&&(p=q(p,{Chrome:"Google Chrome",Edge:"Microsoft Edge","Chrome WebView":"Android WebView","Chrome Headless":"HeadlessChrome","Huawei Browser":"HuaweiBrowser","MIUI Browser":"Miui Browser","Opera Mobi":"OperaMobile",Yandex:"YaBrowser"}),this.set(l,p).set(u,m).set(Se,ot(m)),g=p),this.itemType==x&&p==Lt&&this.set(u,m)}break;case F:var C=a[T];C&&(C&&a[Ve]=="64"&&(C+="64"),rt.call(this.data,C+";",r));break;case L:if(a[w]&&this.set(n,w),a[o]&&(this.set(o,a[o]),!this.get(n)||!this.get(d))){var P={};rt.call(P,"droid 9; "+a[o]+")",r),!this.get(n)&&P.type&&this.set(n,P.type),!this.get(d)&&P.vendor&&this.set(d,P.vendor)}if(a[Y]){var G;if(typeof a[Y]!="string")for(var pe=0;!G&&pe<a[Y].length;)G=q(a[Y][pe++],Ft);else G=q(a[Y],Ft);this.set(n,G)}break;case O:var _=a[se];if(_){var K=a[mt];_==ut&&(K=parseInt(ot(K),10)>=13?"11":"10"),this.set(l,_).set(u,K)}this.get(l)==ut&&a[o]=="Xbox"&&this.set(l,"Xbox").set(u,void 0);break;case te:var Q=this.data,H=function(Oe){return Q[Oe].getItem().setCH(a).parseCH().get()};this.set(S,H(S)).set(F,H(F)).set(L,H(L)).set(x,H(x)).set(O,H(O))}return this},D.call(this,[["itemType",i],["ua",t],["uaCH",s],["rgxMap",e],["data",_s(this,i)]]),this}function B(i,t,e){if(typeof i===ue?(_e(i,!0)?(typeof t===ue&&(e=t),t=i):(e=i,t=void 0),i=void 0):typeof i===lt&&!_e(t,!0)&&(e=t,t=void 0),e&&typeof e.append===Be){var s={};e.forEach(function(h,p){s[p]=h}),e=s}if(!(this instanceof B))return new B(i,t,e).getResult();var a=typeof i===lt?i:e&&e[Mt]?e[Mt]:I&&I.userAgent?I.userAgent:le,r=new Yt(e,!0),c=t?Bs(Nt,t):Nt,g=function(h){return h==te?function(){return new Dt(h,a,c,r).set("ua",a).set(S,this.getBrowser()).set(F,this.getCPU()).set(L,this.getDevice()).set(x,this.getEngine()).set(O,this.getOS()).get()}:function(){return new Dt(h,a,c[h],r).parseUA().get()}};return D.call(this,[["getBrowser",g(S)],["getCPU",g(F)],["getDevice",g(L)],["getEngine",g(x)],["getOS",g(O)],["getResult",g(te)],["getUA",function(){return a}],["setUA",function(h){return ge(h)&&(a=h.length>dt?Te(h,dt):h),this}]]).setUA(a),this}B.VERSION=Ss;B.BROWSER=ze([l,u,Se,n]);B.CPU=ze([T]);B.DEVICE=ze([o,d,n,Ce,w,y,f,R,Me]);B.ENGINE=B.OS=ze([l,u]);class Zt{constructor(t,e){b(this,"config");b(this,"sdkConfig");this.config=t,this.sdkConfig=e}on(t,e,s){const a=function(c){c.data.message!==`kalamba:wrapper-rgs:${t}`&&c.data.message!==`kalamba:wrapper:${t}`||e(c.data.payload)};window.addEventListener("message",a,s)}send(t,...[e]){window.postMessage({message:`kalamba:rgs:${t}`,payload:e})}}class Fs{constructor(t){b(this,"socket",null);b(this,"webSocketUrl");b(this,"eventListeners",{close:[],error:[],message:[]});b(this,"connect",async()=>{const t=new WebSocket(this.webSocketUrl);return t.addEventListener("message",this.handleMessage),new Promise(e=>{t.addEventListener("open",s=>{this.handleOpen(s),e(this.socket)},{once:!0})})});b(this,"send",t=>{if(this.socket==null)throw new Error("Cannot send message, the WebSocket connection is not open");this.socket.send(t)});b(this,"close",()=>{if(this.socket==null)throw new Error("Cannot close the WebSocket connection that is not open");this.socket.close()});b(this,"handleClose",t=>{this.eventListeners.close.forEach(e=>{e(t)}),this.socket.removeEventListener("message",this.handleMessage),this.socket.removeEventListener("close",this.handleClose),this.socket.removeEventListener("error",this.handleError),this.socket=null});b(this,"handleError",t=>{this.eventListeners.error.forEach(e=>{e(t)})});b(this,"handleMessage",t=>{this.eventListeners.message.forEach(e=>{e(t)})});b(this,"handleOpen",t=>{const e=t.target;e.addEventListener("close",this.handleClose),e.addEventListener("error",this.handleError),this.socket=e});this.webSocketUrl=t}addEventListener(t,e){this.eventListeners[t].push(e)}removeEventListener(t,e){const s=this.eventListeners[t].indexOf(e);s!==-1&&this.eventListeners[t].splice(s,1)}}function Le(i){return JSON.parse(i==null?void 0:i.data)}function Ns(i){var t;return((t=i==null?void 0:i.header)==null?void 0:t.name)==="Ping"}function Gt(i){var t;return((t=i==null?void 0:i.header)==null?void 0:t.name)==="RealityCheck"}function Fe(i){return i.header.name==="GameEvent"}function Ds(i){return Fe(i)&&i.body.event==="OPEN_GAME"}function Ht(i){return i.header.code!==1}function Gs(i){return Fe(i)&&i.body.event.includes("_RESULT")}var ie,Ie;class Hs extends Fs{constructor(e,s){const a=new URL(e.apiUrl);a.searchParams.set("cageCode",e.cageCode),a.searchParams.set("gameCode",e.gameCode),a.searchParams.set("operatorCode",e.operatorCode),a.searchParams.set("playMode",e.playMode),a.searchParams.set("token",e.token),a.searchParams.set("username",e.username);super(a.toString());b(this,"cId",0);b(this,"mId",0);b(this,"seqId",0);b(this,"gameCode");M(this,ie);M(this,Ie);b(this,"onMessage",e=>{const s=Le(e);(Fe(s)||Ns(s)||Gt(s))&&this.sendAcknowledgement(s),Gt(s)&&this.handleRealityCheck(s)});this.eventListeners.realityCheck=[],this.gameCode=e.gameCode,v(this,ie,s.requestTimeoutMs),v(this,Ie,s.gameVersion??"unknown"),this.addEventListener("message",this.onMessage)}handleRealityCheck(e){this.eventListeners.realityCheck.forEach(s=>{s(e.body)})}addEventListener(e,s){super.addEventListener(e,s)}removeEventListener(e,s){super.removeEventListener(e,s)}buildHeader(e,s=null){return{cId:s??++this.cId,code:s!==null?1:void 0,mId:++this.mId,name:e}}buildPayload(e,s){return JSON.stringify({body:s,header:e})}getBodyExtras(e){return{action:e,seqId:++this.seqId}}request(e,s){const a=this.buildPayload(e,s);return new Promise((r,c)=>{setTimeout(()=>c({type:"timeout"}),k(this,ie));const g=h=>{const p=Le(h);try{e.cId===p.header.cId&&(this.removeEventListener("message",g),p.header.code===1?r(p):c({message:p,type:"error"}))}catch{c({message:p,type:"error"})}};this.addEventListener("message",g),this.send(a)})}freeRounds(e){const s=this.buildHeader("ActivateFreeRound");return this.request(s,e).then(a=>a.body).catch(a=>{var r;throw{data:(r=a==null?void 0:a.message)==null?void 0:r.body,type:a.type}})}async authenticate(e=!1){const s=this.buildHeader("Authenticate"),a={clientType:3,version:k(this,Ie),reconnect:e};return this.request(s,a).then(r=>r.body).catch(r=>{var c;throw{data:(c=r==null?void 0:r.message)==null?void 0:c.body,type:r.type}})}async getBalance(){const e=this.buildHeader("GetBalance"),s={};return this.request(e,s).then(a=>a.body).catch(a=>{var r;throw{data:(r=a==null?void 0:a.message)==null?void 0:r.body,type:a.type}})}async openGame(){const e=this.buildHeader("OpenGame"),s={gameCode:this.gameCode};return new Promise((a,r)=>{const c=g=>{const h=Le(g);Ds(h)?(this.removeEventListener("message",c),a(h.body)):Ht(h)&&r({data:h.body,type:"error"})};this.addEventListener("message",c),this.request(e,s).catch(g=>{var h;return r({data:(h=g==null?void 0:g.message)==null?void 0:h.body,type:g.type})})})}sendAcknowledgement(e){const{name:s,cId:a}=e.header,r=this.buildHeader(s,a),c=this.buildPayload(r,{});this.send(c)}sendAction(e,s){const a=this.buildHeader("GameAction"),r={...this.getBodyExtras(e),data:s};return new Promise((c,g)=>{const h=p=>{const m=Le(p);Fe(m)&&r.seqId===m.body.correlationSeqId&&(this.removeEventListener("message",h),Gs(m)?c(m.body):Ht(m)&&g({data:m.body,type:"error"}))};this.addEventListener("message",h),this.request(a,r).catch(p=>{var m;return g({data:(m=p==null?void 0:p.message)==null?void 0:m.body,type:p.type})})})}setRequestTimeoutMs(e){v(this,ie,e)}}ie=new WeakMap,Ie=new WeakMap;const Vs={CA_BC:"CA",CA_ON:"CA",GER:"DE",US_CT:"US",US_MI:"US",US_NJ:"US",USA:"US"};function Vt(i){return!i||i==="NOT_APPLICABLE"?null:Vs[i]??i}function es(i){const t=i.contract;return t?{contract:{balance:{coins:t.balance,version:t.balanceVersion},coinValueInCents:t.coinValueInCents,country:t.countryCode,currency:t.currencyCode,jurisdiction:Vt(t.jurisdictionCode),uiMessages:t.uiMessages,username:t.username}}:{contract:{balance:{coins:i.balance,version:i.balanceVersion},coinValueInCents:i.coinValueInCents,country:i.countryCode,currency:i.currencyCode,jurisdiction:Vt(i.jurisdictionCode),uiMessages:i.uiMessages,username:i.username}}}function ts(i){var t,e;return{code:((t=i.data)==null?void 0:t.code)??He.RgsErrorCode.UNKNOWN,details:(e=i.data)==null?void 0:e.details}}function ss(i,t,e){const s=t.contract;if(!s){const a=t.data;return{contract:{bet:{available:a.additionalConfigData.availableMultipliersPerBaseBet,default:{base:a.additionalConfigData.defaultBet.baseBet,multiplier:a.additionalConfigData.defaultBet.betMultiplier},max:a.additionalConfigData.maxAllowedOverallBetInCoins??null,last:a.gameState.betFromCurrentRound?{base:a.gameState.betFromCurrentRound.baseBet,multiplier:a.gameState.betFromCurrentRound.betMultiplier}:null,lastPaid:a.gameState.lastPlacedMainGameBet?{base:a.gameState.lastPlacedMainGameBet.baseBet,multiplier:a.gameState.lastPlacedMainGameBet.betMultiplier}:null},balance:{coins:t.balance,version:t.balanceVersion},freeRounds:(a.FREE_ROUNDS??[]).map(r=>({conf:{base:r.conf.baseBet,multiplier:r.conf.betMultiplier,numAwarded:r.conf.numAwarded},data:{numPlayed:r.data.numPlayed,win:r.data.winAmount,numLeft:r.data.numLeft},id:r.id,rejectable:r.rejectable,skippable:r.skippable,status:r.status,type:r.type})),gameModel:a.additionalConfigData.gameModelFile,metaData:a.gameConfigData.metaData,roundId:a.gameState.cycleId,serverTime:t.balanceVersion,sessionId:a.gameState.sessionId,stateType:{thisRound:a.gameState.stateTypeThisRound,nextRound:a.gameState.stateTypeNextRound},uiMessages:i.uiMessages,win:{max:a.maxWin??null,round:a.gameState.totalWinFromCurrentRound,total:a.gameState.totalWinFromCurrentGameCycle}},data:a}}return{contract:{bet:{available:s.availableMultipliersPerBaseBet,default:{base:s.defaultBet.baseBet,multiplier:s.defaultBet.betMultiplier},max:s.maxBetInCoins??null,last:s.lastBet?{base:s.lastBet.baseBet,multiplier:s.lastBet.betMultiplier}:null,lastPaid:s.lastMainGameBet?{base:s.lastMainGameBet.baseBet,multiplier:s.lastMainGameBet.betMultiplier}:null},balance:{coins:s.balanceInCoins,version:s.balanceVersion},freeRounds:(s.freeRounds??[]).map(a=>({conf:{base:a.conf.baseBet,multiplier:a.conf.betMultiplier,numAwarded:a.conf.numAwarded},data:{numPlayed:a.data.numPlayed,win:a.data.winAmount,numLeft:a.data.numLeft},id:a.id,rejectable:a.rejectable,skippable:a.skippable,status:a.status,type:a.type})),gameModel:s.gameModelFile,metaData:s.metaData,roundId:s.roundId,serverTime:s.serverTime,sessionId:s.sessionId,stateType:{thisRound:s.stateTypeThisRound,nextRound:s.stateTypeNextRound},uiMessages:i.contract.uiMessages.concat(s.uiMessages),win:{max:s.maxWinInCoins??null,round:s.roundWin,total:s.totalWin}},data:e?e(t.opaqueGameServerToUi):t.opaqueGameServerToUi}}function is(i){var t,e;return{code:((t=i.data)==null?void 0:t.code)??He.RgsErrorCode.UNKNOWN,details:(e=i.data)==null?void 0:e.details}}function as(i,t){const e=i.contract;if(!e){const s=i.data;return{contract:{bet:{last:s.gameState.betFromCurrentRound?{base:s.gameState.betFromCurrentRound.baseBet,multiplier:s.gameState.betFromCurrentRound.betMultiplier}:null,lastPaid:{base:(s.gameState.lastPlacedMainGameBet??s.gameState.betFromCurrentRound).baseBet,multiplier:(s.gameState.lastPlacedMainGameBet??s.gameState.betFromCurrentRound).betMultiplier}},balance:{coins:i.balance,version:i.balanceVersion},freeRounds:(s.FREE_ROUNDS??[]).map(a=>({conf:{base:a.conf.baseBet,multiplier:a.conf.betMultiplier,numAwarded:a.conf.numAwarded},data:{numPlayed:a.data.numPlayed,win:a.data.winAmount,numLeft:a.data.numLeft},id:a.id,rejectable:a.rejectable,skippable:a.skippable,status:a.status,type:a.type})),serverTime:i.balanceVersion,roundId:s.gameState.cycleId,stateType:{thisRound:s.gameState.stateTypeThisRound,nextRound:s.gameState.stateTypeNextRound},uiMessages:s.uiMessages,win:{round:s.gameState.totalWinFromCurrentRound,total:s.gameState.totalWinFromCurrentGameCycle}},data:s}}return{contract:{bet:{last:e.lastBet?{base:e.lastBet.baseBet,multiplier:e.lastBet.betMultiplier}:null,lastPaid:{base:e.lastMainGameBet.baseBet,multiplier:e.lastMainGameBet.betMultiplier}},balance:{coins:e.balanceInCoins,version:e.balanceVersion},freeRounds:(e.freeRounds??[]).map(s=>({conf:{base:s.conf.baseBet,multiplier:s.conf.betMultiplier,numAwarded:s.conf.numAwarded},data:{numPlayed:s.data.numPlayed,win:s.data.winAmount,numLeft:s.data.numLeft},id:s.id,rejectable:s.rejectable,skippable:s.skippable,status:s.status,type:s.type})),serverTime:e.serverTime,roundId:e.roundId,stateType:{thisRound:e.stateTypeThisRound,nextRound:e.stateTypeNextRound},uiMessages:e.uiMessages,win:{round:e.roundWin,total:e.totalWin}},data:t?t(i.opaqueGameServerToUi):i.opaqueGameServerToUi}}function ns(i){var t,e;return{code:((t=i.data)==null?void 0:t.code)??He.RgsErrorCode.UNKNOWN,details:(e=i.data)==null?void 0:e.details}}const zs={parseAuthenticateResponse:es,parseAuthenticateError:ts,parseOpenGameResponse:ss,parseOpenGameError:is,parsePlayResponse:as,parsePlayError:ns},qs={aze:"az",bul:"bg",chi:"zh",zho:"zh",hrv:"hr",cze:"cs",dan:"da",dut:"nl",eng:"en",est:"et",fin:"fi",fra:"fr",ger:"de",gre:"el",hun:"hu",ind:"id",ita:"it",jpn:"ja",kor:"ko",nor:"no",pol:"pl",por:"pt",rum:"ro",rus:"ru",srp:"sr",slo:"sk",spa:"es",swe:"sv",tha:"th",tur:"tr",ukr:"uk",vie:"vi"},{device:Ws}=B(navigator.userAgent),js=A("KalambaBullseyePlugin","color:#000000;font-weight:bold;");class $s extends Zt{constructor(...e){super(...e);b(this,"socket");b(this,"error");this.on("openGame",async()=>{try{this.error=void 0;const s=await this.openGame();this.send("openGameResponse",s)}catch(s){this.error=s,this.send("openGameError",s)}}),this.on("play",async s=>{try{this.error=void 0;const a=await this.play(s);this.send("playResponse",a)}catch(a){this.error=a,this.send("playError",a)}}),this.on("freeRounds",async s=>{try{this.error=void 0,await this.socket.freeRounds(s),this.send("freeRoundsResponse",s)}catch(a){this.error=a,this.send("freeRoundsError",a)}}),this.on("getBalance",async()=>{try{this.error=void 0;const s=await this.socket.getBalance();this.send("balance",{balance:s.balance})}catch{}}),this.on("configured",s=>{this.socket.setRequestTimeoutMs(s.ui.requestTimeoutMs)}),this.registerFromSdkEvents()}initialize(e){this.socket=new Hs(e,{gameVersion:this.config.gameVersion,requestTimeoutMs:this.sdkConfig.ui.requestTimeoutMs}),["fireboltroulette"].includes(e.gameCode)||(this.socket.addEventListener("close",s=>{s.code===1008?this.error||this.send("error",{type:"CLOSE",messageCode:"TOO_MANY_OPEN_GAMES",messageKey:"RgsError.TOO_MANY_OPEN_GAMES"}):s.code===1011?this.error||this.send("error",{type:"CLOSE",messageCode:"UNKNOWN",messageKey:"RgsError.UNKNOWN"}):this.reconnect()}),["mobile","tablet"].includes(Ws.type??"")&&document.addEventListener("visibilitychange",async()=>{document.hidden||(this.socket.socket?this.socket.socket&&[WebSocket.CONNECTING,WebSocket.OPEN].includes(this.socket.socket.readyState)&&this.socket.close():this.reconnect())})),this.socket.addEventListener("error",s=>js("error",s)),this.socket.addEventListener("realityCheck",s=>{this.send("realityCheck",s)})}async reconnect(){try{await this.socket.connect(),await this.socket.authenticate(!0),await this.socket.openGame()}catch{this.send("error",{type:"CLOSE",messageCode:"CONNECTION_ERROR",messageKey:"RgsError.CONNECTION_ERROR"})}}async openGame(){var H,Oe;const e=new URLSearchParams(window.location.search),s=e.get("apiUrl"),a=e.get("cageCode"),r=e.get("gameCode"),c=e.get("operatorCode"),g=e.get("playMode"),h=e.get("token"),p=e.get("username"),m=e.get("gameHistoryUrl"),C=e.get("homeUrl")??void 0,P=e.get("cashierUrl")??void 0;this.initialize({apiUrl:s,cageCode:a,gameCode:r,operatorCode:c,playMode:g,token:h,username:p});try{await this.socket.connect()}catch{throw{type:"error",data:{code:He.RgsErrorCode.CONNECTION_ERROR}}}let G;try{G=await this.socket.authenticate()}catch(X){throw{type:X.type,data:X.type==="error"?ts(X.data):void 0}}let pe;try{pe=await this.socket.openGame()}catch(X){throw{type:X.type,data:X.type==="error"?is(X.data):void 0}}const _=es(G),K=ss(G,pe,this.config.dataDecoder&&qe.decoders[this.config.dataDecoder]);this.sdkConfig.api={...this.sdkConfig.api,brand:a,game:r,integration:c,jurisdiction:_.contract.jurisdiction,playMode:g,user:_.contract.username,integrationData:{token:h},country:_.contract.country,currency:_.contract.currency,coinValueInCents:_.contract.coinValueInCents,gameHistoryUrl:m,homeUrl:C,cashierUrl:P,backendSessionId:K.contract.sessionId,lastRoundId:K.contract.roundId};const Q=(Oe=(H=e.get("languageCode"))==null?void 0:H.split("_"))==null?void 0:Oe[0];return Q&&(this.sdkConfig.ui.language=Q.length===3?qs[Q]??Q:Q),K}async play(e){for(;!this.socket.socket;)await new Promise(P=>setTimeout(()=>P(),500));const{contract:{bet:s,forcedOutcomes:a,...r},extra:c,payloadToInject:g,actionType:h}=e,p=this.config.dataEncoder&&qe.encoders[this.config.dataEncoder],m={bet:s?{baseBet:s.base,betMultiplier:s.multiplier}:void 0,forcedOutcomes:a,...r,...g,opaqueUiToGameServer:p?p(c):c};let C;try{C=await this.socket.sendAction(h,m)}catch(P){throw{type:P.type,data:P.type==="error"?ns(P.data):void 0}}return as(C,this.config.dataDecoder&&qe.decoders[this.config.dataDecoder])}registerFromSdkEvents(){this.on("history",()=>{const{api:{game:e,integration:s,integrationData:a,jurisdiction:r,user:c,gameHistoryUrl:g},ui:{language:h}}=this.sdkConfig,p=c.replace(/^user_/,"").replace(new RegExp(`_${s}$`),""),m=new URL(window.location.href);m.hostname=m.hostname.replace(/^v\./,"").replace(/^play\./,"history."),m.pathname=m.pathname.replace(/(\/[0-9]+\.[0-9]+\.[0-9]+)?\/wrapper\.html/,"/list/index.html"),m.search="",m.searchParams.set("apiUrl",new URL(g).origin),m.searchParams.set("gameCode",e),r&&m.searchParams.set("jurisdiction",r),m.searchParams.set("operatorCode",s),m.searchParams.set("token",a.token),m.searchParams.set("username",p),m.searchParams.set("languageCode",h),this.config.gameHistoryUrl&&m.searchParams.set("gameHistoryUrl",this.config.gameHistoryUrl),window.open(m.toString(),"_blank")})}}class os{constructor(t,e,s){b(this,"trackers");b(this,"config");b(this,"sdkConfig");this.trackers=t,this.config=e,this.sdkConfig=s}on(t,e,s){const a=function(c){c.data.message!==`kalamba:wrapper-telemetry:${t}`&&c.data.message!==`kalamba:wrapper:${t}`||e(c.data.payload)};window.addEventListener("message",a,s)}track(t,e){this.trackers.forEach(s=>s.track(t,e))}}function zt(i){return i.reduce((t,e)=>t+e,0)}function Ks(i){const t=i.length,e=zt(i)/t,s=i.map(r=>Math.pow(r-e,2)),a=zt(s)/t;return Math.sqrt(a)}class qt{constructor(){b(this,"rafId",-1);b(this,"startTime",0);b(this,"stopTime",0);b(this,"frames",[]);b(this,"calculateFPS",()=>{const t=Math.floor((this.stopTime-this.startTime)/1e3);return this.frames.map(e=>Math.floor((e-this.startTime)/1e3)).reduce((e,s,a,r)=>(r[a]!==r[a-1]?e.push(1):e[e.length-1]++,e),[]).slice(0,t)});b(this,"getReport",()=>{const t=this.calculateFPS(),e=Math.floor(this.frames.length/((this.stopTime-this.startTime)/1e3)),s=t.length>0?Math.max(...t):e,a=t.length>0?Math.min(...t):e,r=t.length>0?Ks(t):0;return{fpsAvg:e,fpsMax:s,fpsMin:a,fpsStdDev:r}});b(this,"start",()=>{this.startTime=Date.now(),this.frames=[],this.trackFrames()});b(this,"stop",()=>{cancelAnimationFrame(this.rafId),this.stopTime=Date.now()});b(this,"trackFrames",()=>{this.frames.push(Date.now()),this.rafId=requestAnimationFrame(this.trackFrames)})}}const Qs="landscape",Xs="portrait";function Js(){try{const i=document.createElement("canvas");return!!window.WebGLRenderingContext&&(i.getContext("webgl")||i.getContext("experimental-webgl"))instanceof WebGLRenderingContext}catch{return!1}}async function Ys(){if(!window.createImageBitmap)return!1;const e=await(await fetch("data:image/webp;base64,UklGRiQAAABXRUJQVlA4IBgAAAAwAQCdASoCAAEAAQAcJaQAA3AA/v3AgAA=")).blob();try{return await createImageBitmap(e),!0}catch{return!1}}function ct(){return window.innerWidth>=window.innerHeight?Qs:Xs}var Ne,ae,ne,oe,Pe,De,Ae,Ge;class Zs extends os{constructor(...e){super(...e);b(this,"FPS_SAMPLE_INTERVAL",1e4);M(this,Ne,0);M(this,ae);M(this,ne);M(this,oe);M(this,Pe,!1);M(this,De,!1);M(this,Ae,"");M(this,Ge,[]);v(this,ne,{}),v(this,oe,this.deviceInfo()),v(this,ae,this.config.gameVersion),this.on("state",({balance:s})=>{v(this,Ne,s)}),this.on("autoplay",({action:s})=>{["start","resume"].includes(s)?v(this,Pe,!0):v(this,Pe,!1)}),this.on("settings",({fastPlay:s})=>{s!==void 0&&v(this,De,s)}),this.registerEvents()}async registerEvents(){k(this,oe).then(e=>{this.track("Device Information",e)}),this.on("loadStart",()=>{this.track("Game Loading",{progress:0,step:"initial"})}),this.on("loadProgress",e=>{this.track("Game Loading",{progress:e.progress})}),this.on("loadEnd",()=>{this.track("Game Loading",{progress:100,step:"complete"})}),this.on("error",e=>{this.track("System Message",{systemMessageText:e.messageCode,systemMessageType:e.type})}),this.on("openGameResponse",async e=>{v(this,Ae,e.contract.stateType.nextRound),v(this,ne,{balanceInCoins:e.contract.balance.coins,clientVersion:k(this,ae),coinValueInCents:this.sdkConfig.api.coinValueInCents,coinValueInCentsFloat:this.sdkConfig.api.coinValueInCents,currency:this.sdkConfig.api.currency,defaultBaseBet:e.contract.bet.default.base,defaultBetMultiplier:e.contract.bet.default.multiplier,environment:"release",gameCode:this.sdkConfig.api.game,gameCodeServer:this.sdkConfig.api.game,gameModelFile:e.contract.gameModel,jurisdiction:this.sdkConfig.api.jurisdiction,languageCode:this.sdkConfig.ui.language,operatorName:"kalamba",partnerId:this.sdkConfig.api.brand,partnerParentId:this.sdkConfig.api.integration,platform:"WEB",playMode:this.sdkConfig.api.playMode,referrer:window.location.hostname,rootTrackingSessionID:this.sdkConfig.api.sessionId,backendSessionID:this.sdkConfig.api.backendSessionId,serverVersion:e.contract.metaData.version}),this.track("Game Open",k(this,ne))}),this.on("playCycleEnd",async e=>{const s=await k(this,oe),{base:a,multiplier:r}=e.contract.bet.lastPaid??{},c=e.contract.balance.coins,g=e.contract.bet.lastPaid.base*e.contract.bet.lastPaid.multiplier,h=e.contract.win.total,p=h-g,m="spin",C=e.contract.roundId;this.track("Betting Activity",{balance:c-p,balanceAfter:c,baseBet:a,betMultiplier:r,betType:m,gameVersion:k(this,ae),coinValueInCents:this.sdkConfig.api.coinValueInCents,coinValueInCentsFloat:this.sdkConfig.api.coinValueInCents,currency:this.sdkConfig.api.currency,environment:"release",gameCode:this.sdkConfig.api.game,gameCodeServer:this.sdkConfig.api.game,isMobile:s.isMobile,netResult:p,operatorName:"kalamba",orientation:ct(),partnerId:this.sdkConfig.api.brand,partnerParentId:this.sdkConfig.api.integration,platform:"WEB",playMode:this.sdkConfig.api.playMode,roundId:C,roundTypes:["BaseGame"],totalBet:g,totalWin:h}),v(this,Ge,[])}),this.on("telemetry.click",e=>{this.track("UI Interaction",{action:"click",...this.getExtraUiInteractionData(),...e})}),this.on("telemetry.orientationChange",()=>{this.track("UI Interaction",{action:"orientationChange",...this.getExtraUiInteractionData()})}),this.reportFpsSample(),this.reportFpsRound()}reportFpsSample(){const e=new qt,s=()=>{e.stop();const r=e.getReport();this.track("FPS Performance",{...r,fpsType:"sample"}),a()},a=async()=>{e.start(),setTimeout(s,this.FPS_SAMPLE_INTERVAL)};a()}reportFpsRound(){const e=new qt;this.on("playCycleStart",()=>{e.start()}),this.on("playCycleEnd",()=>{e.stop();const s=e.getReport();this.track("FPS Performance",{...s,fpsType:"playCycleStart->playCycleEnd"})})}getExtraUiInteractionData(){return{orientation:ct(),stateType:k(this,Ae)}}async deviceInfo(){var g;const{browser:e,device:s,os:a}=B(navigator.userAgent),r=Js(),c=await Ys();return{browserName:e.name,browserVersion:e.version,connection:(g=navigator.connection)==null?void 0:g.effectiveType,deviceName:s.model,deviceType:s.type,isMobile:["mobile","tablet"].includes(s.type??""),isWebGLSupported:r,isWebPSupported:c,manufacturer:s.vendor,operatingSystem:a.name,operatingSystemVersion:a.version,orientation:ct(),pixelRatio:window.devicePixelRatio,screenHeight:window.screen.height,screenSize:`${window.screen.width}x${window.screen.height}`,screenWidth:window.screen.width,timezoneOffsetMinutes:new Date().getTimezoneOffset(),windowHeight:window.innerHeight,windowSize:`${window.innerWidth}x${window.innerHeight}`,windowWidth:window.innerWidth}}}Ne=new WeakMap,ae=new WeakMap,ne=new WeakMap,oe=new WeakMap,Pe=new WeakMap,De=new WeakMap,Ae=new WeakMap,Ge=new WeakMap;var ei=gt.requireNoop();const Wt=gt.getDefaultExportFromCjs(ei);class bt{constructor(t,e){b(this,"config");b(this,"sdkConfig");this.config=t,this.sdkConfig=e}}const jt=25,$t=1e4;var re,ce,de,W;class ti extends bt{constructor(...e){super(...e);M(this,re,"https://europe-west3-stargazer-328808.cloudfunctions.net/collect-events");M(this,ce);M(this,de);M(this,W,[]);b(this,"processQueueForced");v(this,ce,new Date().getTime()),v(this,W,[]),this.processQueueForced=this.processQueue.bind(this,!0),this.schedule(),fetch(k(this,re),{method:"OPTIONS"}).catch(Wt),this.subscribe()}subscribe(){window.addEventListener("beforeunload",this.processQueueForced,!1),window.addEventListener("pagehide",this.processQueueForced,!1),window.addEventListener("visibilitychange",this.processQueueForced,!1)}schedule(){k(this,de)&&clearTimeout(k(this,de)),v(this,de,window.setTimeout(()=>this.processQueue(),$t))}send(e){v(this,ce,new Date().getTime());try{navigator.sendBeacon(k(this,re),JSON.stringify(e))}catch{fetch(k(this,re),{body:JSON.stringify(e),method:"POST",headers:{"Content-Type":"application/json"},keepalive:!0}).catch(Wt)}this.schedule()}addToQueue(e){k(this,W).push(e),this.processQueue()}processQueue(e=!1){if(!(this.sdkConfig==null||!this.sdkConfig.ui.feature.allowTelemetry)&&!(!e&&k(this,W).length<jt&&new Date().getTime()-k(this,ce)<$t))for(;k(this,W).length;){const s=k(this,W).splice(0,jt).map(a=>({...a,sessionID:this.sdkConfig.api.sessionId,userID:this.sdkConfig.api.user}));this.send(s)}}track(e,s){this.addToQueue({eventName:e,eventParams:s,eventTimestamp:new Date().getTime(),eventUUID:gt.v4()})}}re=new WeakMap,ce=new WeakMap,de=new WeakMap,W=new WeakMap;const si=A("LoggingTracker","color:#000000;font-weight:bold;");class ii extends bt{track(t,e){si(`@${this.sdkConfig.api.user}`,`[${t}]`,e)}}exports.BasicPlugin=ls;exports.CasinoPlugin=U;exports.DebuggingPlugin=hs;exports.EveryMatrixPlugin=Ms;exports.GigPlugin=gs;exports.KalambaBullseyeParsers=zs;exports.KalambaBullseyePlugin=$s;exports.KalambaStargazerPlugin=Zs;exports.KalambaStargazerTracker=ti;exports.LoggingTracker=ii;exports.OryxPlugin=ws;exports.PariplayPlugin=ys;exports.QuantaPlugin=Es;exports.RelaxFEIMPlugin=ks;exports.RgsPlugin=Zt;exports.SoftSwissPlugin=Cs;exports.TelemetryPlugin=os;exports.Tracker=bt;exports.TukoPlugin=vs;
package/dist/plugins.d.ts CHANGED
@@ -74,12 +74,13 @@ declare type CasinoOnlyMessagePayloadMap = {
74
74
  };
75
75
  close: never;
76
76
  freeze: never;
77
- help: {
78
- show?: boolean;
77
+ getBalance: never;
78
+ help?: {
79
+ show: boolean;
79
80
  };
80
81
  history: History_2;
81
- paytable: {
82
- show?: boolean;
82
+ paytable?: {
83
+ show: boolean;
83
84
  };
84
85
  play: PlayRequest;
85
86
  resume: never;
@@ -93,7 +94,7 @@ export declare abstract class CasinoPlugin {
93
94
  sdkConfig: SdkConfig;
94
95
  constructor(config: WrapperConfig, sdkConfig: SdkConfig);
95
96
  protected on<M extends DomainMessage<'wrapper'> | ForwardToPluginsMessage<'casino'>>(message: M, listener: (payload: M extends DomainMessage<'wrapper'> ? DomainMessagePayload<'wrapper', M> : M extends ForwardToPluginsMessage<'casino'> ? ForwardToPluginsMessagePayload<'casino', M> : never) => void, options?: AddEventListenerOptions): void;
96
- protected send<M extends DomainMessage<'casino'>>(message: M, ...[payload]: DomainMessagePayload<'casino', M> extends never ? [] : [payload: DomainMessagePayload<'casino', M>]): void;
97
+ protected send<M extends DomainMessage<'casino'>>(message: M, ...[payload]: DomainMessagePayload<'casino', M> extends never ? [] : undefined extends DomainMessagePayload<'casino', M> ? [] | [DomainMessagePayload<'casino', M>] : [DomainMessagePayload<'casino', M>]): void;
97
98
  }
98
99
 
99
100
  declare type ContractPlayPayload = {
@@ -142,6 +143,13 @@ declare const encoders: {
142
143
  };
143
144
  };
144
145
 
146
+ export declare class EveryMatrixPlugin extends CasinoPlugin {
147
+ constructor(...args: ConstructorParameters<typeof CasinoPlugin>);
148
+ postMessage(event: unknown, payload?: Record<string, unknown>): void;
149
+ registerToSdkEvents(): void;
150
+ registerFromSdkEvents(): void;
151
+ }
152
+
145
153
  declare type ForwardToPluginsMessage<P extends PluginDomain> = keyof ForwardToPluginsMessageMap<'sdk'>[P] | keyof ForwardToPluginsMessageMap<'rgs'>[P] | keyof ForwardToPluginsMessageMap<'casino'>[P] | keyof ForwardToPluginsMessageMap<'telemetry'>[P];
146
154
 
147
155
  declare interface ForwardToPluginsMessageMap<SourceDomain extends DomainPrefix> {
@@ -305,6 +313,10 @@ declare class KalambaWebSocketClient extends WebSocketClient {
305
313
  username: string;
306
314
  };
307
315
  }>;
316
+ getBalance(): Promise<{
317
+ balance: number;
318
+ balanceVersion: string;
319
+ }>;
308
320
  openGame(): Promise<Record<string, unknown> & {
309
321
  contract: {
310
322
  availableMultipliersPerBaseBet: Record<number, number[]>;
@@ -622,7 +634,7 @@ export declare class RelaxFEIMPlugin extends CasinoPlugin {
622
634
  registerFromSdkEvents(): void;
623
635
  }
624
636
 
625
- declare type ResponseMessageName = 'Authenticate' | 'GameAction' | 'GameEvent' | 'OpenGame' | 'Ping' | 'RealityCheck';
637
+ declare type ResponseMessageName = 'Authenticate' | 'GameAction' | 'GameEvent' | 'GetBalance' | 'OpenGame' | 'Ping' | 'RealityCheck';
626
638
 
627
639
  declare type ResultGameEvent = GameEvent<Record<string, unknown> & {
628
640
  contract: {
@@ -711,6 +723,9 @@ declare type RgsOnlyMessagePayloadMap = {
711
723
  sumBetAmount: number;
712
724
  sumWinAmount: number;
713
725
  };
726
+ balance: {
727
+ balance: number;
728
+ };
714
729
  };
715
730
 
716
731
  export declare abstract class RgsPlugin {
@@ -718,7 +733,7 @@ export declare abstract class RgsPlugin {
718
733
  sdkConfig: SdkConfig;
719
734
  constructor(config: WrapperConfig, sdkConfig: SdkConfig);
720
735
  protected on<M extends DomainMessage<'wrapper'> | ForwardToPluginsMessage<'rgs'>>(message: M, listener: (payload: M extends DomainMessage<'wrapper'> ? DomainMessagePayload<'wrapper', M> : M extends ForwardToPluginsMessage<'rgs'> ? ForwardToPluginsMessagePayload<'rgs', M> : never) => void, options?: AddEventListenerOptions): void;
721
- protected send<M extends DomainMessage<'rgs'>>(message: M, ...[payload]: DomainMessagePayload<'rgs', M> extends never ? [] : [payload: DomainMessagePayload<'rgs', M>]): void;
736
+ protected send<M extends DomainMessage<'rgs'>>(message: M, ...[payload]: DomainMessagePayload<'rgs', M> extends never ? [] : undefined extends DomainMessagePayload<'rgs', M> ? [] | [DomainMessagePayload<'rgs', M>] : [DomainMessagePayload<'rgs', M>]): void;
722
737
  }
723
738
 
724
739
  declare interface SdkConfig {
@@ -863,6 +878,12 @@ declare type Settings = {
863
878
  music?: boolean;
864
879
  };
865
880
 
881
+ export declare class SoftSwissPlugin extends CasinoPlugin {
882
+ constructor(...args: ConstructorParameters<typeof CasinoPlugin>);
883
+ postMessage(event: unknown, payload?: Record<string, unknown>): void;
884
+ registerFromSdkEvents(): void;
885
+ }
886
+
866
887
  declare type TelemetryOnlyMessagePayloadMap = {
867
888
  [key: string]: unknown;
868
889
  };
@@ -886,7 +907,7 @@ declare type ToCasinoPluginsForwardedMessageMap = {
886
907
 
887
908
  declare type ToRgsPluginsForwardedMessageMap = {
888
909
  sdk: Pick<SdkOnlyMessagePayloadMap, 'history' | 'openGame' | 'play'>;
889
- casino: Pick<CasinoOnlyMessagePayloadMap, 'play' | 'cashier' | 'close' | 'history'>;
910
+ casino: Pick<CasinoOnlyMessagePayloadMap, 'play' | 'cashier' | 'close' | 'history' | 'getBalance'>;
890
911
  rgs: undefined;
891
912
  telemetry: undefined;
892
913
  wrapper: undefined;