randmarcomps 1.401.0 → 1.403.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.
@@ -54367,7 +54367,7 @@ function useAIAssistant({ userId: t, config: e }) {
54367
54367
  const Ve = `${oe.name} failed.`;
54368
54368
  return console.error(Ve, ge), JSON.stringify({ error: Ve, details: ge instanceof Error ? ge.message : String(ge) });
54369
54369
  }
54370
- }, j = async (oe, Ne = 5) => {
54370
+ }, j = async (oe, Ne = 10) => {
54371
54371
  var ge, Ve, Fe;
54372
54372
  if (Ne === 0) {
54373
54373
  ae({ content: "I've reached my action limit for this request. Please let me know if you'd like me to continue.", timestamp: /* @__PURE__ */ new Date() }), o("");
@@ -62324,7 +62324,8 @@ const fetchGeminiResponse = async (t, e, n, o, l = 3) => {
62324
62324
  g(Ge.some((it) => it.unread > 0));
62325
62325
  }, [Ge, g]);
62326
62326
  const Ut = (it, Ht) => {
62327
- console.log("doSend", Ht), console.log("target", it);
62327
+ Ht = Ht.replace(/\n/g, `
62328
+ `), console.log("doSend", Ht), console.log("target", it);
62328
62329
  const Xt = {
62329
62330
  id: crypto.randomUUID(),
62330
62331
  senderName: e,
@@ -1055,7 +1055,7 @@ In order to be iterable, non-array objects must have a [Symbol.iterator]() metho
1055
1055
  * @license MIT
1056
1056
  */var hasRequiredMd5$1;function requireMd5$1(){return hasRequiredMd5$1||(hasRequiredMd5$1=1,(function(t){(function(){var e="input is invalid type",n="finalize already called",o=typeof window=="object",l=o?window:{};l.JS_MD5_NO_WINDOW&&(o=!1);var d=!o&&typeof self=="object",f=!l.JS_MD5_NO_NODE_JS&&typeof process=="object"&&process.versions&&process.versions.node;f?l=commonjsGlobal:d&&(l=self);var g=!l.JS_MD5_NO_COMMON_JS&&!0&&t.exports,b=!l.JS_MD5_NO_ARRAY_BUFFER&&typeof ArrayBuffer<"u",S="0123456789abcdef".split(""),_=[128,32768,8388608,-2147483648],R=[0,8,16,24],C=["hex","array","digest","buffer","arrayBuffer","base64"],E="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split(""),A=[],I;if(b){var M=new ArrayBuffer(68);I=new Uint8Array(M),A=new Uint32Array(M)}var V=Array.isArray;(l.JS_MD5_NO_NODE_JS||!V)&&(V=function(se){return Object.prototype.toString.call(se)==="[object Array]"});var O=ArrayBuffer.isView;b&&(l.JS_MD5_NO_ARRAY_BUFFER_IS_VIEW||!O)&&(O=function(se){return typeof se=="object"&&se.buffer&&se.buffer.constructor===ArrayBuffer});var z=function(se){var Ne=typeof se;if(Ne==="string")return[se,!0];if(Ne!=="object"||se===null)throw new Error(e);if(b&&se.constructor===ArrayBuffer)return[new Uint8Array(se),!1];if(!V(se)&&!O(se))throw new Error(e);return[se,!1]},Q=function(se){return function(Ne){return new ae(!0).update(Ne)[se]()}},j=function(){var se=Q("hex");f&&(se=F(se)),se.create=function(){return new ae},se.update=function(Ve){return se.create().update(Ve)};for(var Ne=0;Ne<C.length;++Ne){var ge=C[Ne];se[ge]=Q(ge)}return se},F=function(se){var Ne=require$$1,ge=require$$1.Buffer,Ve;ge.from&&!l.JS_MD5_NO_BUFFER_FROM?Ve=ge.from:Ve=function(qe){return new ge(qe)};var Le=function(qe){if(typeof qe=="string")return Ne.createHash("md5").update(qe,"utf8").digest("hex");if(qe==null)throw new Error(e);return qe.constructor===ArrayBuffer&&(qe=new Uint8Array(qe)),V(qe)||O(qe)||qe.constructor===ge?Ne.createHash("md5").update(Ve(qe)).digest("hex"):se(qe)};return Le},te=function(se){return function(Ne,ge){return new je(Ne,!0).update(ge)[se]()}},ne=function(){var se=te("hex");se.create=function(Ve){return new je(Ve)},se.update=function(Ve,Le){return se.create(Ve).update(Le)};for(var Ne=0;Ne<C.length;++Ne){var ge=C[Ne];se[ge]=te(ge)}return se};function ae(se){if(se)A[0]=A[16]=A[1]=A[2]=A[3]=A[4]=A[5]=A[6]=A[7]=A[8]=A[9]=A[10]=A[11]=A[12]=A[13]=A[14]=A[15]=0,this.blocks=A,this.buffer8=I;else if(b){var Ne=new ArrayBuffer(68);this.buffer8=new Uint8Array(Ne),this.blocks=new Uint32Array(Ne)}else this.blocks=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];this.h0=this.h1=this.h2=this.h3=this.start=this.bytes=this.hBytes=0,this.finalized=this.hashed=!1,this.first=!0}ae.prototype.update=function(se){if(this.finalized)throw new Error(n);var Ne=z(se);se=Ne[0];for(var ge=Ne[1],Ve,Le=0,qe,Be=se.length,$e=this.blocks,He=this.buffer8;Le<Be;){if(this.hashed&&(this.hashed=!1,$e[0]=$e[16],$e[16]=$e[1]=$e[2]=$e[3]=$e[4]=$e[5]=$e[6]=$e[7]=$e[8]=$e[9]=$e[10]=$e[11]=$e[12]=$e[13]=$e[14]=$e[15]=0),ge)if(b)for(qe=this.start;Le<Be&&qe<64;++Le)Ve=se.charCodeAt(Le),Ve<128?He[qe++]=Ve:Ve<2048?(He[qe++]=192|Ve>>>6,He[qe++]=128|Ve&63):Ve<55296||Ve>=57344?(He[qe++]=224|Ve>>>12,He[qe++]=128|Ve>>>6&63,He[qe++]=128|Ve&63):(Ve=65536+((Ve&1023)<<10|se.charCodeAt(++Le)&1023),He[qe++]=240|Ve>>>18,He[qe++]=128|Ve>>>12&63,He[qe++]=128|Ve>>>6&63,He[qe++]=128|Ve&63);else for(qe=this.start;Le<Be&&qe<64;++Le)Ve=se.charCodeAt(Le),Ve<128?$e[qe>>>2]|=Ve<<R[qe++&3]:Ve<2048?($e[qe>>>2]|=(192|Ve>>>6)<<R[qe++&3],$e[qe>>>2]|=(128|Ve&63)<<R[qe++&3]):Ve<55296||Ve>=57344?($e[qe>>>2]|=(224|Ve>>>12)<<R[qe++&3],$e[qe>>>2]|=(128|Ve>>>6&63)<<R[qe++&3],$e[qe>>>2]|=(128|Ve&63)<<R[qe++&3]):(Ve=65536+((Ve&1023)<<10|se.charCodeAt(++Le)&1023),$e[qe>>>2]|=(240|Ve>>>18)<<R[qe++&3],$e[qe>>>2]|=(128|Ve>>>12&63)<<R[qe++&3],$e[qe>>>2]|=(128|Ve>>>6&63)<<R[qe++&3],$e[qe>>>2]|=(128|Ve&63)<<R[qe++&3]);else if(b)for(qe=this.start;Le<Be&&qe<64;++Le)He[qe++]=se[Le];else for(qe=this.start;Le<Be&&qe<64;++Le)$e[qe>>>2]|=se[Le]<<R[qe++&3];this.lastByteIndex=qe,this.bytes+=qe-this.start,qe>=64?(this.start=qe-64,this.hash(),this.hashed=!0):this.start=qe}return this.bytes>4294967295&&(this.hBytes+=this.bytes/4294967296<<0,this.bytes=this.bytes%4294967296),this},ae.prototype.finalize=function(){if(!this.finalized){this.finalized=!0;var se=this.blocks,Ne=this.lastByteIndex;se[Ne>>>2]|=_[Ne&3],Ne>=56&&(this.hashed||this.hash(),se[0]=se[16],se[16]=se[1]=se[2]=se[3]=se[4]=se[5]=se[6]=se[7]=se[8]=se[9]=se[10]=se[11]=se[12]=se[13]=se[14]=se[15]=0),se[14]=this.bytes<<3,se[15]=this.hBytes<<3|this.bytes>>>29,this.hash()}},ae.prototype.hash=function(){var se,Ne,ge,Ve,Le,qe,Be=this.blocks;this.first?(se=Be[0]-680876937,se=(se<<7|se>>>25)-271733879<<0,Ve=(-1732584194^se&2004318071)+Be[1]-117830708,Ve=(Ve<<12|Ve>>>20)+se<<0,ge=(-271733879^Ve&(se^-271733879))+Be[2]-1126478375,ge=(ge<<17|ge>>>15)+Ve<<0,Ne=(se^ge&(Ve^se))+Be[3]-1316259209,Ne=(Ne<<22|Ne>>>10)+ge<<0):(se=this.h0,Ne=this.h1,ge=this.h2,Ve=this.h3,se+=(Ve^Ne&(ge^Ve))+Be[0]-680876936,se=(se<<7|se>>>25)+Ne<<0,Ve+=(ge^se&(Ne^ge))+Be[1]-389564586,Ve=(Ve<<12|Ve>>>20)+se<<0,ge+=(Ne^Ve&(se^Ne))+Be[2]+606105819,ge=(ge<<17|ge>>>15)+Ve<<0,Ne+=(se^ge&(Ve^se))+Be[3]-1044525330,Ne=(Ne<<22|Ne>>>10)+ge<<0),se+=(Ve^Ne&(ge^Ve))+Be[4]-176418897,se=(se<<7|se>>>25)+Ne<<0,Ve+=(ge^se&(Ne^ge))+Be[5]+1200080426,Ve=(Ve<<12|Ve>>>20)+se<<0,ge+=(Ne^Ve&(se^Ne))+Be[6]-1473231341,ge=(ge<<17|ge>>>15)+Ve<<0,Ne+=(se^ge&(Ve^se))+Be[7]-45705983,Ne=(Ne<<22|Ne>>>10)+ge<<0,se+=(Ve^Ne&(ge^Ve))+Be[8]+1770035416,se=(se<<7|se>>>25)+Ne<<0,Ve+=(ge^se&(Ne^ge))+Be[9]-1958414417,Ve=(Ve<<12|Ve>>>20)+se<<0,ge+=(Ne^Ve&(se^Ne))+Be[10]-42063,ge=(ge<<17|ge>>>15)+Ve<<0,Ne+=(se^ge&(Ve^se))+Be[11]-1990404162,Ne=(Ne<<22|Ne>>>10)+ge<<0,se+=(Ve^Ne&(ge^Ve))+Be[12]+1804603682,se=(se<<7|se>>>25)+Ne<<0,Ve+=(ge^se&(Ne^ge))+Be[13]-40341101,Ve=(Ve<<12|Ve>>>20)+se<<0,ge+=(Ne^Ve&(se^Ne))+Be[14]-1502002290,ge=(ge<<17|ge>>>15)+Ve<<0,Ne+=(se^ge&(Ve^se))+Be[15]+1236535329,Ne=(Ne<<22|Ne>>>10)+ge<<0,se+=(ge^Ve&(Ne^ge))+Be[1]-165796510,se=(se<<5|se>>>27)+Ne<<0,Ve+=(Ne^ge&(se^Ne))+Be[6]-1069501632,Ve=(Ve<<9|Ve>>>23)+se<<0,ge+=(se^Ne&(Ve^se))+Be[11]+643717713,ge=(ge<<14|ge>>>18)+Ve<<0,Ne+=(Ve^se&(ge^Ve))+Be[0]-373897302,Ne=(Ne<<20|Ne>>>12)+ge<<0,se+=(ge^Ve&(Ne^ge))+Be[5]-701558691,se=(se<<5|se>>>27)+Ne<<0,Ve+=(Ne^ge&(se^Ne))+Be[10]+38016083,Ve=(Ve<<9|Ve>>>23)+se<<0,ge+=(se^Ne&(Ve^se))+Be[15]-660478335,ge=(ge<<14|ge>>>18)+Ve<<0,Ne+=(Ve^se&(ge^Ve))+Be[4]-405537848,Ne=(Ne<<20|Ne>>>12)+ge<<0,se+=(ge^Ve&(Ne^ge))+Be[9]+568446438,se=(se<<5|se>>>27)+Ne<<0,Ve+=(Ne^ge&(se^Ne))+Be[14]-1019803690,Ve=(Ve<<9|Ve>>>23)+se<<0,ge+=(se^Ne&(Ve^se))+Be[3]-187363961,ge=(ge<<14|ge>>>18)+Ve<<0,Ne+=(Ve^se&(ge^Ve))+Be[8]+1163531501,Ne=(Ne<<20|Ne>>>12)+ge<<0,se+=(ge^Ve&(Ne^ge))+Be[13]-1444681467,se=(se<<5|se>>>27)+Ne<<0,Ve+=(Ne^ge&(se^Ne))+Be[2]-51403784,Ve=(Ve<<9|Ve>>>23)+se<<0,ge+=(se^Ne&(Ve^se))+Be[7]+1735328473,ge=(ge<<14|ge>>>18)+Ve<<0,Ne+=(Ve^se&(ge^Ve))+Be[12]-1926607734,Ne=(Ne<<20|Ne>>>12)+ge<<0,Le=Ne^ge,se+=(Le^Ve)+Be[5]-378558,se=(se<<4|se>>>28)+Ne<<0,Ve+=(Le^se)+Be[8]-2022574463,Ve=(Ve<<11|Ve>>>21)+se<<0,qe=Ve^se,ge+=(qe^Ne)+Be[11]+1839030562,ge=(ge<<16|ge>>>16)+Ve<<0,Ne+=(qe^ge)+Be[14]-35309556,Ne=(Ne<<23|Ne>>>9)+ge<<0,Le=Ne^ge,se+=(Le^Ve)+Be[1]-1530992060,se=(se<<4|se>>>28)+Ne<<0,Ve+=(Le^se)+Be[4]+1272893353,Ve=(Ve<<11|Ve>>>21)+se<<0,qe=Ve^se,ge+=(qe^Ne)+Be[7]-155497632,ge=(ge<<16|ge>>>16)+Ve<<0,Ne+=(qe^ge)+Be[10]-1094730640,Ne=(Ne<<23|Ne>>>9)+ge<<0,Le=Ne^ge,se+=(Le^Ve)+Be[13]+681279174,se=(se<<4|se>>>28)+Ne<<0,Ve+=(Le^se)+Be[0]-358537222,Ve=(Ve<<11|Ve>>>21)+se<<0,qe=Ve^se,ge+=(qe^Ne)+Be[3]-722521979,ge=(ge<<16|ge>>>16)+Ve<<0,Ne+=(qe^ge)+Be[6]+76029189,Ne=(Ne<<23|Ne>>>9)+ge<<0,Le=Ne^ge,se+=(Le^Ve)+Be[9]-640364487,se=(se<<4|se>>>28)+Ne<<0,Ve+=(Le^se)+Be[12]-421815835,Ve=(Ve<<11|Ve>>>21)+se<<0,qe=Ve^se,ge+=(qe^Ne)+Be[15]+530742520,ge=(ge<<16|ge>>>16)+Ve<<0,Ne+=(qe^ge)+Be[2]-995338651,Ne=(Ne<<23|Ne>>>9)+ge<<0,se+=(ge^(Ne|~Ve))+Be[0]-198630844,se=(se<<6|se>>>26)+Ne<<0,Ve+=(Ne^(se|~ge))+Be[7]+1126891415,Ve=(Ve<<10|Ve>>>22)+se<<0,ge+=(se^(Ve|~Ne))+Be[14]-1416354905,ge=(ge<<15|ge>>>17)+Ve<<0,Ne+=(Ve^(ge|~se))+Be[5]-57434055,Ne=(Ne<<21|Ne>>>11)+ge<<0,se+=(ge^(Ne|~Ve))+Be[12]+1700485571,se=(se<<6|se>>>26)+Ne<<0,Ve+=(Ne^(se|~ge))+Be[3]-1894986606,Ve=(Ve<<10|Ve>>>22)+se<<0,ge+=(se^(Ve|~Ne))+Be[10]-1051523,ge=(ge<<15|ge>>>17)+Ve<<0,Ne+=(Ve^(ge|~se))+Be[1]-2054922799,Ne=(Ne<<21|Ne>>>11)+ge<<0,se+=(ge^(Ne|~Ve))+Be[8]+1873313359,se=(se<<6|se>>>26)+Ne<<0,Ve+=(Ne^(se|~ge))+Be[15]-30611744,Ve=(Ve<<10|Ve>>>22)+se<<0,ge+=(se^(Ve|~Ne))+Be[6]-1560198380,ge=(ge<<15|ge>>>17)+Ve<<0,Ne+=(Ve^(ge|~se))+Be[13]+1309151649,Ne=(Ne<<21|Ne>>>11)+ge<<0,se+=(ge^(Ne|~Ve))+Be[4]-145523070,se=(se<<6|se>>>26)+Ne<<0,Ve+=(Ne^(se|~ge))+Be[11]-1120210379,Ve=(Ve<<10|Ve>>>22)+se<<0,ge+=(se^(Ve|~Ne))+Be[2]+718787259,ge=(ge<<15|ge>>>17)+Ve<<0,Ne+=(Ve^(ge|~se))+Be[9]-343485551,Ne=(Ne<<21|Ne>>>11)+ge<<0,this.first?(this.h0=se+1732584193<<0,this.h1=Ne-271733879<<0,this.h2=ge-1732584194<<0,this.h3=Ve+271733878<<0,this.first=!1):(this.h0=this.h0+se<<0,this.h1=this.h1+Ne<<0,this.h2=this.h2+ge<<0,this.h3=this.h3+Ve<<0)},ae.prototype.hex=function(){this.finalize();var se=this.h0,Ne=this.h1,ge=this.h2,Ve=this.h3;return S[se>>>4&15]+S[se&15]+S[se>>>12&15]+S[se>>>8&15]+S[se>>>20&15]+S[se>>>16&15]+S[se>>>28&15]+S[se>>>24&15]+S[Ne>>>4&15]+S[Ne&15]+S[Ne>>>12&15]+S[Ne>>>8&15]+S[Ne>>>20&15]+S[Ne>>>16&15]+S[Ne>>>28&15]+S[Ne>>>24&15]+S[ge>>>4&15]+S[ge&15]+S[ge>>>12&15]+S[ge>>>8&15]+S[ge>>>20&15]+S[ge>>>16&15]+S[ge>>>28&15]+S[ge>>>24&15]+S[Ve>>>4&15]+S[Ve&15]+S[Ve>>>12&15]+S[Ve>>>8&15]+S[Ve>>>20&15]+S[Ve>>>16&15]+S[Ve>>>28&15]+S[Ve>>>24&15]},ae.prototype.toString=ae.prototype.hex,ae.prototype.digest=function(){this.finalize();var se=this.h0,Ne=this.h1,ge=this.h2,Ve=this.h3;return[se&255,se>>>8&255,se>>>16&255,se>>>24&255,Ne&255,Ne>>>8&255,Ne>>>16&255,Ne>>>24&255,ge&255,ge>>>8&255,ge>>>16&255,ge>>>24&255,Ve&255,Ve>>>8&255,Ve>>>16&255,Ve>>>24&255]},ae.prototype.array=ae.prototype.digest,ae.prototype.arrayBuffer=function(){this.finalize();var se=new ArrayBuffer(16),Ne=new Uint32Array(se);return Ne[0]=this.h0,Ne[1]=this.h1,Ne[2]=this.h2,Ne[3]=this.h3,se},ae.prototype.buffer=ae.prototype.arrayBuffer,ae.prototype.base64=function(){for(var se,Ne,ge,Ve="",Le=this.array(),qe=0;qe<15;)se=Le[qe++],Ne=Le[qe++],ge=Le[qe++],Ve+=E[se>>>2]+E[(se<<4|Ne>>>4)&63]+E[(Ne<<2|ge>>>6)&63]+E[ge&63];return se=Le[qe],Ve+=E[se>>>2]+E[se<<4&63]+"==",Ve};function je(se,Ne){var ge,Ve=z(se);if(se=Ve[0],Ve[1]){var Le=[],qe=se.length,Be=0,$e;for(ge=0;ge<qe;++ge)$e=se.charCodeAt(ge),$e<128?Le[Be++]=$e:$e<2048?(Le[Be++]=192|$e>>>6,Le[Be++]=128|$e&63):$e<55296||$e>=57344?(Le[Be++]=224|$e>>>12,Le[Be++]=128|$e>>>6&63,Le[Be++]=128|$e&63):($e=65536+(($e&1023)<<10|se.charCodeAt(++ge)&1023),Le[Be++]=240|$e>>>18,Le[Be++]=128|$e>>>12&63,Le[Be++]=128|$e>>>6&63,Le[Be++]=128|$e&63);se=Le}se.length>64&&(se=new ae(!0).update(se).array());var He=[],We=[];for(ge=0;ge<64;++ge){var Ue=se[ge]||0;He[ge]=92^Ue,We[ge]=54^Ue}ae.call(this,Ne),this.update(We),this.oKeyPad=He,this.inner=!0,this.sharedMemory=Ne}je.prototype=new ae,je.prototype.finalize=function(){if(ae.prototype.finalize.call(this),this.inner){this.inner=!1;var se=this.array();ae.call(this,this.sharedMemory),this.update(this.oKeyPad),this.update(se),ae.prototype.finalize.call(this)}};var Ae=j();Ae.md5=Ae,Ae.md5.hmac=ne(),g?t.exports=Ae:l.md5=Ae})()})(md5$2)),md5$2.exports}var md5Exports$1=requireMd5$1();const bodyKey="TheRequestBody";function getHash(t){return md5Exports$1.md5(t).substring(0,16)}function deduplicateApiFunctions(t){const e=new Map;return t.map(n=>{const o=n.declaration.name,l=e.get(o)||0;let d=o;return l>0&&(d=`${o}_${l}`),e.set(o,l+1),{...n,declaration:{...n.declaration,name:d}}})}async function fetchApiFunctions(){var t,e,n;try{const o=await fetch("https://api.randmar.io/swagger/V4/swagger.json");if(!o.ok)throw new Error("Failed to fetch Swagger spec");const l=await o.json(),d=[];for(const[f,g]of Object.entries(l.paths)){const b=["get","post","put","delete"];for(const S of b){const _=g[S];if(!_||_["x-allowed-for-chatbots"]!==!0)continue;const R=f.split("/").filter(Boolean);let C;R.length>0&&R[0].toLowerCase()==="v4"?C=R.length>1?R[1]:"api":C=R.length>0?R[0]:"api",C=C.replace(/[{}]/g,"");const E=getHash(f),A=`${S}-${C.toLowerCase()}-${E}`,I={},M=[];(t=_.parameters)==null||t.forEach(te=>{I[te.name]={type:te.schema.type,description:te.description||`The ${te.name} parameter`},te.required&&M.push(te.name)});const V=((e=_.parameters)==null?void 0:e.filter(te=>te.in==="path").map(te=>te.name))||[];if((S==="post"||S==="put")&&_.requestBody){const te=(n=_.requestBody.content["application/json"])==null?void 0:n.schema;if(te&&"$ref"in te&&te.$ref.startsWith("#/components/schemas/")){const ne=te.$ref.substring(21);I[bodyKey]={type:Type.STRING,description:`${_.requestBody.description||"Request body content"}. Must be a JSON string with these properties: ${JSON.stringify(l.components.schemas[ne].properties)}`}}else I[bodyKey]={type:Type.STRING,description:_.requestBody.description||"Request body content"};M.push(bodyKey)}const O={name:A,description:_.description?`${_.summary}
1057
1057
 
1058
- ${_.description}`:_.summary||`${S.toUpperCase()} ${R[R.length-1]}`,parameters:{type:Type.OBJECT,properties:I,required:M}},z=async te=>{var ae;let ne=`https://api.randmar.io${f}`;try{V.forEach(Ve=>{const Le=`{${Ve}}`,qe=Ve;ne=ne.replace(Le,te[qe])});const je=localStorage.getItem("access_token"),Ae={method:S.toUpperCase(),headers:{Authorization:je?`Bearer ${je}`:"","Content-Type":"application/json"}},se=[];if((((ae=_.parameters)==null?void 0:ae.filter(Ve=>Ve.in==="query"))||[]).forEach(Ve=>{const Le=Ve.name,qe=te[Le];qe!=null&&se.push(`${Ve.name}=${encodeURIComponent(qe)}`)}),se.length>0&&(ne+=`?${se.join("&")}`),S==="post"||S==="put"){const Le=te[bodyKey];Le&&(Ae.body=Le)}const ge=await fetch(ne,Ae);if(!ge.ok){const Ve=await ge.text();throw console.error(`[API Function] Error response: ${Ve}`),new Error(`Error ${ge.status}: ${Ve}`)}return await ge.text()}catch(je){return console.error(`Error in ${A}:`,je),`I'm sorry, I couldn't retrieve the requested information. Error: ${je instanceof Error?je.message:"Unknown error"}`}},Q=_.tags.at(0),j=(S=="get"?"Fetching data":"Updating data")+` using the Randmar ${Q} API.`,F=`${S} ${f}`;d.push({declaration:O,handler:z,prettyName:j,details:F})}}return deduplicateApiFunctions(d)}catch(o){return console.error("Error fetching API functions:",o),[]}}function promisifyRequest(t){return new Promise((e,n)=>{t.oncomplete=t.onsuccess=()=>e(t.result),t.onabort=t.onerror=()=>n(t.error)})}function createStore(t,e){let n;const o=()=>{if(n)return n;const l=indexedDB.open(t);return l.onupgradeneeded=()=>l.result.createObjectStore(e),n=promisifyRequest(l),n.then(d=>{d.onclose=()=>n=void 0},()=>{}),n};return(l,d)=>o().then(f=>d(f.transaction(e,l).objectStore(e)))}let defaultGetStoreFunc;function defaultGetStore(){return defaultGetStoreFunc||(defaultGetStoreFunc=createStore("keyval-store","keyval")),defaultGetStoreFunc}function get$1(t,e=defaultGetStore()){return e("readonly",n=>promisifyRequest(n.get(t)))}function set$1(t,e,n=defaultGetStore()){return n("readwrite",o=>(o.put(e,t),promisifyRequest(o.transaction)))}const useCachedHeavyApiCalls=(t,e)=>{const[n,o]=React.useState({topProducts:[],updatedAtSecondsSinceEpoch:0}),[l,d]=React.useState(!1),f=12,[g]=useLazyGetV4PartnerByRouteApplicationIdProductsQuery();return React.useEffect(()=>{if(!e){o({topProducts:[],updatedAtSecondsSinceEpoch:0}),d(!1);return}const b=`heavy_api_cache_v5_${t}`,S=f*60*60,_=async()=>{d(!0);try{const C=await g({routeApplicationId:t});if(C.data){const E={topProducts:C.data.filter(A=>(A.OverallPercentileRank??0)>=95).sort((A,I)=>(A.RandmarSKU??"").localeCompare(I.RandmarSKU??"")),updatedAtSecondsSinceEpoch:Math.floor(Date.now()/1e3)};await set$1(b,E),o(E)}}catch(C){console.error("Failed to fetch products:",C)}finally{d(!1)}},R=async()=>{const C=await get$1(b);C?Math.floor(Date.now()/1e3)-C.updatedAtSecondsSinceEpoch>S?await _():(o(C),d(!1)):await _()};d(!0),R().catch(C=>{console.error("Failed to process cache, fetching new data",C),_()})},[t,e,g]),{...n,isLoading:l}};function useAIAssistant({userId:t,config:e}){const[n,o]=React.useState(""),[l,d]=React.useState([]),[f,g]=React.useState([]),[b,S]=React.useState([]),[_,R]=React.useState(!1),[C,E]=React.useState([]),[A,I]=React.useState([]),[M]=useLazyGetV4PartnerByApplicationIdAccountQuery(),[V]=usePostV4PartnerByApplicationIdGenerationRandmarAssistantMutation(),[O]=usePostV4PartnerByApplicationIdGenerationUploadMutation(),{topProducts:z,isLoading:Q}=useCachedHeavyApiCalls(t,e.assistantCachedPreloading);React.useEffect(()=>{const se=async()=>{R(!0);try{const Ne=await fetchApiFunctions(),ge={declaration:{name:"set_on_behalf_id",description:"Call this function when the user wants to act on behalf of another one. It will return to you important flags such as: is user specified by the user ID a reseller, manufacturer or an agency?",parameters:{type:Type.OBJECT,properties:{user_id:{type:Type.STRING,description:"The user ID to use going forward."}},required:["user_id"]}},prettyName:"Fetching account details",details:"GET Partner Account",handler:async Ve=>{const qe=await M({applicationId:Ve.user_id});return JSON.stringify(qe.data)}};E([...Ne,ge])}catch(Ne){console.error("Error loading API functions:",Ne)}R(!1)};C.length===0&&!_&&se()},[]),React.useEffect(()=>{e.assistantCachedPreloading&&(Q?g(se=>[...se,"Preloading Best-Sellers..."]):z.length>0&&g(se=>[...se,"Best-Sellers preloaded."]))},[Q,z.length,e.assistantCachedPreloading]),React.useEffect(()=>{if(n||b.length===0)return;o("Handling message...");const[se,Ne]=b[0];S(ge=>ge.slice(1)),te(se,Ne)},[n,b]),React.useEffect(()=>{Ae()},[e.assistantThinkHarder,e.assistantCachedPreloading,e.assistantDynamicPreloading]);const j=async se=>{const Ne=C.find(ge=>ge.declaration.name===se.name);if(!Ne){const ge=`Function ${se.name} not found`;return console.error(ge),JSON.stringify({error:ge})}try{g(Ve=>[...Ve,[Ne.prettyName,`${Ne.details} where ${JSON.stringify(se.args,null,2)}`]]);const ge=await Ne.handler(se.args);return typeof ge=="string"?ge:JSON.stringify(ge)}catch(ge){const Ve=`${se.name} failed.`;return console.error(Ve,ge),JSON.stringify({error:Ve,details:ge instanceof Error?ge.message:String(ge)})}},F=async(se,Ne=5)=>{var ge,Ve,Le;if(Ne===0){ae({content:"I've reached my action limit for this request. Please let me know if you'd like me to continue.",timestamp:new Date}),o("");return}try{o("Thinking...");const Be=await V({applicationId:t,body:se}).unwrap(),$e=[...se,Be];I($e);const He=(Ve=(ge=Be.Parts)==null?void 0:ge.find(Ue=>Ue.Text))==null?void 0:Ve.Text;He&&ae({content:He,timestamp:new Date});const We=((Le=Be.Parts)==null?void 0:Le.map(Ue=>Ue.FunctionCall).filter(Boolean))??[];if(We.length>0){o("Using Randmar API...");const Ue=[];for(const Ke of We)if(Ke!=null&&Ke.Name){const tt=await j({name:Ke.Name,args:Ke.Args??{}});Ue.push({FunctionResponse:{Name:Ke.Name,Content:tt}})}if(Ue.length>0){const Ke={Role:"user",Parts:Ue},tt=[...$e,Ke];I(tt),o("Composing response..."),await F(tt,Ne-1);return}}o("")}catch(qe){console.error("Error during AI interaction:",qe),ae({content:"I'm sorry, I encountered an error. Please try again.",timestamp:new Date}),o("")}},te=async(se,Ne)=>{try{const ge=[{Text:se.trim()}];if(Ne){o("Receiving attached file...");let qe=new Blob([await Ne.arrayBuffer()],{type:Ne.type});const Be=await O({applicationId:t,body:{file:qe}}).unwrap();ge.push({FileData:{FileUri:Be,MimeType:Ne.type}})}const Ve={Role:"user",Parts:ge},Le=[...A,Ve];I(Le),await F(Le)}catch(ge){console.error("Error processing user request:",ge),ae({content:"I'm sorry, there was an issue with your request, especially if a file was attached. Please try again.",timestamp:new Date}),o("")}},ne=(se,Ne)=>{if(C.length>0&&!Q){if(A.length===0){let Ve=[];if(e.assistantDynamicPreloading&&Ve.push(`Fetch the initial (called onload in your instructions) information for me (app ID ${t}) and provide a short summary. Tell me to hold on until done. No need to suggest follow-up actions yet, I'll ask you a question right after you're done loading.`),e.assistantCachedPreloading&&z.length>0){const Le=z.map(qe=>({RandmarSKU:qe.RandmarSKU,RandmarTitle:qe.RandmarTitle,CategoryCode:qe.Category,UPC:qe.UPC,ManufName:qe.ManufacturerName,CategoryName:qe.ProductType,Desc:qe.BodyHTML,MAP:qe.MAP,MSRP:qe.MSRP,ManufID:qe.ManufacturerId,MPN:qe.MPN}));Ve.push(`Here are the current best-selling products: ${JSON.stringify(Le)}.`)}Ve.length>0&&I([{Role:"user",Parts:[{Text:Ve.join(`
1058
+ ${_.description}`:_.summary||`${S.toUpperCase()} ${R[R.length-1]}`,parameters:{type:Type.OBJECT,properties:I,required:M}},z=async te=>{var ae;let ne=`https://api.randmar.io${f}`;try{V.forEach(Ve=>{const Le=`{${Ve}}`,qe=Ve;ne=ne.replace(Le,te[qe])});const je=localStorage.getItem("access_token"),Ae={method:S.toUpperCase(),headers:{Authorization:je?`Bearer ${je}`:"","Content-Type":"application/json"}},se=[];if((((ae=_.parameters)==null?void 0:ae.filter(Ve=>Ve.in==="query"))||[]).forEach(Ve=>{const Le=Ve.name,qe=te[Le];qe!=null&&se.push(`${Ve.name}=${encodeURIComponent(qe)}`)}),se.length>0&&(ne+=`?${se.join("&")}`),S==="post"||S==="put"){const Le=te[bodyKey];Le&&(Ae.body=Le)}const ge=await fetch(ne,Ae);if(!ge.ok){const Ve=await ge.text();throw console.error(`[API Function] Error response: ${Ve}`),new Error(`Error ${ge.status}: ${Ve}`)}return await ge.text()}catch(je){return console.error(`Error in ${A}:`,je),`I'm sorry, I couldn't retrieve the requested information. Error: ${je instanceof Error?je.message:"Unknown error"}`}},Q=_.tags.at(0),j=(S=="get"?"Fetching data":"Updating data")+` using the Randmar ${Q} API.`,F=`${S} ${f}`;d.push({declaration:O,handler:z,prettyName:j,details:F})}}return deduplicateApiFunctions(d)}catch(o){return console.error("Error fetching API functions:",o),[]}}function promisifyRequest(t){return new Promise((e,n)=>{t.oncomplete=t.onsuccess=()=>e(t.result),t.onabort=t.onerror=()=>n(t.error)})}function createStore(t,e){let n;const o=()=>{if(n)return n;const l=indexedDB.open(t);return l.onupgradeneeded=()=>l.result.createObjectStore(e),n=promisifyRequest(l),n.then(d=>{d.onclose=()=>n=void 0},()=>{}),n};return(l,d)=>o().then(f=>d(f.transaction(e,l).objectStore(e)))}let defaultGetStoreFunc;function defaultGetStore(){return defaultGetStoreFunc||(defaultGetStoreFunc=createStore("keyval-store","keyval")),defaultGetStoreFunc}function get$1(t,e=defaultGetStore()){return e("readonly",n=>promisifyRequest(n.get(t)))}function set$1(t,e,n=defaultGetStore()){return n("readwrite",o=>(o.put(e,t),promisifyRequest(o.transaction)))}const useCachedHeavyApiCalls=(t,e)=>{const[n,o]=React.useState({topProducts:[],updatedAtSecondsSinceEpoch:0}),[l,d]=React.useState(!1),f=12,[g]=useLazyGetV4PartnerByRouteApplicationIdProductsQuery();return React.useEffect(()=>{if(!e){o({topProducts:[],updatedAtSecondsSinceEpoch:0}),d(!1);return}const b=`heavy_api_cache_v5_${t}`,S=f*60*60,_=async()=>{d(!0);try{const C=await g({routeApplicationId:t});if(C.data){const E={topProducts:C.data.filter(A=>(A.OverallPercentileRank??0)>=95).sort((A,I)=>(A.RandmarSKU??"").localeCompare(I.RandmarSKU??"")),updatedAtSecondsSinceEpoch:Math.floor(Date.now()/1e3)};await set$1(b,E),o(E)}}catch(C){console.error("Failed to fetch products:",C)}finally{d(!1)}},R=async()=>{const C=await get$1(b);C?Math.floor(Date.now()/1e3)-C.updatedAtSecondsSinceEpoch>S?await _():(o(C),d(!1)):await _()};d(!0),R().catch(C=>{console.error("Failed to process cache, fetching new data",C),_()})},[t,e,g]),{...n,isLoading:l}};function useAIAssistant({userId:t,config:e}){const[n,o]=React.useState(""),[l,d]=React.useState([]),[f,g]=React.useState([]),[b,S]=React.useState([]),[_,R]=React.useState(!1),[C,E]=React.useState([]),[A,I]=React.useState([]),[M]=useLazyGetV4PartnerByApplicationIdAccountQuery(),[V]=usePostV4PartnerByApplicationIdGenerationRandmarAssistantMutation(),[O]=usePostV4PartnerByApplicationIdGenerationUploadMutation(),{topProducts:z,isLoading:Q}=useCachedHeavyApiCalls(t,e.assistantCachedPreloading);React.useEffect(()=>{const se=async()=>{R(!0);try{const Ne=await fetchApiFunctions(),ge={declaration:{name:"set_on_behalf_id",description:"Call this function when the user wants to act on behalf of another one. It will return to you important flags such as: is user specified by the user ID a reseller, manufacturer or an agency?",parameters:{type:Type.OBJECT,properties:{user_id:{type:Type.STRING,description:"The user ID to use going forward."}},required:["user_id"]}},prettyName:"Fetching account details",details:"GET Partner Account",handler:async Ve=>{const qe=await M({applicationId:Ve.user_id});return JSON.stringify(qe.data)}};E([...Ne,ge])}catch(Ne){console.error("Error loading API functions:",Ne)}R(!1)};C.length===0&&!_&&se()},[]),React.useEffect(()=>{e.assistantCachedPreloading&&(Q?g(se=>[...se,"Preloading Best-Sellers..."]):z.length>0&&g(se=>[...se,"Best-Sellers preloaded."]))},[Q,z.length,e.assistantCachedPreloading]),React.useEffect(()=>{if(n||b.length===0)return;o("Handling message...");const[se,Ne]=b[0];S(ge=>ge.slice(1)),te(se,Ne)},[n,b]),React.useEffect(()=>{Ae()},[e.assistantThinkHarder,e.assistantCachedPreloading,e.assistantDynamicPreloading]);const j=async se=>{const Ne=C.find(ge=>ge.declaration.name===se.name);if(!Ne){const ge=`Function ${se.name} not found`;return console.error(ge),JSON.stringify({error:ge})}try{g(Ve=>[...Ve,[Ne.prettyName,`${Ne.details} where ${JSON.stringify(se.args,null,2)}`]]);const ge=await Ne.handler(se.args);return typeof ge=="string"?ge:JSON.stringify(ge)}catch(ge){const Ve=`${se.name} failed.`;return console.error(Ve,ge),JSON.stringify({error:Ve,details:ge instanceof Error?ge.message:String(ge)})}},F=async(se,Ne=10)=>{var ge,Ve,Le;if(Ne===0){ae({content:"I've reached my action limit for this request. Please let me know if you'd like me to continue.",timestamp:new Date}),o("");return}try{o("Thinking...");const Be=await V({applicationId:t,body:se}).unwrap(),$e=[...se,Be];I($e);const He=(Ve=(ge=Be.Parts)==null?void 0:ge.find(Ue=>Ue.Text))==null?void 0:Ve.Text;He&&ae({content:He,timestamp:new Date});const We=((Le=Be.Parts)==null?void 0:Le.map(Ue=>Ue.FunctionCall).filter(Boolean))??[];if(We.length>0){o("Using Randmar API...");const Ue=[];for(const Ke of We)if(Ke!=null&&Ke.Name){const tt=await j({name:Ke.Name,args:Ke.Args??{}});Ue.push({FunctionResponse:{Name:Ke.Name,Content:tt}})}if(Ue.length>0){const Ke={Role:"user",Parts:Ue},tt=[...$e,Ke];I(tt),o("Composing response..."),await F(tt,Ne-1);return}}o("")}catch(qe){console.error("Error during AI interaction:",qe),ae({content:"I'm sorry, I encountered an error. Please try again.",timestamp:new Date}),o("")}},te=async(se,Ne)=>{try{const ge=[{Text:se.trim()}];if(Ne){o("Receiving attached file...");let qe=new Blob([await Ne.arrayBuffer()],{type:Ne.type});const Be=await O({applicationId:t,body:{file:qe}}).unwrap();ge.push({FileData:{FileUri:Be,MimeType:Ne.type}})}const Ve={Role:"user",Parts:ge},Le=[...A,Ve];I(Le),await F(Le)}catch(ge){console.error("Error processing user request:",ge),ae({content:"I'm sorry, there was an issue with your request, especially if a file was attached. Please try again.",timestamp:new Date}),o("")}},ne=(se,Ne)=>{if(C.length>0&&!Q){if(A.length===0){let Ve=[];if(e.assistantDynamicPreloading&&Ve.push(`Fetch the initial (called onload in your instructions) information for me (app ID ${t}) and provide a short summary. Tell me to hold on until done. No need to suggest follow-up actions yet, I'll ask you a question right after you're done loading.`),e.assistantCachedPreloading&&z.length>0){const Le=z.map(qe=>({RandmarSKU:qe.RandmarSKU,RandmarTitle:qe.RandmarTitle,CategoryCode:qe.Category,UPC:qe.UPC,ManufName:qe.ManufacturerName,CategoryName:qe.ProductType,Desc:qe.BodyHTML,MAP:qe.MAP,MSRP:qe.MSRP,ManufID:qe.ManufacturerId,MPN:qe.MPN}));Ve.push(`Here are the current best-selling products: ${JSON.stringify(Le)}.`)}Ve.length>0&&I([{Role:"user",Parts:[{Text:Ve.join(`
1059
1059
 
1060
1060
  `)}]}])}S(Ve=>[...Ve,[se,Ne]])}},ae=se=>d(Ne=>[...Ne,se]),je=()=>d([]),Ae=()=>{I([]),S([]),d([]),o("")};return{handleSubmitToBot:ne,botMessages:l,clearBotMessages:je,botReady:C.length>0&&!Q,botStatus:n,debugMessages:f,reset:Ae}}class HttpError extends Error{constructor(e,n){const o=new.target.prototype;super(`${e}: Status code '${n}'`),this.statusCode=n,this.__proto__=o}}class TimeoutError extends Error{constructor(e="A timeout occurred."){const n=new.target.prototype;super(e),this.__proto__=n}}class AbortError extends Error{constructor(e="An abort occurred."){const n=new.target.prototype;super(e),this.__proto__=n}}class UnsupportedTransportError extends Error{constructor(e,n){const o=new.target.prototype;super(e),this.transport=n,this.errorType="UnsupportedTransportError",this.__proto__=o}}class DisabledTransportError extends Error{constructor(e,n){const o=new.target.prototype;super(e),this.transport=n,this.errorType="DisabledTransportError",this.__proto__=o}}class FailedToStartTransportError extends Error{constructor(e,n){const o=new.target.prototype;super(e),this.transport=n,this.errorType="FailedToStartTransportError",this.__proto__=o}}class FailedToNegotiateWithServerError extends Error{constructor(e){const n=new.target.prototype;super(e),this.errorType="FailedToNegotiateWithServerError",this.__proto__=n}}class AggregateErrors extends Error{constructor(e,n){const o=new.target.prototype;super(e),this.innerErrors=n,this.__proto__=o}}class HttpResponse{constructor(e,n,o){this.statusCode=e,this.statusText=n,this.content=o}}class HttpClient{get(e,n){return this.send({...n,method:"GET",url:e})}post(e,n){return this.send({...n,method:"POST",url:e})}delete(e,n){return this.send({...n,method:"DELETE",url:e})}getCookieString(e){return""}}var LogLevel;(function(t){t[t.Trace=0]="Trace",t[t.Debug=1]="Debug",t[t.Information=2]="Information",t[t.Warning=3]="Warning",t[t.Error=4]="Error",t[t.Critical=5]="Critical",t[t.None=6]="None"})(LogLevel||(LogLevel={}));class NullLogger{constructor(){}log(e,n){}}NullLogger.instance=new NullLogger;const VERSION="8.0.17";class Arg{static isRequired(e,n){if(e==null)throw new Error(`The '${n}' argument is required.`)}static isNotEmpty(e,n){if(!e||e.match(/^\s*$/))throw new Error(`The '${n}' argument should not be empty.`)}static isIn(e,n,o){if(!(e in n))throw new Error(`Unknown ${o} value: ${e}.`)}}class Platform{static get isBrowser(){return!Platform.isNode&&typeof window=="object"&&typeof window.document=="object"}static get isWebWorker(){return!Platform.isNode&&typeof self=="object"&&"importScripts"in self}static get isReactNative(){return!Platform.isNode&&typeof window=="object"&&typeof window.document>"u"}static get isNode(){return typeof process<"u"&&process.release&&process.release.name==="node"}}function getDataDetail(t,e){let n="";return isArrayBuffer(t)?(n=`Binary data of length ${t.byteLength}`,e&&(n+=`. Content: '${formatArrayBuffer(t)}'`)):typeof t=="string"&&(n=`String data of length ${t.length}`,e&&(n+=`. Content: '${t}'`)),n}function formatArrayBuffer(t){const e=new Uint8Array(t);let n="";return e.forEach(o=>{const l=o<16?"0":"";n+=`0x${l}${o.toString(16)} `}),n.substr(0,n.length-1)}function isArrayBuffer(t){return t&&typeof ArrayBuffer<"u"&&(t instanceof ArrayBuffer||t.constructor&&t.constructor.name==="ArrayBuffer")}async function sendMessage(t,e,n,o,l,d){const f={},[g,b]=getUserAgentHeader();f[g]=b,t.log(LogLevel.Trace,`(${e} transport) sending data. ${getDataDetail(l,d.logMessageContent)}.`);const S=isArrayBuffer(l)?"arraybuffer":"text",_=await n.post(o,{content:l,headers:{...f,...d.headers},responseType:S,timeout:d.timeout,withCredentials:d.withCredentials});t.log(LogLevel.Trace,`(${e} transport) request complete. Response status: ${_.statusCode}.`)}function createLogger(t){return t===void 0?new ConsoleLogger(LogLevel.Information):t===null?NullLogger.instance:t.log!==void 0?t:new ConsoleLogger(t)}class SubjectSubscription{constructor(e,n){this._subject=e,this._observer=n}dispose(){const e=this._subject.observers.indexOf(this._observer);e>-1&&this._subject.observers.splice(e,1),this._subject.observers.length===0&&this._subject.cancelCallback&&this._subject.cancelCallback().catch(n=>{})}}class ConsoleLogger{constructor(e){this._minLevel=e,this.out=console}log(e,n){if(e>=this._minLevel){const o=`[${new Date().toISOString()}] ${LogLevel[e]}: ${n}`;switch(e){case LogLevel.Critical:case LogLevel.Error:this.out.error(o);break;case LogLevel.Warning:this.out.warn(o);break;case LogLevel.Information:this.out.info(o);break;default:this.out.log(o);break}}}}function getUserAgentHeader(){let t="X-SignalR-User-Agent";return Platform.isNode&&(t="User-Agent"),[t,constructUserAgent(VERSION,getOsName(),getRuntime(),getRuntimeVersion())]}function constructUserAgent(t,e,n,o){let l="Microsoft SignalR/";const d=t.split(".");return l+=`${d[0]}.${d[1]}`,l+=` (${t}; `,e&&e!==""?l+=`${e}; `:l+="Unknown OS; ",l+=`${n}`,o?l+=`; ${o}`:l+="; Unknown Runtime Version",l+=")",l}function getOsName(){if(Platform.isNode)switch(process.platform){case"win32":return"Windows NT";case"darwin":return"macOS";case"linux":return"Linux";default:return process.platform}else return""}function getRuntimeVersion(){if(Platform.isNode)return process.versions.node}function getRuntime(){return Platform.isNode?"NodeJS":"Browser"}function getErrorString(t){return t.stack?t.stack:t.message?t.message:`${t}`}function getGlobalThis(){if(typeof globalThis<"u")return globalThis;if(typeof self<"u")return self;if(typeof window<"u")return window;if(typeof global<"u")return global;throw new Error("could not find global")}class FetchHttpClient extends HttpClient{constructor(e){if(super(),this._logger=e,typeof fetch>"u"||Platform.isNode){const n=typeof __webpack_require__=="function"?__non_webpack_require__:require;this._jar=new(n("tough-cookie")).CookieJar,typeof fetch>"u"?this._fetchType=n("node-fetch"):this._fetchType=fetch,this._fetchType=n("fetch-cookie")(this._fetchType,this._jar)}else this._fetchType=fetch.bind(getGlobalThis());if(typeof AbortController>"u"){const n=typeof __webpack_require__=="function"?__non_webpack_require__:require;this._abortControllerType=n("abort-controller")}else this._abortControllerType=AbortController}async send(e){if(e.abortSignal&&e.abortSignal.aborted)throw new AbortError;if(!e.method)throw new Error("No method defined.");if(!e.url)throw new Error("No url defined.");const n=new this._abortControllerType;let o;e.abortSignal&&(e.abortSignal.onabort=()=>{n.abort(),o=new AbortError});let l=null;if(e.timeout){const b=e.timeout;l=setTimeout(()=>{n.abort(),this._logger.log(LogLevel.Warning,"Timeout from HTTP request."),o=new TimeoutError},b)}e.content===""&&(e.content=void 0),e.content&&(e.headers=e.headers||{},isArrayBuffer(e.content)?e.headers["Content-Type"]="application/octet-stream":e.headers["Content-Type"]="text/plain;charset=UTF-8");let d;try{d=await this._fetchType(e.url,{body:e.content,cache:"no-cache",credentials:e.withCredentials===!0?"include":"same-origin",headers:{"X-Requested-With":"XMLHttpRequest",...e.headers},method:e.method,mode:"cors",redirect:"follow",signal:n.signal})}catch(b){throw o||(this._logger.log(LogLevel.Warning,`Error from HTTP request. ${b}.`),b)}finally{l&&clearTimeout(l),e.abortSignal&&(e.abortSignal.onabort=null)}if(!d.ok){const b=await deserializeContent(d,"text");throw new HttpError(b||d.statusText,d.status)}const g=await deserializeContent(d,e.responseType);return new HttpResponse(d.status,d.statusText,g)}getCookieString(e){let n="";return Platform.isNode&&this._jar&&this._jar.getCookies(e,(o,l)=>n=l.join("; ")),n}}function deserializeContent(t,e){let n;switch(e){case"arraybuffer":n=t.arrayBuffer();break;case"text":n=t.text();break;case"blob":case"document":case"json":throw new Error(`${e} is not supported.`);default:n=t.text();break}return n}class XhrHttpClient extends HttpClient{constructor(e){super(),this._logger=e}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new AbortError):e.method?e.url?new Promise((n,o)=>{const l=new XMLHttpRequest;l.open(e.method,e.url,!0),l.withCredentials=e.withCredentials===void 0?!0:e.withCredentials,l.setRequestHeader("X-Requested-With","XMLHttpRequest"),e.content===""&&(e.content=void 0),e.content&&(isArrayBuffer(e.content)?l.setRequestHeader("Content-Type","application/octet-stream"):l.setRequestHeader("Content-Type","text/plain;charset=UTF-8"));const d=e.headers;d&&Object.keys(d).forEach(f=>{l.setRequestHeader(f,d[f])}),e.responseType&&(l.responseType=e.responseType),e.abortSignal&&(e.abortSignal.onabort=()=>{l.abort(),o(new AbortError)}),e.timeout&&(l.timeout=e.timeout),l.onload=()=>{e.abortSignal&&(e.abortSignal.onabort=null),l.status>=200&&l.status<300?n(new HttpResponse(l.status,l.statusText,l.response||l.responseText)):o(new HttpError(l.response||l.responseText||l.statusText,l.status))},l.onerror=()=>{this._logger.log(LogLevel.Warning,`Error from HTTP request. ${l.status}: ${l.statusText}.`),o(new HttpError(l.statusText,l.status))},l.ontimeout=()=>{this._logger.log(LogLevel.Warning,"Timeout from HTTP request."),o(new TimeoutError)},l.send(e.content)}):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}}class DefaultHttpClient extends HttpClient{constructor(e){if(super(),typeof fetch<"u"||Platform.isNode)this._httpClient=new FetchHttpClient(e);else if(typeof XMLHttpRequest<"u")this._httpClient=new XhrHttpClient(e);else throw new Error("No usable HttpClient found.")}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new AbortError):e.method?e.url?this._httpClient.send(e):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}getCookieString(e){return this._httpClient.getCookieString(e)}}class TextMessageFormat{static write(e){return`${e}${TextMessageFormat.RecordSeparator}`}static parse(e){if(e[e.length-1]!==TextMessageFormat.RecordSeparator)throw new Error("Message is incomplete.");const n=e.split(TextMessageFormat.RecordSeparator);return n.pop(),n}}TextMessageFormat.RecordSeparatorCode=30,TextMessageFormat.RecordSeparator=String.fromCharCode(TextMessageFormat.RecordSeparatorCode);class HandshakeProtocol{writeHandshakeRequest(e){return TextMessageFormat.write(JSON.stringify(e))}parseHandshakeResponse(e){let n,o;if(isArrayBuffer(e)){const g=new Uint8Array(e),b=g.indexOf(TextMessageFormat.RecordSeparatorCode);if(b===-1)throw new Error("Message is incomplete.");const S=b+1;n=String.fromCharCode.apply(null,Array.prototype.slice.call(g.slice(0,S))),o=g.byteLength>S?g.slice(S).buffer:null}else{const g=e,b=g.indexOf(TextMessageFormat.RecordSeparator);if(b===-1)throw new Error("Message is incomplete.");const S=b+1;n=g.substring(0,S),o=g.length>S?g.substring(S):null}const l=TextMessageFormat.parse(n),d=JSON.parse(l[0]);if(d.type)throw new Error("Expected a handshake response from the server.");return[o,d]}}var MessageType;(function(t){t[t.Invocation=1]="Invocation",t[t.StreamItem=2]="StreamItem",t[t.Completion=3]="Completion",t[t.StreamInvocation=4]="StreamInvocation",t[t.CancelInvocation=5]="CancelInvocation",t[t.Ping=6]="Ping",t[t.Close=7]="Close",t[t.Ack=8]="Ack",t[t.Sequence=9]="Sequence"})(MessageType||(MessageType={}));class Subject{constructor(){this.observers=[]}next(e){for(const n of this.observers)n.next(e)}error(e){for(const n of this.observers)n.error&&n.error(e)}complete(){for(const e of this.observers)e.complete&&e.complete()}subscribe(e){return this.observers.push(e),new SubjectSubscription(this,e)}}class MessageBuffer{constructor(e,n,o){this._bufferSize=1e5,this._messages=[],this._totalMessageCount=0,this._waitForSequenceMessage=!1,this._nextReceivingSequenceId=1,this._latestReceivedSequenceId=0,this._bufferedByteCount=0,this._reconnectInProgress=!1,this._protocol=e,this._connection=n,this._bufferSize=o}async _send(e){const n=this._protocol.writeMessage(e);let o=Promise.resolve();if(this._isInvocationMessage(e)){this._totalMessageCount++;let l=()=>{},d=()=>{};isArrayBuffer(n)?this._bufferedByteCount+=n.byteLength:this._bufferedByteCount+=n.length,this._bufferedByteCount>=this._bufferSize&&(o=new Promise((f,g)=>{l=f,d=g})),this._messages.push(new BufferedItem(n,this._totalMessageCount,l,d))}try{this._reconnectInProgress||await this._connection.send(n)}catch{this._disconnected()}await o}_ack(e){let n=-1;for(let o=0;o<this._messages.length;o++){const l=this._messages[o];if(l._id<=e.sequenceId)n=o,isArrayBuffer(l._message)?this._bufferedByteCount-=l._message.byteLength:this._bufferedByteCount-=l._message.length,l._resolver();else if(this._bufferedByteCount<this._bufferSize)l._resolver();else break}n!==-1&&(this._messages=this._messages.slice(n+1))}_shouldProcessMessage(e){if(this._waitForSequenceMessage)return e.type!==MessageType.Sequence?!1:(this._waitForSequenceMessage=!1,!0);if(!this._isInvocationMessage(e))return!0;const n=this._nextReceivingSequenceId;return this._nextReceivingSequenceId++,n<=this._latestReceivedSequenceId?(n===this._latestReceivedSequenceId&&this._ackTimer(),!1):(this._latestReceivedSequenceId=n,this._ackTimer(),!0)}_resetSequence(e){if(e.sequenceId>this._nextReceivingSequenceId){this._connection.stop(new Error("Sequence ID greater than amount of messages we've received."));return}this._nextReceivingSequenceId=e.sequenceId}_disconnected(){this._reconnectInProgress=!0,this._waitForSequenceMessage=!0}async _resend(){const e=this._messages.length!==0?this._messages[0]._id:this._totalMessageCount+1;await this._connection.send(this._protocol.writeMessage({type:MessageType.Sequence,sequenceId:e}));const n=this._messages;for(const o of n)await this._connection.send(o._message);this._reconnectInProgress=!1}_dispose(e){e??(e=new Error("Unable to reconnect to server."));for(const n of this._messages)n._rejector(e)}_isInvocationMessage(e){switch(e.type){case MessageType.Invocation:case MessageType.StreamItem:case MessageType.Completion:case MessageType.StreamInvocation:case MessageType.CancelInvocation:return!0;case MessageType.Close:case MessageType.Sequence:case MessageType.Ping:case MessageType.Ack:return!1}}_ackTimer(){this._ackTimerHandle===void 0&&(this._ackTimerHandle=setTimeout(async()=>{try{this._reconnectInProgress||await this._connection.send(this._protocol.writeMessage({type:MessageType.Ack,sequenceId:this._latestReceivedSequenceId}))}catch{}clearTimeout(this._ackTimerHandle),this._ackTimerHandle=void 0},1e3))}}class BufferedItem{constructor(e,n,o,l){this._message=e,this._id=n,this._resolver=o,this._rejector=l}}const DEFAULT_TIMEOUT_IN_MS=30*1e3,DEFAULT_PING_INTERVAL_IN_MS=15*1e3,DEFAULT_STATEFUL_RECONNECT_BUFFER_SIZE=1e5;var HubConnectionState;(function(t){t.Disconnected="Disconnected",t.Connecting="Connecting",t.Connected="Connected",t.Disconnecting="Disconnecting",t.Reconnecting="Reconnecting"})(HubConnectionState||(HubConnectionState={}));class HubConnection{static create(e,n,o,l,d,f,g){return new HubConnection(e,n,o,l,d,f,g)}constructor(e,n,o,l,d,f,g){this._nextKeepAlive=0,this._freezeEventListener=()=>{this._logger.log(LogLevel.Warning,"The page is being frozen, this will likely lead to the connection being closed and messages being lost. For more information see the docs at https://learn.microsoft.com/aspnet/core/signalr/javascript-client#bsleep")},Arg.isRequired(e,"connection"),Arg.isRequired(n,"logger"),Arg.isRequired(o,"protocol"),this.serverTimeoutInMilliseconds=d??DEFAULT_TIMEOUT_IN_MS,this.keepAliveIntervalInMilliseconds=f??DEFAULT_PING_INTERVAL_IN_MS,this._statefulReconnectBufferSize=g??DEFAULT_STATEFUL_RECONNECT_BUFFER_SIZE,this._logger=n,this._protocol=o,this.connection=e,this._reconnectPolicy=l,this._handshakeProtocol=new HandshakeProtocol,this.connection.onreceive=b=>this._processIncomingData(b),this.connection.onclose=b=>this._connectionClosed(b),this._callbacks={},this._methods={},this._closedCallbacks=[],this._reconnectingCallbacks=[],this._reconnectedCallbacks=[],this._invocationId=0,this._receivedHandshakeResponse=!1,this._connectionState=HubConnectionState.Disconnected,this._connectionStarted=!1,this._cachedPingMessage=this._protocol.writeMessage({type:MessageType.Ping})}get state(){return this._connectionState}get connectionId(){return this.connection&&this.connection.connectionId||null}get baseUrl(){return this.connection.baseUrl||""}set baseUrl(e){if(this._connectionState!==HubConnectionState.Disconnected&&this._connectionState!==HubConnectionState.Reconnecting)throw new Error("The HubConnection must be in the Disconnected or Reconnecting state to change the url.");if(!e)throw new Error("The HubConnection url must be a valid url.");this.connection.baseUrl=e}start(){return this._startPromise=this._startWithStateTransitions(),this._startPromise}async _startWithStateTransitions(){if(this._connectionState!==HubConnectionState.Disconnected)return Promise.reject(new Error("Cannot start a HubConnection that is not in the 'Disconnected' state."));this._connectionState=HubConnectionState.Connecting,this._logger.log(LogLevel.Debug,"Starting HubConnection.");try{await this._startInternal(),Platform.isBrowser&&window.document.addEventListener("freeze",this._freezeEventListener),this._connectionState=HubConnectionState.Connected,this._connectionStarted=!0,this._logger.log(LogLevel.Debug,"HubConnection connected successfully.")}catch(e){return this._connectionState=HubConnectionState.Disconnected,this._logger.log(LogLevel.Debug,`HubConnection failed to start successfully because of error '${e}'.`),Promise.reject(e)}}async _startInternal(){this._stopDuringStartError=void 0,this._receivedHandshakeResponse=!1;const e=new Promise((n,o)=>{this._handshakeResolver=n,this._handshakeRejecter=o});await this.connection.start(this._protocol.transferFormat);try{let n=this._protocol.version;this.connection.features.reconnect||(n=1);const o={protocol:this._protocol.name,version:n};if(this._logger.log(LogLevel.Debug,"Sending handshake request."),await this._sendMessage(this._handshakeProtocol.writeHandshakeRequest(o)),this._logger.log(LogLevel.Information,`Using HubProtocol '${this._protocol.name}'.`),this._cleanupTimeout(),this._resetTimeoutPeriod(),this._resetKeepAliveInterval(),await e,this._stopDuringStartError)throw this._stopDuringStartError;(this.connection.features.reconnect||!1)&&(this._messageBuffer=new MessageBuffer(this._protocol,this.connection,this._statefulReconnectBufferSize),this.connection.features.disconnected=this._messageBuffer._disconnected.bind(this._messageBuffer),this.connection.features.resend=()=>{if(this._messageBuffer)return this._messageBuffer._resend()}),this.connection.features.inherentKeepAlive||await this._sendMessage(this._cachedPingMessage)}catch(n){throw this._logger.log(LogLevel.Debug,`Hub handshake failed with error '${n}' during start(). Stopping HubConnection.`),this._cleanupTimeout(),this._cleanupPingTimer(),await this.connection.stop(n),n}}async stop(){const e=this._startPromise;this.connection.features.reconnect=!1,this._stopPromise=this._stopInternal(),await this._stopPromise;try{await e}catch{}}_stopInternal(e){if(this._connectionState===HubConnectionState.Disconnected)return this._logger.log(LogLevel.Debug,`Call to HubConnection.stop(${e}) ignored because it is already in the disconnected state.`),Promise.resolve();if(this._connectionState===HubConnectionState.Disconnecting)return this._logger.log(LogLevel.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise;const n=this._connectionState;return this._connectionState=HubConnectionState.Disconnecting,this._logger.log(LogLevel.Debug,"Stopping HubConnection."),this._reconnectDelayHandle?(this._logger.log(LogLevel.Debug,"Connection stopped during reconnect delay. Done reconnecting."),clearTimeout(this._reconnectDelayHandle),this._reconnectDelayHandle=void 0,this._completeClose(),Promise.resolve()):(n===HubConnectionState.Connected&&this._sendCloseMessage(),this._cleanupTimeout(),this._cleanupPingTimer(),this._stopDuringStartError=e||new AbortError("The connection was stopped before the hub handshake could complete."),this.connection.stop(e))}async _sendCloseMessage(){try{await this._sendWithProtocol(this._createCloseMessage())}catch{}}stream(e,...n){const[o,l]=this._replaceStreamingParams(n),d=this._createStreamInvocation(e,n,l);let f;const g=new Subject;return g.cancelCallback=()=>{const b=this._createCancelInvocation(d.invocationId);return delete this._callbacks[d.invocationId],f.then(()=>this._sendWithProtocol(b))},this._callbacks[d.invocationId]=(b,S)=>{if(S){g.error(S);return}else b&&(b.type===MessageType.Completion?b.error?g.error(new Error(b.error)):g.complete():g.next(b.item))},f=this._sendWithProtocol(d).catch(b=>{g.error(b),delete this._callbacks[d.invocationId]}),this._launchStreams(o,f),g}_sendMessage(e){return this._resetKeepAliveInterval(),this.connection.send(e)}_sendWithProtocol(e){return this._messageBuffer?this._messageBuffer._send(e):this._sendMessage(this._protocol.writeMessage(e))}send(e,...n){const[o,l]=this._replaceStreamingParams(n),d=this._sendWithProtocol(this._createInvocation(e,n,!0,l));return this._launchStreams(o,d),d}invoke(e,...n){const[o,l]=this._replaceStreamingParams(n),d=this._createInvocation(e,n,!1,l);return new Promise((g,b)=>{this._callbacks[d.invocationId]=(_,R)=>{if(R){b(R);return}else _&&(_.type===MessageType.Completion?_.error?b(new Error(_.error)):g(_.result):b(new Error(`Unexpected message type: ${_.type}`)))};const S=this._sendWithProtocol(d).catch(_=>{b(_),delete this._callbacks[d.invocationId]});this._launchStreams(o,S)})}on(e,n){!e||!n||(e=e.toLowerCase(),this._methods[e]||(this._methods[e]=[]),this._methods[e].indexOf(n)===-1&&this._methods[e].push(n))}off(e,n){if(!e)return;e=e.toLowerCase();const o=this._methods[e];if(o)if(n){const l=o.indexOf(n);l!==-1&&(o.splice(l,1),o.length===0&&delete this._methods[e])}else delete this._methods[e]}onclose(e){e&&this._closedCallbacks.push(e)}onreconnecting(e){e&&this._reconnectingCallbacks.push(e)}onreconnected(e){e&&this._reconnectedCallbacks.push(e)}_processIncomingData(e){if(this._cleanupTimeout(),this._receivedHandshakeResponse||(e=this._processHandshakeResponse(e),this._receivedHandshakeResponse=!0),e){const n=this._protocol.parseMessages(e,this._logger);for(const o of n)if(!(this._messageBuffer&&!this._messageBuffer._shouldProcessMessage(o)))switch(o.type){case MessageType.Invocation:this._invokeClientMethod(o).catch(l=>{this._logger.log(LogLevel.Error,`Invoke client method threw error: ${getErrorString(l)}`)});break;case MessageType.StreamItem:case MessageType.Completion:{const l=this._callbacks[o.invocationId];if(l){o.type===MessageType.Completion&&delete this._callbacks[o.invocationId];try{l(o)}catch(d){this._logger.log(LogLevel.Error,`Stream callback threw error: ${getErrorString(d)}`)}}break}case MessageType.Ping:break;case MessageType.Close:{this._logger.log(LogLevel.Information,"Close message received from server.");const l=o.error?new Error("Server returned an error on close: "+o.error):void 0;o.allowReconnect===!0?this.connection.stop(l):this._stopPromise=this._stopInternal(l);break}case MessageType.Ack:this._messageBuffer&&this._messageBuffer._ack(o);break;case MessageType.Sequence:this._messageBuffer&&this._messageBuffer._resetSequence(o);break;default:this._logger.log(LogLevel.Warning,`Invalid message type: ${o.type}.`);break}}this._resetTimeoutPeriod()}_processHandshakeResponse(e){let n,o;try{[o,n]=this._handshakeProtocol.parseHandshakeResponse(e)}catch(l){const d="Error parsing handshake response: "+l;this._logger.log(LogLevel.Error,d);const f=new Error(d);throw this._handshakeRejecter(f),f}if(n.error){const l="Server returned handshake error: "+n.error;this._logger.log(LogLevel.Error,l);const d=new Error(l);throw this._handshakeRejecter(d),d}else this._logger.log(LogLevel.Debug,"Server handshake complete.");return this._handshakeResolver(),o}_resetKeepAliveInterval(){this.connection.features.inherentKeepAlive||(this._nextKeepAlive=new Date().getTime()+this.keepAliveIntervalInMilliseconds,this._cleanupPingTimer())}_resetTimeoutPeriod(){if((!this.connection.features||!this.connection.features.inherentKeepAlive)&&(this._timeoutHandle=setTimeout(()=>this.serverTimeout(),this.serverTimeoutInMilliseconds),this._pingServerHandle===void 0)){let e=this._nextKeepAlive-new Date().getTime();e<0&&(e=0),this._pingServerHandle=setTimeout(async()=>{if(this._connectionState===HubConnectionState.Connected)try{await this._sendMessage(this._cachedPingMessage)}catch{this._cleanupPingTimer()}},e)}}serverTimeout(){this.connection.stop(new Error("Server timeout elapsed without receiving a message from the server."))}async _invokeClientMethod(e){const n=e.target.toLowerCase(),o=this._methods[n];if(!o){this._logger.log(LogLevel.Warning,`No client method with the name '${n}' found.`),e.invocationId&&(this._logger.log(LogLevel.Warning,`No result given for '${n}' method and invocation ID '${e.invocationId}'.`),await this._sendWithProtocol(this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null)));return}const l=o.slice(),d=!!e.invocationId;let f,g,b;for(const S of l)try{const _=f;f=await S.apply(this,e.arguments),d&&f&&_&&(this._logger.log(LogLevel.Error,`Multiple results provided for '${n}'. Sending error to server.`),b=this._createCompletionMessage(e.invocationId,"Client provided multiple results.",null)),g=void 0}catch(_){g=_,this._logger.log(LogLevel.Error,`A callback for the method '${n}' threw error '${_}'.`)}b?await this._sendWithProtocol(b):d?(g?b=this._createCompletionMessage(e.invocationId,`${g}`,null):f!==void 0?b=this._createCompletionMessage(e.invocationId,null,f):(this._logger.log(LogLevel.Warning,`No result given for '${n}' method and invocation ID '${e.invocationId}'.`),b=this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null)),await this._sendWithProtocol(b)):f&&this._logger.log(LogLevel.Error,`Result given for '${n}' method but server is not expecting a result.`)}_connectionClosed(e){this._logger.log(LogLevel.Debug,`HubConnection.connectionClosed(${e}) called while in state ${this._connectionState}.`),this._stopDuringStartError=this._stopDuringStartError||e||new AbortError("The underlying connection was closed before the hub handshake could complete."),this._handshakeResolver&&this._handshakeResolver(),this._cancelCallbacksWithError(e||new Error("Invocation canceled due to the underlying connection being closed.")),this._cleanupTimeout(),this._cleanupPingTimer(),this._connectionState===HubConnectionState.Disconnecting?this._completeClose(e):this._connectionState===HubConnectionState.Connected&&this._reconnectPolicy?this._reconnect(e):this._connectionState===HubConnectionState.Connected&&this._completeClose(e)}_completeClose(e){if(this._connectionStarted){this._connectionState=HubConnectionState.Disconnected,this._connectionStarted=!1,this._messageBuffer&&(this._messageBuffer._dispose(e??new Error("Connection closed.")),this._messageBuffer=void 0),Platform.isBrowser&&window.document.removeEventListener("freeze",this._freezeEventListener);try{this._closedCallbacks.forEach(n=>n.apply(this,[e]))}catch(n){this._logger.log(LogLevel.Error,`An onclose callback called with error '${e}' threw error '${n}'.`)}}}async _reconnect(e){const n=Date.now();let o=0,l=e!==void 0?e:new Error("Attempting to reconnect due to a unknown error."),d=this._getNextRetryDelay(o++,0,l);if(d===null){this._logger.log(LogLevel.Debug,"Connection not reconnecting because the IRetryPolicy returned null on the first reconnect attempt."),this._completeClose(e);return}if(this._connectionState=HubConnectionState.Reconnecting,e?this._logger.log(LogLevel.Information,`Connection reconnecting because of error '${e}'.`):this._logger.log(LogLevel.Information,"Connection reconnecting."),this._reconnectingCallbacks.length!==0){try{this._reconnectingCallbacks.forEach(f=>f.apply(this,[e]))}catch(f){this._logger.log(LogLevel.Error,`An onreconnecting callback called with error '${e}' threw error '${f}'.`)}if(this._connectionState!==HubConnectionState.Reconnecting){this._logger.log(LogLevel.Debug,"Connection left the reconnecting state in onreconnecting callback. Done reconnecting.");return}}for(;d!==null;){if(this._logger.log(LogLevel.Information,`Reconnect attempt number ${o} will start in ${d} ms.`),await new Promise(f=>{this._reconnectDelayHandle=setTimeout(f,d)}),this._reconnectDelayHandle=void 0,this._connectionState!==HubConnectionState.Reconnecting){this._logger.log(LogLevel.Debug,"Connection left the reconnecting state during reconnect delay. Done reconnecting.");return}try{if(await this._startInternal(),this._connectionState=HubConnectionState.Connected,this._logger.log(LogLevel.Information,"HubConnection reconnected successfully."),this._reconnectedCallbacks.length!==0)try{this._reconnectedCallbacks.forEach(f=>f.apply(this,[this.connection.connectionId]))}catch(f){this._logger.log(LogLevel.Error,`An onreconnected callback called with connectionId '${this.connection.connectionId}; threw error '${f}'.`)}return}catch(f){if(this._logger.log(LogLevel.Information,`Reconnect attempt failed because of error '${f}'.`),this._connectionState!==HubConnectionState.Reconnecting){this._logger.log(LogLevel.Debug,`Connection moved to the '${this._connectionState}' from the reconnecting state during reconnect attempt. Done reconnecting.`),this._connectionState===HubConnectionState.Disconnecting&&this._completeClose();return}l=f instanceof Error?f:new Error(f.toString()),d=this._getNextRetryDelay(o++,Date.now()-n,l)}}this._logger.log(LogLevel.Information,`Reconnect retries have been exhausted after ${Date.now()-n} ms and ${o} failed attempts. Connection disconnecting.`),this._completeClose()}_getNextRetryDelay(e,n,o){try{return this._reconnectPolicy.nextRetryDelayInMilliseconds({elapsedMilliseconds:n,previousRetryCount:e,retryReason:o})}catch(l){return this._logger.log(LogLevel.Error,`IRetryPolicy.nextRetryDelayInMilliseconds(${e}, ${n}) threw error '${l}'.`),null}}_cancelCallbacksWithError(e){const n=this._callbacks;this._callbacks={},Object.keys(n).forEach(o=>{const l=n[o];try{l(null,e)}catch(d){this._logger.log(LogLevel.Error,`Stream 'error' callback called with '${e}' threw error: ${getErrorString(d)}`)}})}_cleanupPingTimer(){this._pingServerHandle&&(clearTimeout(this._pingServerHandle),this._pingServerHandle=void 0)}_cleanupTimeout(){this._timeoutHandle&&clearTimeout(this._timeoutHandle)}_createInvocation(e,n,o,l){if(o)return l.length!==0?{arguments:n,streamIds:l,target:e,type:MessageType.Invocation}:{arguments:n,target:e,type:MessageType.Invocation};{const d=this._invocationId;return this._invocationId++,l.length!==0?{arguments:n,invocationId:d.toString(),streamIds:l,target:e,type:MessageType.Invocation}:{arguments:n,invocationId:d.toString(),target:e,type:MessageType.Invocation}}}_launchStreams(e,n){if(e.length!==0){n||(n=Promise.resolve());for(const o in e)e[o].subscribe({complete:()=>{n=n.then(()=>this._sendWithProtocol(this._createCompletionMessage(o)))},error:l=>{let d;l instanceof Error?d=l.message:l&&l.toString?d=l.toString():d="Unknown error",n=n.then(()=>this._sendWithProtocol(this._createCompletionMessage(o,d)))},next:l=>{n=n.then(()=>this._sendWithProtocol(this._createStreamItemMessage(o,l)))}})}}_replaceStreamingParams(e){const n=[],o=[];for(let l=0;l<e.length;l++){const d=e[l];if(this._isObservable(d)){const f=this._invocationId;this._invocationId++,n[f]=d,o.push(f.toString()),e.splice(l,1)}}return[n,o]}_isObservable(e){return e&&e.subscribe&&typeof e.subscribe=="function"}_createStreamInvocation(e,n,o){const l=this._invocationId;return this._invocationId++,o.length!==0?{arguments:n,invocationId:l.toString(),streamIds:o,target:e,type:MessageType.StreamInvocation}:{arguments:n,invocationId:l.toString(),target:e,type:MessageType.StreamInvocation}}_createCancelInvocation(e){return{invocationId:e,type:MessageType.CancelInvocation}}_createStreamItemMessage(e,n){return{invocationId:e,item:n,type:MessageType.StreamItem}}_createCompletionMessage(e,n,o){return n?{error:n,invocationId:e,type:MessageType.Completion}:{invocationId:e,result:o,type:MessageType.Completion}}_createCloseMessage(){return{type:MessageType.Close}}}const DEFAULT_RETRY_DELAYS_IN_MILLISECONDS=[0,2e3,1e4,3e4,null];class DefaultReconnectPolicy{constructor(e){this._retryDelays=e!==void 0?[...e,null]:DEFAULT_RETRY_DELAYS_IN_MILLISECONDS}nextRetryDelayInMilliseconds(e){return this._retryDelays[e.previousRetryCount]}}class HeaderNames{}HeaderNames.Authorization="Authorization",HeaderNames.Cookie="Cookie";class AccessTokenHttpClient extends HttpClient{constructor(e,n){super(),this._innerClient=e,this._accessTokenFactory=n}async send(e){let n=!0;this._accessTokenFactory&&(!this._accessToken||e.url&&e.url.indexOf("/negotiate?")>0)&&(n=!1,this._accessToken=await this._accessTokenFactory()),this._setAuthorizationHeader(e);const o=await this._innerClient.send(e);return n&&o.statusCode===401&&this._accessTokenFactory?(this._accessToken=await this._accessTokenFactory(),this._setAuthorizationHeader(e),await this._innerClient.send(e)):o}_setAuthorizationHeader(e){e.headers||(e.headers={}),this._accessToken?e.headers[HeaderNames.Authorization]=`Bearer ${this._accessToken}`:this._accessTokenFactory&&e.headers[HeaderNames.Authorization]&&delete e.headers[HeaderNames.Authorization]}getCookieString(e){return this._innerClient.getCookieString(e)}}var HttpTransportType;(function(t){t[t.None=0]="None",t[t.WebSockets=1]="WebSockets",t[t.ServerSentEvents=2]="ServerSentEvents",t[t.LongPolling=4]="LongPolling"})(HttpTransportType||(HttpTransportType={}));var TransferFormat;(function(t){t[t.Text=1]="Text",t[t.Binary=2]="Binary"})(TransferFormat||(TransferFormat={}));let AbortController$1=class{constructor(){this._isAborted=!1,this.onabort=null}abort(){this._isAborted||(this._isAborted=!0,this.onabort&&this.onabort())}get signal(){return this}get aborted(){return this._isAborted}};class LongPollingTransport{get pollAborted(){return this._pollAbort.aborted}constructor(e,n,o){this._httpClient=e,this._logger=n,this._pollAbort=new AbortController$1,this._options=o,this._running=!1,this.onreceive=null,this.onclose=null}async connect(e,n){if(Arg.isRequired(e,"url"),Arg.isRequired(n,"transferFormat"),Arg.isIn(n,TransferFormat,"transferFormat"),this._url=e,this._logger.log(LogLevel.Trace,"(LongPolling transport) Connecting."),n===TransferFormat.Binary&&typeof XMLHttpRequest<"u"&&typeof new XMLHttpRequest().responseType!="string")throw new Error("Binary protocols over XmlHttpRequest not implementing advanced features are not supported.");const[o,l]=getUserAgentHeader(),d={[o]:l,...this._options.headers},f={abortSignal:this._pollAbort.signal,headers:d,timeout:1e5,withCredentials:this._options.withCredentials};n===TransferFormat.Binary&&(f.responseType="arraybuffer");const g=`${e}&_=${Date.now()}`;this._logger.log(LogLevel.Trace,`(LongPolling transport) polling: ${g}.`);const b=await this._httpClient.get(g,f);b.statusCode!==200?(this._logger.log(LogLevel.Error,`(LongPolling transport) Unexpected response code: ${b.statusCode}.`),this._closeError=new HttpError(b.statusText||"",b.statusCode),this._running=!1):this._running=!0,this._receiving=this._poll(this._url,f)}async _poll(e,n){try{for(;this._running;)try{const o=`${e}&_=${Date.now()}`;this._logger.log(LogLevel.Trace,`(LongPolling transport) polling: ${o}.`);const l=await this._httpClient.get(o,n);l.statusCode===204?(this._logger.log(LogLevel.Information,"(LongPolling transport) Poll terminated by server."),this._running=!1):l.statusCode!==200?(this._logger.log(LogLevel.Error,`(LongPolling transport) Unexpected response code: ${l.statusCode}.`),this._closeError=new HttpError(l.statusText||"",l.statusCode),this._running=!1):l.content?(this._logger.log(LogLevel.Trace,`(LongPolling transport) data received. ${getDataDetail(l.content,this._options.logMessageContent)}.`),this.onreceive&&this.onreceive(l.content)):this._logger.log(LogLevel.Trace,"(LongPolling transport) Poll timed out, reissuing.")}catch(o){this._running?o instanceof TimeoutError?this._logger.log(LogLevel.Trace,"(LongPolling transport) Poll timed out, reissuing."):(this._closeError=o,this._running=!1):this._logger.log(LogLevel.Trace,`(LongPolling transport) Poll errored after shutdown: ${o.message}`)}}finally{this._logger.log(LogLevel.Trace,"(LongPolling transport) Polling complete."),this.pollAborted||this._raiseOnClose()}}async send(e){return this._running?sendMessage(this._logger,"LongPolling",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}async stop(){this._logger.log(LogLevel.Trace,"(LongPolling transport) Stopping polling."),this._running=!1,this._pollAbort.abort();try{await this._receiving,this._logger.log(LogLevel.Trace,`(LongPolling transport) sending DELETE request to ${this._url}.`);const e={},[n,o]=getUserAgentHeader();e[n]=o;const l={headers:{...e,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials};let d;try{await this._httpClient.delete(this._url,l)}catch(f){d=f}d?d instanceof HttpError&&(d.statusCode===404?this._logger.log(LogLevel.Trace,"(LongPolling transport) A 404 response was returned from sending a DELETE request."):this._logger.log(LogLevel.Trace,`(LongPolling transport) Error sending a DELETE request: ${d}`)):this._logger.log(LogLevel.Trace,"(LongPolling transport) DELETE request accepted.")}finally{this._logger.log(LogLevel.Trace,"(LongPolling transport) Stop finished."),this._raiseOnClose()}}_raiseOnClose(){if(this.onclose){let e="(LongPolling transport) Firing onclose event.";this._closeError&&(e+=" Error: "+this._closeError),this._logger.log(LogLevel.Trace,e),this.onclose(this._closeError)}}}class ServerSentEventsTransport{constructor(e,n,o,l){this._httpClient=e,this._accessToken=n,this._logger=o,this._options=l,this.onreceive=null,this.onclose=null}async connect(e,n){return Arg.isRequired(e,"url"),Arg.isRequired(n,"transferFormat"),Arg.isIn(n,TransferFormat,"transferFormat"),this._logger.log(LogLevel.Trace,"(SSE transport) Connecting."),this._url=e,this._accessToken&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(this._accessToken)}`),new Promise((o,l)=>{let d=!1;if(n!==TransferFormat.Text){l(new Error("The Server-Sent Events transport only supports the 'Text' transfer format"));return}let f;if(Platform.isBrowser||Platform.isWebWorker)f=new this._options.EventSource(e,{withCredentials:this._options.withCredentials});else{const g=this._httpClient.getCookieString(e),b={};b.Cookie=g;const[S,_]=getUserAgentHeader();b[S]=_,f=new this._options.EventSource(e,{withCredentials:this._options.withCredentials,headers:{...b,...this._options.headers}})}try{f.onmessage=g=>{if(this.onreceive)try{this._logger.log(LogLevel.Trace,`(SSE transport) data received. ${getDataDetail(g.data,this._options.logMessageContent)}.`),this.onreceive(g.data)}catch(b){this._close(b);return}},f.onerror=g=>{d?this._close():l(new Error("EventSource failed to connect. The connection could not be found on the server, either the connection ID is not present on the server, or a proxy is refusing/buffering the connection. If you have multiple servers check that sticky sessions are enabled."))},f.onopen=()=>{this._logger.log(LogLevel.Information,`SSE connected to ${this._url}`),this._eventSource=f,d=!0,o()}}catch(g){l(g);return}})}async send(e){return this._eventSource?sendMessage(this._logger,"SSE",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}stop(){return this._close(),Promise.resolve()}_close(e){this._eventSource&&(this._eventSource.close(),this._eventSource=void 0,this.onclose&&this.onclose(e))}}class WebSocketTransport{constructor(e,n,o,l,d,f){this._logger=o,this._accessTokenFactory=n,this._logMessageContent=l,this._webSocketConstructor=d,this._httpClient=e,this.onreceive=null,this.onclose=null,this._headers=f}async connect(e,n){Arg.isRequired(e,"url"),Arg.isRequired(n,"transferFormat"),Arg.isIn(n,TransferFormat,"transferFormat"),this._logger.log(LogLevel.Trace,"(WebSockets transport) Connecting.");let o;return this._accessTokenFactory&&(o=await this._accessTokenFactory()),new Promise((l,d)=>{e=e.replace(/^http/,"ws");let f;const g=this._httpClient.getCookieString(e);let b=!1;if(Platform.isNode||Platform.isReactNative){const S={},[_,R]=getUserAgentHeader();S[_]=R,o&&(S[HeaderNames.Authorization]=`Bearer ${o}`),g&&(S[HeaderNames.Cookie]=g),f=new this._webSocketConstructor(e,void 0,{headers:{...S,...this._headers}})}else o&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(o)}`);f||(f=new this._webSocketConstructor(e)),n===TransferFormat.Binary&&(f.binaryType="arraybuffer"),f.onopen=S=>{this._logger.log(LogLevel.Information,`WebSocket connected to ${e}.`),this._webSocket=f,b=!0,l()},f.onerror=S=>{let _=null;typeof ErrorEvent<"u"&&S instanceof ErrorEvent?_=S.error:_="There was an error with the transport",this._logger.log(LogLevel.Information,`(WebSockets transport) ${_}.`)},f.onmessage=S=>{if(this._logger.log(LogLevel.Trace,`(WebSockets transport) data received. ${getDataDetail(S.data,this._logMessageContent)}.`),this.onreceive)try{this.onreceive(S.data)}catch(_){this._close(_);return}},f.onclose=S=>{if(b)this._close(S);else{let _=null;typeof ErrorEvent<"u"&&S instanceof ErrorEvent?_=S.error:_="WebSocket failed to connect. The connection could not be found on the server, either the endpoint may not be a SignalR endpoint, the connection ID is not present on the server, or there is a proxy blocking WebSockets. If you have multiple servers check that sticky sessions are enabled.",d(new Error(_))}}})}send(e){return this._webSocket&&this._webSocket.readyState===this._webSocketConstructor.OPEN?(this._logger.log(LogLevel.Trace,`(WebSockets transport) sending data. ${getDataDetail(e,this._logMessageContent)}.`),this._webSocket.send(e),Promise.resolve()):Promise.reject("WebSocket is not in the OPEN state")}stop(){return this._webSocket&&this._close(void 0),Promise.resolve()}_close(e){this._webSocket&&(this._webSocket.onclose=()=>{},this._webSocket.onmessage=()=>{},this._webSocket.onerror=()=>{},this._webSocket.close(),this._webSocket=void 0),this._logger.log(LogLevel.Trace,"(WebSockets transport) socket closed."),this.onclose&&(this._isCloseEvent(e)&&(e.wasClean===!1||e.code!==1e3)?this.onclose(new Error(`WebSocket closed with status code: ${e.code} (${e.reason||"no reason given"}).`)):e instanceof Error?this.onclose(e):this.onclose())}_isCloseEvent(e){return e&&typeof e.wasClean=="boolean"&&typeof e.code=="number"}}const MAX_REDIRECTS=100;class HttpConnection{constructor(e,n={}){if(this._stopPromiseResolver=()=>{},this.features={},this._negotiateVersion=1,Arg.isRequired(e,"url"),this._logger=createLogger(n.logger),this.baseUrl=this._resolveUrl(e),n=n||{},n.logMessageContent=n.logMessageContent===void 0?!1:n.logMessageContent,typeof n.withCredentials=="boolean"||n.withCredentials===void 0)n.withCredentials=n.withCredentials===void 0?!0:n.withCredentials;else throw new Error("withCredentials option was not a 'boolean' or 'undefined' value");n.timeout=n.timeout===void 0?100*1e3:n.timeout;let o=null,l=null;if(Platform.isNode&&typeof require<"u"){const d=typeof __webpack_require__=="function"?__non_webpack_require__:require;o=d("ws"),l=d("eventsource")}!Platform.isNode&&typeof WebSocket<"u"&&!n.WebSocket?n.WebSocket=WebSocket:Platform.isNode&&!n.WebSocket&&o&&(n.WebSocket=o),!Platform.isNode&&typeof EventSource<"u"&&!n.EventSource?n.EventSource=EventSource:Platform.isNode&&!n.EventSource&&typeof l<"u"&&(n.EventSource=l),this._httpClient=new AccessTokenHttpClient(n.httpClient||new DefaultHttpClient(this._logger),n.accessTokenFactory),this._connectionState="Disconnected",this._connectionStarted=!1,this._options=n,this.onreceive=null,this.onclose=null}async start(e){if(e=e||TransferFormat.Binary,Arg.isIn(e,TransferFormat,"transferFormat"),this._logger.log(LogLevel.Debug,`Starting connection with transfer format '${TransferFormat[e]}'.`),this._connectionState!=="Disconnected")return Promise.reject(new Error("Cannot start an HttpConnection that is not in the 'Disconnected' state."));if(this._connectionState="Connecting",this._startInternalPromise=this._startInternal(e),await this._startInternalPromise,this._connectionState==="Disconnecting"){const n="Failed to start the HttpConnection before stop() was called.";return this._logger.log(LogLevel.Error,n),await this._stopPromise,Promise.reject(new AbortError(n))}else if(this._connectionState!=="Connected"){const n="HttpConnection.startInternal completed gracefully but didn't enter the connection into the connected state!";return this._logger.log(LogLevel.Error,n),Promise.reject(new AbortError(n))}this._connectionStarted=!0}send(e){return this._connectionState!=="Connected"?Promise.reject(new Error("Cannot send data if the connection is not in the 'Connected' State.")):(this._sendQueue||(this._sendQueue=new TransportSendQueue(this.transport)),this._sendQueue.send(e))}async stop(e){if(this._connectionState==="Disconnected")return this._logger.log(LogLevel.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnected state.`),Promise.resolve();if(this._connectionState==="Disconnecting")return this._logger.log(LogLevel.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise;this._connectionState="Disconnecting",this._stopPromise=new Promise(n=>{this._stopPromiseResolver=n}),await this._stopInternal(e),await this._stopPromise}async _stopInternal(e){this._stopError=e;try{await this._startInternalPromise}catch{}if(this.transport){try{await this.transport.stop()}catch(n){this._logger.log(LogLevel.Error,`HttpConnection.transport.stop() threw error '${n}'.`),this._stopConnection()}this.transport=void 0}else this._logger.log(LogLevel.Debug,"HttpConnection.transport is undefined in HttpConnection.stop() because start() failed.")}async _startInternal(e){let n=this.baseUrl;this._accessTokenFactory=this._options.accessTokenFactory,this._httpClient._accessTokenFactory=this._accessTokenFactory;try{if(this._options.skipNegotiation)if(this._options.transport===HttpTransportType.WebSockets)this.transport=this._constructTransport(HttpTransportType.WebSockets),await this._startTransport(n,e);else throw new Error("Negotiation can only be skipped when using the WebSocket transport directly.");else{let o=null,l=0;do{if(o=await this._getNegotiationResponse(n),this._connectionState==="Disconnecting"||this._connectionState==="Disconnected")throw new AbortError("The connection was stopped during negotiation.");if(o.error)throw new Error(o.error);if(o.ProtocolVersion)throw new Error("Detected a connection attempt to an ASP.NET SignalR Server. This client only supports connecting to an ASP.NET Core SignalR Server. See https://aka.ms/signalr-core-differences for details.");if(o.url&&(n=o.url),o.accessToken){const d=o.accessToken;this._accessTokenFactory=()=>d,this._httpClient._accessToken=d,this._httpClient._accessTokenFactory=void 0}l++}while(o.url&&l<MAX_REDIRECTS);if(l===MAX_REDIRECTS&&o.url)throw new Error("Negotiate redirection limit exceeded.");await this._createTransport(n,this._options.transport,o,e)}this.transport instanceof LongPollingTransport&&(this.features.inherentKeepAlive=!0),this._connectionState==="Connecting"&&(this._logger.log(LogLevel.Debug,"The HttpConnection connected successfully."),this._connectionState="Connected")}catch(o){return this._logger.log(LogLevel.Error,"Failed to start the connection: "+o),this._connectionState="Disconnected",this.transport=void 0,this._stopPromiseResolver(),Promise.reject(o)}}async _getNegotiationResponse(e){const n={},[o,l]=getUserAgentHeader();n[o]=l;const d=this._resolveNegotiateUrl(e);this._logger.log(LogLevel.Debug,`Sending negotiation request: ${d}.`);try{const f=await this._httpClient.post(d,{content:"",headers:{...n,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials});if(f.statusCode!==200)return Promise.reject(new Error(`Unexpected status code returned from negotiate '${f.statusCode}'`));const g=JSON.parse(f.content);return(!g.negotiateVersion||g.negotiateVersion<1)&&(g.connectionToken=g.connectionId),g.useStatefulReconnect&&this._options._useStatefulReconnect!==!0?Promise.reject(new FailedToNegotiateWithServerError("Client didn't negotiate Stateful Reconnect but the server did.")):g}catch(f){let g="Failed to complete negotiation with the server: "+f;return f instanceof HttpError&&f.statusCode===404&&(g=g+" Either this is not a SignalR endpoint or there is a proxy blocking the connection."),this._logger.log(LogLevel.Error,g),Promise.reject(new FailedToNegotiateWithServerError(g))}}_createConnectUrl(e,n){return n?e+(e.indexOf("?")===-1?"?":"&")+`id=${n}`:e}async _createTransport(e,n,o,l){let d=this._createConnectUrl(e,o.connectionToken);if(this._isITransport(n)){this._logger.log(LogLevel.Debug,"Connection was provided an instance of ITransport, using that directly."),this.transport=n,await this._startTransport(d,l),this.connectionId=o.connectionId;return}const f=[],g=o.availableTransports||[];let b=o;for(const S of g){const _=this._resolveTransportOrError(S,n,l,(b==null?void 0:b.useStatefulReconnect)===!0);if(_ instanceof Error)f.push(`${S.transport} failed:`),f.push(_);else if(this._isITransport(_)){if(this.transport=_,!b){try{b=await this._getNegotiationResponse(e)}catch(R){return Promise.reject(R)}d=this._createConnectUrl(e,b.connectionToken)}try{await this._startTransport(d,l),this.connectionId=b.connectionId;return}catch(R){if(this._logger.log(LogLevel.Error,`Failed to start the transport '${S.transport}': ${R}`),b=void 0,f.push(new FailedToStartTransportError(`${S.transport} failed: ${R}`,HttpTransportType[S.transport])),this._connectionState!=="Connecting"){const C="Failed to select transport before stop() was called.";return this._logger.log(LogLevel.Debug,C),Promise.reject(new AbortError(C))}}}}return f.length>0?Promise.reject(new AggregateErrors(`Unable to connect to the server with any of the available transports. ${f.join(" ")}`,f)):Promise.reject(new Error("None of the transports supported by the client are supported by the server."))}_constructTransport(e){switch(e){case HttpTransportType.WebSockets:if(!this._options.WebSocket)throw new Error("'WebSocket' is not supported in your environment.");return new WebSocketTransport(this._httpClient,this._accessTokenFactory,this._logger,this._options.logMessageContent,this._options.WebSocket,this._options.headers||{});case HttpTransportType.ServerSentEvents:if(!this._options.EventSource)throw new Error("'EventSource' is not supported in your environment.");return new ServerSentEventsTransport(this._httpClient,this._httpClient._accessToken,this._logger,this._options);case HttpTransportType.LongPolling:return new LongPollingTransport(this._httpClient,this._logger,this._options);default:throw new Error(`Unknown transport: ${e}.`)}}_startTransport(e,n){return this.transport.onreceive=this.onreceive,this.features.reconnect?this.transport.onclose=async o=>{let l=!1;if(this.features.reconnect)try{this.features.disconnected(),await this.transport.connect(e,n),await this.features.resend()}catch{l=!0}else{this._stopConnection(o);return}l&&this._stopConnection(o)}:this.transport.onclose=o=>this._stopConnection(o),this.transport.connect(e,n)}_resolveTransportOrError(e,n,o,l){const d=HttpTransportType[e.transport];if(d==null)return this._logger.log(LogLevel.Debug,`Skipping transport '${e.transport}' because it is not supported by this client.`),new Error(`Skipping transport '${e.transport}' because it is not supported by this client.`);if(transportMatches(n,d))if(e.transferFormats.map(g=>TransferFormat[g]).indexOf(o)>=0){if(d===HttpTransportType.WebSockets&&!this._options.WebSocket||d===HttpTransportType.ServerSentEvents&&!this._options.EventSource)return this._logger.log(LogLevel.Debug,`Skipping transport '${HttpTransportType[d]}' because it is not supported in your environment.'`),new UnsupportedTransportError(`'${HttpTransportType[d]}' is not supported in your environment.`,d);this._logger.log(LogLevel.Debug,`Selecting transport '${HttpTransportType[d]}'.`);try{return this.features.reconnect=d===HttpTransportType.WebSockets?l:void 0,this._constructTransport(d)}catch(g){return g}}else return this._logger.log(LogLevel.Debug,`Skipping transport '${HttpTransportType[d]}' because it does not support the requested transfer format '${TransferFormat[o]}'.`),new Error(`'${HttpTransportType[d]}' does not support ${TransferFormat[o]}.`);else return this._logger.log(LogLevel.Debug,`Skipping transport '${HttpTransportType[d]}' because it was disabled by the client.`),new DisabledTransportError(`'${HttpTransportType[d]}' is disabled by the client.`,d)}_isITransport(e){return e&&typeof e=="object"&&"connect"in e}_stopConnection(e){if(this._logger.log(LogLevel.Debug,`HttpConnection.stopConnection(${e}) called while in state ${this._connectionState}.`),this.transport=void 0,e=this._stopError||e,this._stopError=void 0,this._connectionState==="Disconnected"){this._logger.log(LogLevel.Debug,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is already in the disconnected state.`);return}if(this._connectionState==="Connecting")throw this._logger.log(LogLevel.Warning,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is still in the connecting state.`),new Error(`HttpConnection.stopConnection(${e}) was called while the connection is still in the connecting state.`);if(this._connectionState==="Disconnecting"&&this._stopPromiseResolver(),e?this._logger.log(LogLevel.Error,`Connection disconnected with error '${e}'.`):this._logger.log(LogLevel.Information,"Connection disconnected."),this._sendQueue&&(this._sendQueue.stop().catch(n=>{this._logger.log(LogLevel.Error,`TransportSendQueue.stop() threw error '${n}'.`)}),this._sendQueue=void 0),this.connectionId=void 0,this._connectionState="Disconnected",this._connectionStarted){this._connectionStarted=!1;try{this.onclose&&this.onclose(e)}catch(n){this._logger.log(LogLevel.Error,`HttpConnection.onclose(${e}) threw error '${n}'.`)}}}_resolveUrl(e){if(e.lastIndexOf("https://",0)===0||e.lastIndexOf("http://",0)===0)return e;if(!Platform.isBrowser)throw new Error(`Cannot resolve '${e}'.`);const n=window.document.createElement("a");return n.href=e,this._logger.log(LogLevel.Information,`Normalizing '${e}' to '${n.href}'.`),n.href}_resolveNegotiateUrl(e){const n=new URL(e);n.pathname.endsWith("/")?n.pathname+="negotiate":n.pathname+="/negotiate";const o=new URLSearchParams(n.searchParams);return o.has("negotiateVersion")||o.append("negotiateVersion",this._negotiateVersion.toString()),o.has("useStatefulReconnect")?o.get("useStatefulReconnect")==="true"&&(this._options._useStatefulReconnect=!0):this._options._useStatefulReconnect===!0&&o.append("useStatefulReconnect","true"),n.search=o.toString(),n.toString()}}function transportMatches(t,e){return!t||(e&t)!==0}class TransportSendQueue{constructor(e){this._transport=e,this._buffer=[],this._executing=!0,this._sendBufferedData=new PromiseSource,this._transportResult=new PromiseSource,this._sendLoopPromise=this._sendLoop()}send(e){return this._bufferData(e),this._transportResult||(this._transportResult=new PromiseSource),this._transportResult.promise}stop(){return this._executing=!1,this._sendBufferedData.resolve(),this._sendLoopPromise}_bufferData(e){if(this._buffer.length&&typeof this._buffer[0]!=typeof e)throw new Error(`Expected data to be of type ${typeof this._buffer} but was of type ${typeof e}`);this._buffer.push(e),this._sendBufferedData.resolve()}async _sendLoop(){for(;;){if(await this._sendBufferedData.promise,!this._executing){this._transportResult&&this._transportResult.reject("Connection stopped.");break}this._sendBufferedData=new PromiseSource;const e=this._transportResult;this._transportResult=void 0;const n=typeof this._buffer[0]=="string"?this._buffer.join(""):TransportSendQueue._concatBuffers(this._buffer);this._buffer.length=0;try{await this._transport.send(n),e.resolve()}catch(o){e.reject(o)}}}static _concatBuffers(e){const n=e.map(d=>d.byteLength).reduce((d,f)=>d+f),o=new Uint8Array(n);let l=0;for(const d of e)o.set(new Uint8Array(d),l),l+=d.byteLength;return o.buffer}}class PromiseSource{constructor(){this.promise=new Promise((e,n)=>[this._resolver,this._rejecter]=[e,n])}resolve(){this._resolver()}reject(e){this._rejecter(e)}}const JSON_HUB_PROTOCOL_NAME="json";class JsonHubProtocol{constructor(){this.name=JSON_HUB_PROTOCOL_NAME,this.version=2,this.transferFormat=TransferFormat.Text}parseMessages(e,n){if(typeof e!="string")throw new Error("Invalid input for JSON hub protocol. Expected a string.");if(!e)return[];n===null&&(n=NullLogger.instance);const o=TextMessageFormat.parse(e),l=[];for(const d of o){const f=JSON.parse(d);if(typeof f.type!="number")throw new Error("Invalid payload.");switch(f.type){case MessageType.Invocation:this._isInvocationMessage(f);break;case MessageType.StreamItem:this._isStreamItemMessage(f);break;case MessageType.Completion:this._isCompletionMessage(f);break;case MessageType.Ping:break;case MessageType.Close:break;case MessageType.Ack:this._isAckMessage(f);break;case MessageType.Sequence:this._isSequenceMessage(f);break;default:n.log(LogLevel.Information,"Unknown message type '"+f.type+"' ignored.");continue}l.push(f)}return l}writeMessage(e){return TextMessageFormat.write(JSON.stringify(e))}_isInvocationMessage(e){this._assertNotEmptyString(e.target,"Invalid payload for Invocation message."),e.invocationId!==void 0&&this._assertNotEmptyString(e.invocationId,"Invalid payload for Invocation message.")}_isStreamItemMessage(e){if(this._assertNotEmptyString(e.invocationId,"Invalid payload for StreamItem message."),e.item===void 0)throw new Error("Invalid payload for StreamItem message.")}_isCompletionMessage(e){if(e.result&&e.error)throw new Error("Invalid payload for Completion message.");!e.result&&e.error&&this._assertNotEmptyString(e.error,"Invalid payload for Completion message."),this._assertNotEmptyString(e.invocationId,"Invalid payload for Completion message.")}_isAckMessage(e){if(typeof e.sequenceId!="number")throw new Error("Invalid SequenceId for Ack message.")}_isSequenceMessage(e){if(typeof e.sequenceId!="number")throw new Error("Invalid SequenceId for Sequence message.")}_assertNotEmptyString(e,n){if(typeof e!="string"||e==="")throw new Error(n)}}const LogLevelNameMapping={trace:LogLevel.Trace,debug:LogLevel.Debug,info:LogLevel.Information,information:LogLevel.Information,warn:LogLevel.Warning,warning:LogLevel.Warning,error:LogLevel.Error,critical:LogLevel.Critical,none:LogLevel.None};function parseLogLevel(t){const e=LogLevelNameMapping[t.toLowerCase()];if(typeof e<"u")return e;throw new Error(`Unknown log level: ${t}`)}class HubConnectionBuilder{configureLogging(e){if(Arg.isRequired(e,"logging"),isLogger(e))this.logger=e;else if(typeof e=="string"){const n=parseLogLevel(e);this.logger=new ConsoleLogger(n)}else this.logger=new ConsoleLogger(e);return this}withUrl(e,n){return Arg.isRequired(e,"url"),Arg.isNotEmpty(e,"url"),this.url=e,typeof n=="object"?this.httpConnectionOptions={...this.httpConnectionOptions,...n}:this.httpConnectionOptions={...this.httpConnectionOptions,transport:n},this}withHubProtocol(e){return Arg.isRequired(e,"protocol"),this.protocol=e,this}withAutomaticReconnect(e){if(this.reconnectPolicy)throw new Error("A reconnectPolicy has already been set.");return e?Array.isArray(e)?this.reconnectPolicy=new DefaultReconnectPolicy(e):this.reconnectPolicy=e:this.reconnectPolicy=new DefaultReconnectPolicy,this}withServerTimeout(e){return Arg.isRequired(e,"milliseconds"),this._serverTimeoutInMilliseconds=e,this}withKeepAliveInterval(e){return Arg.isRequired(e,"milliseconds"),this._keepAliveIntervalInMilliseconds=e,this}withStatefulReconnect(e){return this.httpConnectionOptions===void 0&&(this.httpConnectionOptions={}),this.httpConnectionOptions._useStatefulReconnect=!0,this._statefulReconnectBufferSize=e==null?void 0:e.bufferSize,this}build(){const e=this.httpConnectionOptions||{};if(e.logger===void 0&&(e.logger=this.logger),!this.url)throw new Error("The 'HubConnectionBuilder.withUrl' method must be called before building the connection.");const n=new HttpConnection(this.url,e);return HubConnection.create(n,this.logger||NullLogger.instance,this.protocol||new JsonHubProtocol,this.reconnectPolicy,this._serverTimeoutInMilliseconds,this._keepAliveIntervalInMilliseconds,this._statefulReconnectBufferSize)}}function isLogger(t){return t.log!==void 0}const Textarea=React__namespace.forwardRef(({className:t,...e},n)=>jsxRuntime.jsx("textarea",{className:cn("flex min-h-[60px] w-full rounded-md border border-input bg-transparent px-3 py-2 text-base shadow-xs placeholder:text-muted-foreground focus-visible:outline-hidden focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 md:text-sm",t),ref:n,...e}));Textarea.displayName="Textarea";function ChatList({userId:t,chats:e,activeChat:n,onSelectChat:o,assistantStickyMode:l}){if(l){const d=e[0];return d?jsxRuntime.jsx("div",{className:"space-y-1",children:display(d,n,o,jsxRuntime.jsx(Bot,{className:"text-primary fill-white min-h-full"}))}):null}return jsxRuntime.jsx("div",{className:"space-y-1",children:e.map(d=>{const f=jsxRuntime.jsx(jsxRuntime.Fragment,{children:jsxRuntime.jsx(PartnerLogo,{id:d.partner1===t?d.partner2:d.partner1,width:72,height:72})});return display(d,n,o,f)})})}function display(t,e,n,o){var l;return jsxRuntime.jsxs("button",{className:cn("w-full flex items-center p-2 rounded-md hover:bg-slate-100 transition-colors",(e==null?void 0:e.partner1)===t.partner1&&(e==null?void 0:e.partner2)===t.partner2&&"bg-slate-100"),onClick:()=>n([t.partner1,t.partner2]),children:[jsxRuntime.jsx(Avatar,{className:"h-8 w-8 flex-shrink-0 rounded-none",children:t.pending?jsxRuntime.jsx(MessageSquareLock,{}):jsxRuntime.jsx(jsxRuntime.Fragment,{children:o})}),jsxRuntime.jsxs("div",{className:"ml-2 text-left overflow-hidden",children:[jsxRuntime.jsx("div",{className:"font-medium text-sm truncate",children:t.name}),jsxRuntime.jsx("div",{className:"text-xs text-muted-foreground truncate text-ellipsis",children:((l=t.messages.at(-1))==null?void 0:l.content)??""})]}),t.unread>0&&jsxRuntime.jsx("div",{className:"ml-auto bg-red-500 text-white text-xs rounded-full h-5 w-5 flex items-center justify-center",children:t.unread})]},t.partner1+" and "+t.partner2)}var md5$1={exports:{}},crypt={exports:{}},hasRequiredCrypt;function requireCrypt(){return hasRequiredCrypt||(hasRequiredCrypt=1,(function(){var t="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",e={rotl:function(n,o){return n<<o|n>>>32-o},rotr:function(n,o){return n<<32-o|n>>>o},endian:function(n){if(n.constructor==Number)return e.rotl(n,8)&16711935|e.rotl(n,24)&4278255360;for(var o=0;o<n.length;o++)n[o]=e.endian(n[o]);return n},randomBytes:function(n){for(var o=[];n>0;n--)o.push(Math.floor(Math.random()*256));return o},bytesToWords:function(n){for(var o=[],l=0,d=0;l<n.length;l++,d+=8)o[d>>>5]|=n[l]<<24-d%32;return o},wordsToBytes:function(n){for(var o=[],l=0;l<n.length*32;l+=8)o.push(n[l>>>5]>>>24-l%32&255);return o},bytesToHex:function(n){for(var o=[],l=0;l<n.length;l++)o.push((n[l]>>>4).toString(16)),o.push((n[l]&15).toString(16));return o.join("")},hexToBytes:function(n){for(var o=[],l=0;l<n.length;l+=2)o.push(parseInt(n.substr(l,2),16));return o},bytesToBase64:function(n){for(var o=[],l=0;l<n.length;l+=3)for(var d=n[l]<<16|n[l+1]<<8|n[l+2],f=0;f<4;f++)l*8+f*6<=n.length*8?o.push(t.charAt(d>>>6*(3-f)&63)):o.push("=");return o.join("")},base64ToBytes:function(n){n=n.replace(/[^A-Z0-9+\/]/ig,"");for(var o=[],l=0,d=0;l<n.length;d=++l%4)d!=0&&o.push((t.indexOf(n.charAt(l-1))&Math.pow(2,-2*d+8)-1)<<d*2|t.indexOf(n.charAt(l))>>>6-d*2);return o}};crypt.exports=e})()),crypt.exports}var charenc_1,hasRequiredCharenc;function requireCharenc(){if(hasRequiredCharenc)return charenc_1;hasRequiredCharenc=1;var t={utf8:{stringToBytes:function(e){return t.bin.stringToBytes(unescape(encodeURIComponent(e)))},bytesToString:function(e){return decodeURIComponent(escape(t.bin.bytesToString(e)))}},bin:{stringToBytes:function(e){for(var n=[],o=0;o<e.length;o++)n.push(e.charCodeAt(o)&255);return n},bytesToString:function(e){for(var n=[],o=0;o<e.length;o++)n.push(String.fromCharCode(e[o]));return n.join("")}}};return charenc_1=t,charenc_1}/*!
1061
1061
  * Determine if an object is a Buffer
@@ -1127,7 +1127,8 @@ Please report this to https://github.com/markedjs/marked.`,t){const o="<p>An err
1127
1127
  - Do not include <html>, <head>, <body>, or markdown \`\`\` fences. Output only the content itself.`:"Provide a helpful, concise response in plain text. Do not use any HTML tags or markdown formatting."}
1128
1128
  ---
1129
1129
  Prompt: "${e}"
1130
- `;try{const g=new GoogleGenAI({apiKey:t}),b=n?"gemini-2.5-pro":"gemini-2.5-flash";return(await g.chats.create({model:b}).sendMessage({message:f})).text??"Sorry, I couldn't generate a response for this."}catch(g){if(console.error("Error fetching AI response:",g),l>0)return await new Promise(b=>setTimeout(b,(4-l)*500)),fetchGeminiResponse(t,e,n,o,l-1);throw new Error("An error occurred while generating the response.")}},useGemini=(t={})=>{const{useProModel:e=!1,outputFormat:n="html"}=t,[o,l]=React.useState(null),[d,f]=React.useState(!1),[g,b]=React.useState(null),{apiKey:S}=useGeminiApiKey(),_=React.useRef(null),R=React.useCallback(async C=>{if(!S){b("API Key is required.");return}_.current=C;const E=`${C}::${n}`;if(resultCache.has(E)){const I=resultCache.get(E);return _.current===C&&(l(I),f(!1),b(null)),I}if(requestCache.has(E)){f(!0);try{return await requestCache.get(E)}catch(I){_.current===C&&b(I instanceof Error?I.message:"An unknown error occurred.");return}finally{_.current===C&&f(!1)}}f(!0),b(null);const A=fetchGeminiResponse(S,C,e,n).then(I=>{const M=cleanResponseString(I,n);return resultCache.set(E,M),M}).finally(()=>{requestCache.delete(E)});requestCache.set(E,A);try{const I=await A;return _.current===C&&l(I),I}catch(I){_.current===C&&b(I instanceof Error?I.message:"An unknown error occurred.");return}finally{_.current===C&&f(!1)}},[S,e,n]);return{response:o,isLoading:d,error:g,sendPrompt:R}},STORAGE_KEY="appConfig",defaultConfig={assistantThinkHarder:!1,assistantCachedPreloading:!1,assistantDynamicPreloading:!1},useConfig=()=>{const[t,e]=React.useState(()=>{try{const n=window.localStorage.getItem(STORAGE_KEY);if(n){const o=JSON.parse(n);return{...defaultConfig,...o}}return defaultConfig}catch(n){return console.warn(`Error reading or parsing localStorage key "${STORAGE_KEY}":`,n),defaultConfig}});return React.useEffect(()=>{try{window.localStorage.setItem(STORAGE_KEY,JSON.stringify(t))}catch(n){console.warn(`Error setting localStorage key "${STORAGE_KEY}":`,n)}},[t]),[t,e]},ASSISTANT_ID="RandmarAIChatAssistant",sortChats=(t,e)=>t.unread>0&&e.unread===0?-1:e.unread>0&&t.unread===0?1:t.name.localeCompare(e.name),ChatLayout=React.forwardRef(({userId:t,userName:e,inputRef:n,assistantOnly:o,className:l,initialPrompt:d},f)=>{const{setHasUnreads:g}=useChat(),{data:b,refetch:S}=useGetV4PartnerByRouteApplicationIdBusinessDevelopmentConversationsQuery({routeApplicationId:t},{skip:o===!0}),[_,R]=React.useState(!1),[C]=usePostV4PartnerByApplicationIdAccountDebugFeedbackMutation(),[E,{isLoading:A}]=usePostV4PartnerByRouteApplicationIdBusinessDevelopmentConversationPartnerAndPartnerIdMutation(),[I,M]=useConfig(),V=React.useRef(null),O=React.useRef(!1),[z]=useLazyGetV4PartnerByApplicationIdAccountQuery(),{sendPrompt:Q}=useGemini({outputFormat:"text",useProModel:!0}),[j,F]=React.useState(!1),[te]=usePostV4PartnerByRouteApplicationIdBusinessDevelopmentConversationPartnerAndPartnerIdMutation(),[ne]=usePostV4PartnerByRouteApplicationIdBusinessDevelopmentConversationAndConversationIdReadMutation(),[ae]=useLazyGetV4PartnerByRouteApplicationIdBusinessDevelopmentConversationAndConversationIdMessagesQuery(),{handleSubmitToBot:je,botMessages:Ae,clearBotMessages:se,botReady:Ne,debugMessages:ge,botStatus:Ve,reset:Le}=useAIAssistant({userId:t,config:I});React.useEffect(()=>{const it={partner1:t,partner2:ASSISTANT_ID,name:"Randmar Assistant",unread:0,pending:!1,messages:[],conversationID:-1};if(o===!0){Qe([it]);return}if(!b)return;(async()=>{const Xt=b.map(async sn=>{var $n,Pn,Dn;const mn=await ae({routeApplicationId:t,conversationId:sn.ConversationId});return{partner1:sn.Participant1,partner2:sn.Participant2,name:(($n=sn.Participant)==null?void 0:$n.PublicName)??"missing public name",unread:((Pn=mn.data)==null?void 0:Pn.filter(bn=>!bn.Read&&bn.SenderId!=t).length)??0,pending:sn.Status!=="Approved",messages:((Dn=mn.data)==null?void 0:Dn.map(bn=>({id:"history"+bn.MessageId,fromPartnerID:bn.SenderId,toPartnerID:bn.SenderId==sn.Participant1?sn.Participant2:sn.Participant1,senderName:bn.SenderName??"missing name",timestamp:new Date(bn.SentDate+"Z").getTime(),content:bn.Content??"no content"})))??[],conversationID:sn.ConversationId}}),dn=await Promise.all(Xt);dn.sort(sortChats),Qe([it,...dn]),setTimeout(()=>{var sn;return(sn=Vt.current)==null?void 0:sn.focus()},50)})()},[b,o,t]);const[qe,Be]=React.useState("approved"),[$e,He]=React.useState([t,ASSISTANT_ID]),[We,Ue]=React.useState(""),[Ke,tt]=React.useState(null),[Ge,Qe]=React.useState([]),[Xe,ot]=React.useState(""),[Ze,at]=React.useState(null),lt=React.useRef(null),ze=React.useRef(null),[yt,et]=React.useState(null),[Rt,$t]=React.useState([]),[Ft,Wt]=React.useState([]),Vt=n||ze,Je=React.useRef(null),{toast:rt}=useToast(),st=()=>Ge.find(it=>it.partner1===($e==null?void 0:$e[0])&&it.partner2===($e==null?void 0:$e[1])),pt=()=>($e==null?void 0:$e[0])===ASSISTANT_ID||($e==null?void 0:$e[1])===ASSISTANT_ID;function ft(){const it=st();it&&(pt()||ne({routeApplicationId:t,conversationId:it.conversationID}))}React.useEffect(()=>{d&&Ne&&(O.current||pt()&&Zt&&(O.current=!0,Ut(Zt,d)))},[d,Ne,$e,O]);const dt=React.useMemo(()=>Ge.filter(it=>{if(it.partner1===ASSISTANT_ID||it.partner2===ASSISTANT_ID)return!0;const Xt=it.name.toLowerCase().includes(Xe.toLowerCase());return qe==="approved"?Xt&&!it.pending:qe==="pending"?Xt&&it.pending:Xt}),[Ge,Xe,qe]);React.useEffect(()=>{var it;yt!==null&&(rt({title:"File attached",description:"Add your instruction before sending.",variant:"success"}),(it=Vt.current)==null||it.focus())},[yt]),React.useEffect(()=>{Ae.length!==0&&(Ae.forEach(it=>{if(!it||it.isComponent)return;const Ht={id:it.timestamp.toString(),fromPartnerID:ASSISTANT_ID,toPartnerID:t,senderName:"Assistant",timestamp:it.timestamp.getTime(),content:it.content};mt(Ht)}),se())},[Ae]);const mt=it=>Wt(Ht=>[...Ht,it]);React.useEffect(()=>{if(Ft.length==0)return;console.log(Ft.length,"unprocessedMessages detected");const it=(Xt,dn)=>dn.partner1===Xt.toPartnerID&&dn.partner2===Xt.fromPartnerID||dn.partner2===Xt.toPartnerID&&dn.partner1===Xt.fromPartnerID;let Ht=!1;Ft.forEach(Xt=>{if(!Ge.some(dn=>it(Xt,dn))){console.log("message received for unknown convo ID - need to refetch!"),Ht=!0;return}Qe(dn=>dn.map(sn=>{if(!it(Xt,sn)||sn.messages.some(Pn=>Pn.id===Xt.id))return sn;let mn=1;const $n=document.activeElement&&document.activeElement===Vt.current;return($e==null?void 0:$e[0])==sn.partner1&&$e[1]==sn.partner2&&$n&&(mn=0,ft(),setTimeout(()=>{var Pn;return(Pn=lt.current)==null?void 0:Pn.scrollIntoView({behavior:"smooth"})},50),sn.pending&&Be("approved")),{...sn,pending:!1,unread:sn.unread+mn,messages:[...sn.messages,Xt]}}).sort(sortChats))}),console.log("need refetch:",Ht),Ht&&S(),Wt([])},[Ft,Wt,Qe,He,$e]),React.useEffect(()=>{if(o===!0)return;const it=new HubConnectionBuilder().withUrl("https://api.randmar.io/hub",{accessTokenFactory:()=>localStorage.getItem("access_token"),headers:{"X-Impersonated-Id":t}}).configureLogging(LogLevel.Information).withAutomaticReconnect().withHubProtocol(new JsonHubProtocol).build();return it.on("ReceiveMessage",mt),it.start().catch(Ht=>console.error("Error connecting to SignalR hub:",Ht)),at(it),()=>{it&&it.stop()}},[t,o]),React.useEffect(()=>{var Ht;!$e||!st()||(Ht=Vt.current)==null||Ht.focus()},[$e]),React.useEffect(()=>{if(!$e)return;const it=st();if(!it)return;const Ht=document.activeElement&&document.activeElement===Vt.current;it.unread>0&&Ht&&(ft(),Qe(Xt=>Xt.map(dn=>dn.partner1===$e[0]&&dn.partner2===$e[1]?{...dn,unread:0}:dn)))},[$e,Ge]),React.useEffect(()=>{g(Ge.some(it=>it.unread>0))},[Ge,g]);const Ut=(it,Ht)=>{console.log("doSend",Ht),console.log("target",it);const Xt={id:crypto.randomUUID(),senderName:e,fromPartnerID:t,toPartnerID:it.partner1===t?it.partner2:it.partner1,content:Ht+(yt?` (${yt==null?void 0:yt.name} attached)`:""),timestamp:Date.now()};mt(Xt),Xt.toPartnerID==ASSISTANT_ID?(je(Xt.content,yt??void 0),yt&&$t(dn=>[...dn,yt.name])):(console.log("signal R send!"),Ze.invoke("NewMessage",Xt).catch(dn=>console.error("Error sending message:",dn))),Ue(""),et(null),Je.current&&(Je.current.value="")},Jt=(it,Ht)=>tt([it,Ht]);React.useEffect(()=>{if(Ke===null)return;const it=Ge.find(Xt=>Xt.conversationID===Ke[0]);if(!it||(it.pending&&Be("pending"),He([it.partner1,it.partner2]),Ke[0]===-1&&!Ne)||Ke[0]!==-1&&!Ze)return;const Ht=Ke[1];tt(null),Ht&&Ut(it,Ht)},[Ke,Ge,Be,He,Ne,Ze]),React.useImperativeHandle(f,()=>({setActiveChatAndSendMessage:Jt}));const pn=it=>{var Xt;if(!pt())return;const Ht=(Xt=it.clipboardData)==null?void 0:Xt.items;if(Ht){for(let dn=0;dn<Ht.length;dn++)if(Ht[dn].type.indexOf("image")!==-1){const sn=Ht[dn].getAsFile();if(sn){et(sn);return}}}},vn=()=>{!Zt||!We.trim()||!$e||o!==!0&&!Ze||(Zt.unread>0&&(ft(),Qe(it=>it.map(Ht=>Ht.partner1===$e[0]&&Ht.partner2===$e[1]?{...Ht,unread:0}:Ht))),Ut(Zt,We))},qt=it=>{it.target.files&&it.target.files[0]?et(it.target.files[0]):et(null)},En=()=>{var it;(it=Je.current)==null||it.click()},Rn=()=>{var it;et(null),rt({title:"File removed",description:"No file will be sent to the assistant.",variant:"secondary"}),(it=Vt.current)==null||it.focus()},Sn=()=>{const Ht={messages:Ge.find(Xt=>Xt.partner1===ASSISTANT_ID||Xt.partner2===ASSISTANT_ID),debug:ge};R(!0),C({applicationId:t,emailAddress:e,body:Ht}).then(Xt=>{if(Xt.error){console.error(Xt.error),rt({title:"Error",description:"Could not send your feedback. Please try again later.",variant:"destructive"});return}rt({title:"Success",description:"Your feedback has been successfully sent. Thank you!",variant:"success"})}).catch(Xt=>{console.error(Xt),rt({title:"Error",description:"Could not send your feedback. Please try again later.",variant:"destructive"})}).finally(()=>{R(!1)})},Cn=async()=>{var it,Ht,Xt,dn,sn;V.current&&(V.current.disabled=!0),F(!0);try{const mn=await z({applicationId:t}),$n=((it=mn.data)==null?void 0:it.About)??"a new business venture",Pn=[];(Ht=mn.data)!=null&&Ht.IsManufacturer&&Pn.push("Manufacturer"),(Xt=mn.data)!=null&&Xt.IsReseller&&Pn.push("Reseller"),(dn=mn.data)!=null&&dn.IsSalesAgency&&Pn.push("Sales Agency");const bn=`
1130
+ `;try{const g=new GoogleGenAI({apiKey:t}),b=n?"gemini-2.5-pro":"gemini-2.5-flash";return(await g.chats.create({model:b}).sendMessage({message:f})).text??"Sorry, I couldn't generate a response for this."}catch(g){if(console.error("Error fetching AI response:",g),l>0)return await new Promise(b=>setTimeout(b,(4-l)*500)),fetchGeminiResponse(t,e,n,o,l-1);throw new Error("An error occurred while generating the response.")}},useGemini=(t={})=>{const{useProModel:e=!1,outputFormat:n="html"}=t,[o,l]=React.useState(null),[d,f]=React.useState(!1),[g,b]=React.useState(null),{apiKey:S}=useGeminiApiKey(),_=React.useRef(null),R=React.useCallback(async C=>{if(!S){b("API Key is required.");return}_.current=C;const E=`${C}::${n}`;if(resultCache.has(E)){const I=resultCache.get(E);return _.current===C&&(l(I),f(!1),b(null)),I}if(requestCache.has(E)){f(!0);try{return await requestCache.get(E)}catch(I){_.current===C&&b(I instanceof Error?I.message:"An unknown error occurred.");return}finally{_.current===C&&f(!1)}}f(!0),b(null);const A=fetchGeminiResponse(S,C,e,n).then(I=>{const M=cleanResponseString(I,n);return resultCache.set(E,M),M}).finally(()=>{requestCache.delete(E)});requestCache.set(E,A);try{const I=await A;return _.current===C&&l(I),I}catch(I){_.current===C&&b(I instanceof Error?I.message:"An unknown error occurred.");return}finally{_.current===C&&f(!1)}},[S,e,n]);return{response:o,isLoading:d,error:g,sendPrompt:R}},STORAGE_KEY="appConfig",defaultConfig={assistantThinkHarder:!1,assistantCachedPreloading:!1,assistantDynamicPreloading:!1},useConfig=()=>{const[t,e]=React.useState(()=>{try{const n=window.localStorage.getItem(STORAGE_KEY);if(n){const o=JSON.parse(n);return{...defaultConfig,...o}}return defaultConfig}catch(n){return console.warn(`Error reading or parsing localStorage key "${STORAGE_KEY}":`,n),defaultConfig}});return React.useEffect(()=>{try{window.localStorage.setItem(STORAGE_KEY,JSON.stringify(t))}catch(n){console.warn(`Error setting localStorage key "${STORAGE_KEY}":`,n)}},[t]),[t,e]},ASSISTANT_ID="RandmarAIChatAssistant",sortChats=(t,e)=>t.unread>0&&e.unread===0?-1:e.unread>0&&t.unread===0?1:t.name.localeCompare(e.name),ChatLayout=React.forwardRef(({userId:t,userName:e,inputRef:n,assistantOnly:o,className:l,initialPrompt:d},f)=>{const{setHasUnreads:g}=useChat(),{data:b,refetch:S}=useGetV4PartnerByRouteApplicationIdBusinessDevelopmentConversationsQuery({routeApplicationId:t},{skip:o===!0}),[_,R]=React.useState(!1),[C]=usePostV4PartnerByApplicationIdAccountDebugFeedbackMutation(),[E,{isLoading:A}]=usePostV4PartnerByRouteApplicationIdBusinessDevelopmentConversationPartnerAndPartnerIdMutation(),[I,M]=useConfig(),V=React.useRef(null),O=React.useRef(!1),[z]=useLazyGetV4PartnerByApplicationIdAccountQuery(),{sendPrompt:Q}=useGemini({outputFormat:"text",useProModel:!0}),[j,F]=React.useState(!1),[te]=usePostV4PartnerByRouteApplicationIdBusinessDevelopmentConversationPartnerAndPartnerIdMutation(),[ne]=usePostV4PartnerByRouteApplicationIdBusinessDevelopmentConversationAndConversationIdReadMutation(),[ae]=useLazyGetV4PartnerByRouteApplicationIdBusinessDevelopmentConversationAndConversationIdMessagesQuery(),{handleSubmitToBot:je,botMessages:Ae,clearBotMessages:se,botReady:Ne,debugMessages:ge,botStatus:Ve,reset:Le}=useAIAssistant({userId:t,config:I});React.useEffect(()=>{const it={partner1:t,partner2:ASSISTANT_ID,name:"Randmar Assistant",unread:0,pending:!1,messages:[],conversationID:-1};if(o===!0){Qe([it]);return}if(!b)return;(async()=>{const Xt=b.map(async sn=>{var $n,Pn,Dn;const mn=await ae({routeApplicationId:t,conversationId:sn.ConversationId});return{partner1:sn.Participant1,partner2:sn.Participant2,name:(($n=sn.Participant)==null?void 0:$n.PublicName)??"missing public name",unread:((Pn=mn.data)==null?void 0:Pn.filter(bn=>!bn.Read&&bn.SenderId!=t).length)??0,pending:sn.Status!=="Approved",messages:((Dn=mn.data)==null?void 0:Dn.map(bn=>({id:"history"+bn.MessageId,fromPartnerID:bn.SenderId,toPartnerID:bn.SenderId==sn.Participant1?sn.Participant2:sn.Participant1,senderName:bn.SenderName??"missing name",timestamp:new Date(bn.SentDate+"Z").getTime(),content:bn.Content??"no content"})))??[],conversationID:sn.ConversationId}}),dn=await Promise.all(Xt);dn.sort(sortChats),Qe([it,...dn]),setTimeout(()=>{var sn;return(sn=Vt.current)==null?void 0:sn.focus()},50)})()},[b,o,t]);const[qe,Be]=React.useState("approved"),[$e,He]=React.useState([t,ASSISTANT_ID]),[We,Ue]=React.useState(""),[Ke,tt]=React.useState(null),[Ge,Qe]=React.useState([]),[Xe,ot]=React.useState(""),[Ze,at]=React.useState(null),lt=React.useRef(null),ze=React.useRef(null),[yt,et]=React.useState(null),[Rt,$t]=React.useState([]),[Ft,Wt]=React.useState([]),Vt=n||ze,Je=React.useRef(null),{toast:rt}=useToast(),st=()=>Ge.find(it=>it.partner1===($e==null?void 0:$e[0])&&it.partner2===($e==null?void 0:$e[1])),pt=()=>($e==null?void 0:$e[0])===ASSISTANT_ID||($e==null?void 0:$e[1])===ASSISTANT_ID;function ft(){const it=st();it&&(pt()||ne({routeApplicationId:t,conversationId:it.conversationID}))}React.useEffect(()=>{d&&Ne&&(O.current||pt()&&Zt&&(O.current=!0,Ut(Zt,d)))},[d,Ne,$e,O]);const dt=React.useMemo(()=>Ge.filter(it=>{if(it.partner1===ASSISTANT_ID||it.partner2===ASSISTANT_ID)return!0;const Xt=it.name.toLowerCase().includes(Xe.toLowerCase());return qe==="approved"?Xt&&!it.pending:qe==="pending"?Xt&&it.pending:Xt}),[Ge,Xe,qe]);React.useEffect(()=>{var it;yt!==null&&(rt({title:"File attached",description:"Add your instruction before sending.",variant:"success"}),(it=Vt.current)==null||it.focus())},[yt]),React.useEffect(()=>{Ae.length!==0&&(Ae.forEach(it=>{if(!it||it.isComponent)return;const Ht={id:it.timestamp.toString(),fromPartnerID:ASSISTANT_ID,toPartnerID:t,senderName:"Assistant",timestamp:it.timestamp.getTime(),content:it.content};mt(Ht)}),se())},[Ae]);const mt=it=>Wt(Ht=>[...Ht,it]);React.useEffect(()=>{if(Ft.length==0)return;console.log(Ft.length,"unprocessedMessages detected");const it=(Xt,dn)=>dn.partner1===Xt.toPartnerID&&dn.partner2===Xt.fromPartnerID||dn.partner2===Xt.toPartnerID&&dn.partner1===Xt.fromPartnerID;let Ht=!1;Ft.forEach(Xt=>{if(!Ge.some(dn=>it(Xt,dn))){console.log("message received for unknown convo ID - need to refetch!"),Ht=!0;return}Qe(dn=>dn.map(sn=>{if(!it(Xt,sn)||sn.messages.some(Pn=>Pn.id===Xt.id))return sn;let mn=1;const $n=document.activeElement&&document.activeElement===Vt.current;return($e==null?void 0:$e[0])==sn.partner1&&$e[1]==sn.partner2&&$n&&(mn=0,ft(),setTimeout(()=>{var Pn;return(Pn=lt.current)==null?void 0:Pn.scrollIntoView({behavior:"smooth"})},50),sn.pending&&Be("approved")),{...sn,pending:!1,unread:sn.unread+mn,messages:[...sn.messages,Xt]}}).sort(sortChats))}),console.log("need refetch:",Ht),Ht&&S(),Wt([])},[Ft,Wt,Qe,He,$e]),React.useEffect(()=>{if(o===!0)return;const it=new HubConnectionBuilder().withUrl("https://api.randmar.io/hub",{accessTokenFactory:()=>localStorage.getItem("access_token"),headers:{"X-Impersonated-Id":t}}).configureLogging(LogLevel.Information).withAutomaticReconnect().withHubProtocol(new JsonHubProtocol).build();return it.on("ReceiveMessage",mt),it.start().catch(Ht=>console.error("Error connecting to SignalR hub:",Ht)),at(it),()=>{it&&it.stop()}},[t,o]),React.useEffect(()=>{var Ht;!$e||!st()||(Ht=Vt.current)==null||Ht.focus()},[$e]),React.useEffect(()=>{if(!$e)return;const it=st();if(!it)return;const Ht=document.activeElement&&document.activeElement===Vt.current;it.unread>0&&Ht&&(ft(),Qe(Xt=>Xt.map(dn=>dn.partner1===$e[0]&&dn.partner2===$e[1]?{...dn,unread:0}:dn)))},[$e,Ge]),React.useEffect(()=>{g(Ge.some(it=>it.unread>0))},[Ge,g]);const Ut=(it,Ht)=>{Ht=Ht.replace(/\n/g,`
1131
+ `),console.log("doSend",Ht),console.log("target",it);const Xt={id:crypto.randomUUID(),senderName:e,fromPartnerID:t,toPartnerID:it.partner1===t?it.partner2:it.partner1,content:Ht+(yt?` (${yt==null?void 0:yt.name} attached)`:""),timestamp:Date.now()};mt(Xt),Xt.toPartnerID==ASSISTANT_ID?(je(Xt.content,yt??void 0),yt&&$t(dn=>[...dn,yt.name])):(console.log("signal R send!"),Ze.invoke("NewMessage",Xt).catch(dn=>console.error("Error sending message:",dn))),Ue(""),et(null),Je.current&&(Je.current.value="")},Jt=(it,Ht)=>tt([it,Ht]);React.useEffect(()=>{if(Ke===null)return;const it=Ge.find(Xt=>Xt.conversationID===Ke[0]);if(!it||(it.pending&&Be("pending"),He([it.partner1,it.partner2]),Ke[0]===-1&&!Ne)||Ke[0]!==-1&&!Ze)return;const Ht=Ke[1];tt(null),Ht&&Ut(it,Ht)},[Ke,Ge,Be,He,Ne,Ze]),React.useImperativeHandle(f,()=>({setActiveChatAndSendMessage:Jt}));const pn=it=>{var Xt;if(!pt())return;const Ht=(Xt=it.clipboardData)==null?void 0:Xt.items;if(Ht){for(let dn=0;dn<Ht.length;dn++)if(Ht[dn].type.indexOf("image")!==-1){const sn=Ht[dn].getAsFile();if(sn){et(sn);return}}}},vn=()=>{!Zt||!We.trim()||!$e||o!==!0&&!Ze||(Zt.unread>0&&(ft(),Qe(it=>it.map(Ht=>Ht.partner1===$e[0]&&Ht.partner2===$e[1]?{...Ht,unread:0}:Ht))),Ut(Zt,We))},qt=it=>{it.target.files&&it.target.files[0]?et(it.target.files[0]):et(null)},En=()=>{var it;(it=Je.current)==null||it.click()},Rn=()=>{var it;et(null),rt({title:"File removed",description:"No file will be sent to the assistant.",variant:"secondary"}),(it=Vt.current)==null||it.focus()},Sn=()=>{const Ht={messages:Ge.find(Xt=>Xt.partner1===ASSISTANT_ID||Xt.partner2===ASSISTANT_ID),debug:ge};R(!0),C({applicationId:t,emailAddress:e,body:Ht}).then(Xt=>{if(Xt.error){console.error(Xt.error),rt({title:"Error",description:"Could not send your feedback. Please try again later.",variant:"destructive"});return}rt({title:"Success",description:"Your feedback has been successfully sent. Thank you!",variant:"success"})}).catch(Xt=>{console.error(Xt),rt({title:"Error",description:"Could not send your feedback. Please try again later.",variant:"destructive"})}).finally(()=>{R(!1)})},Cn=async()=>{var it,Ht,Xt,dn,sn;V.current&&(V.current.disabled=!0),F(!0);try{const mn=await z({applicationId:t}),$n=((it=mn.data)==null?void 0:it.About)??"a new business venture",Pn=[];(Ht=mn.data)!=null&&Ht.IsManufacturer&&Pn.push("Manufacturer"),(Xt=mn.data)!=null&&Xt.IsReseller&&Pn.push("Reseller"),(dn=mn.data)!=null&&dn.IsSalesAgency&&Pn.push("Sales Agency");const bn=`
1131
1132
  Your task is to draft a ready-to-send opening message from a user to the Randmar team.
1132
1133
 
1133
1134
  **Your Persona:** You are an entrepreneur and a ${Pn.length>0?Pn.join("/"):"Entrepreneur"}.
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "randmarcomps",
3
3
  "private": false,
4
- "version": "1.401.0",
4
+ "version": "1.403.0",
5
5
  "description": "The UI library enabling speed and consistency in Randmar frontends.",
6
6
  "type": "module",
7
7
  "files": [