@arena-im/react-sdk-auth 1.11.0-dev.2 → 1.13.0-dev.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/index.umd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("react/jsx-runtime"),require("react"),require("@tanstack/react-query"),require("js-cookie"),require("jwt-decode")):"function"==typeof define&&define.amd?define(["exports","react/jsx-runtime","react","@tanstack/react-query","js-cookie","jwt-decode"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).ArenaReactSDK={},e.jsxRuntime,e.React,e.ReactQuery,e.Cookies,e.jwtDecode)}(this,function(e,t,o,n,r,s){"use strict";const i=o.createContext(void 0),a=({children:e})=>{const[n,r]=o.useState(!1),[s,a]=o.useState(void 0),[u,c]=o.useState(void 0),[l,d]=o.useState(void 0),[k,T]=o.useState(void 0);return t.jsx(i.Provider,{value:{isOpen:n,appName:s,appDescription:u,trackOptions:k,onAuthCompleted:l,openDialog:({trackOptions:e,appName:t,appDescription:o,onAuthCompleted:n})=>{r(!0),T(e),a(t),c(o),d(n)},closeDialog:()=>r(!1),onOpenChange:e=>r(e)},children:e})},u=()=>{const e=o.useContext(i);if(!e)throw new Error("useAuthDialog must be used within an AuthDialogProvider");return e},c=e=>{const t="development"===e;return{profileServiceUrl:t?"https://profile-service-dev.arena.im":"https://profile-service-prd.arena.im",identityServiceUrl:t?"https://token-service-dev.arena.im":"https://token-service-prd.arena.im",refreshTokenApiKey:t?"AIzaSyCJhWFCK3ics9kJ2eSgQD7kWHUsOsJyPdk":"AIzaSyD_a4tNVdFVqgGbTfOGCaZ5pvUHErcE79c",authIframeUrl:t?"https://auth2.dev.arena.im":"https://auth2.arena.im",environment:e,debug:"development"===e}},l=o.createContext(void 0),d=({children:e,environment:o="development"})=>{const n=c(o);return t.jsx(l.Provider,{value:{config:n,environment:o},children:e})},k=()=>{const e=o.useContext(l);if(!e)throw new Error("useConfig must be used within a ConfigProvider");return e},T={"Content-Type":"application/json"};async function p(e,t,o={}){const n=await fetch(t,{...o,method:e,headers:{"Content-Type":"application/json",...o.headers}});if(!n.ok)throw new Error(`Error: ${n.statusText}`);return n.json()}const h=e=>{let t;const o=new Set,n=(e,n)=>{const r="function"==typeof e?e(t):e;if(!Object.is(r,t)){const e=t;t=(null!=n?n:"object"!=typeof r||null===r)?r:Object.assign({},t,r),o.forEach(o=>o(t,e))}},r=()=>t,s={setState:n,getState:r,getInitialState:()=>i,subscribe:e=>(o.add(e),()=>o.delete(e))},i=t=e(n,r,s);return s},f=e=>e;const m=e=>{const t=(e=>e?h(e):h)(e),n=e=>function(e,t=f){const n=o.useSyncExternalStore(e.subscribe,o.useCallback(()=>t(e.getState()),[e,t]),o.useCallback(()=>t(e.getInitialState()),[e,t]));return o.useDebugValue(n),n}(t,e);return Object.assign(n,t),n},y=e=>m,g=e=>(t,o,n)=>{const r=n.subscribe;n.subscribe=(e,t,o)=>{let s=e;if(t){const r=(null==o?void 0:o.equalityFn)||Object.is;let i=e(n.getState());s=o=>{const n=e(o);if(!r(i,n)){const e=i;t(i=n,e)}},(null==o?void 0:o.fireImmediately)&&t(i,i)}return r(s)};return e(t,o,n)};var S,U;e.TokenType=void 0,(S=e.TokenType||(e.TokenType={})).ANONYMOUS="anonymous",S.GUEST="guest",S.PUBLIC="public",S.CUSTOM="custom",e.AuthCookie=void 0,(U=e.AuthCookie||(e.AuthCookie={})).PUBLIC_ID_TOKEN="arena-auth-public-id-token",U.PUBLIC_REFRESH_TOKEN="arena-auth-public-refresh-token",U.ANONYMOUS_ID_TOKEN="arena-auth-anonymous-id-token",U.GUEST_ID_TOKEN="arena-auth-guest-id-token",U.CUSTOM_ID_TOKEN="arena-auth-custom-id-token",U.CUSTOM_USER="arena-auth-custom-user";const C="arena-auth-token-updated";function v(e,t){document.dispatchEvent(new CustomEvent(C,{detail:{...t,type:e}}))}const A={public:{idToken:r.get(e.AuthCookie.PUBLIC_ID_TOKEN)||null,refreshToken:r.get(e.AuthCookie.PUBLIC_REFRESH_TOKEN)||null},anonymous:{idToken:r.get(e.AuthCookie.ANONYMOUS_ID_TOKEN)||null},guest:{idToken:r.get(e.AuthCookie.GUEST_ID_TOKEN)||null},custom:{idToken:r.get(e.AuthCookie.CUSTOM_ID_TOKEN)||null}},E=y()(g((t,o)=>{const n=(n,s,i=!0,a)=>{n===o().tokens.public.idToken&&s===o().tokens.public.refreshToken||(t(e=>({tokens:{...e.tokens,public:{idToken:n,refreshToken:s}}})),r.set(e.AuthCookie.PUBLIC_ID_TOKEN,n,{expires:1/24}),r.set(e.AuthCookie.PUBLIC_REFRESH_TOKEN,s,{expires:30}),i&&v(e.TokenType.PUBLIC,{idToken:n,refreshToken:s,source:a}))},s=(n,s=!0,i)=>{n!==o().tokens.anonymous.idToken&&(t(e=>({tokens:{...e.tokens,anonymous:{idToken:n}}})),r.set(e.AuthCookie.ANONYMOUS_ID_TOKEN,n,{expires:1/24}),s&&v(e.TokenType.ANONYMOUS,{idToken:n,source:i}))},i=(n,s=!0,i)=>{n!==o().tokens.guest.idToken&&(t(e=>({tokens:{...e.tokens,guest:{idToken:n}}})),r.set(e.AuthCookie.GUEST_ID_TOKEN,n,{expires:1/24}),s&&v(e.TokenType.GUEST,{idToken:n,source:i}))},a=(n,s=!0,i)=>{n!==o().tokens.custom.idToken&&(t(e=>({tokens:{...e.tokens,custom:{idToken:n}}})),r.set(e.AuthCookie.CUSTOM_ID_TOKEN,n),s&&v(e.TokenType.CUSTOM,{idToken:n,source:i}))},u=(o=!0,n)=>{r.remove(e.AuthCookie.PUBLIC_ID_TOKEN),r.remove(e.AuthCookie.PUBLIC_REFRESH_TOKEN),t(e=>({tokens:{...e.tokens,public:{idToken:null,refreshToken:null}}})),o&&v(e.TokenType.PUBLIC,{idToken:null,source:n})},c=(o=!0,n)=>{r.remove(e.AuthCookie.ANONYMOUS_ID_TOKEN),t(e=>({tokens:{...e.tokens,anonymous:{idToken:null}}})),o&&v(e.TokenType.ANONYMOUS,{idToken:null,source:n})},l=(o=!0,n)=>{r.remove(e.AuthCookie.GUEST_ID_TOKEN),t(e=>({tokens:{...e.tokens,guest:{idToken:null}}})),o&&v(e.TokenType.GUEST,{idToken:null,source:n})},d=(o=!0,n)=>{r.remove(e.AuthCookie.CUSTOM_ID_TOKEN),localStorage.removeItem(e.AuthCookie.CUSTOM_ID_TOKEN),localStorage.removeItem(e.AuthCookie.CUSTOM_USER),t(e=>({tokens:{...e.tokens,custom:{idToken:null}}})),o&&v(e.TokenType.CUSTOM,{idToken:null,source:n})};return{tokens:A,getToken:e=>o().tokens[e]?.idToken||null,getMostPrivilegedToken:(t=[e.TokenType.PUBLIC,e.TokenType.GUEST,e.TokenType.ANONYMOUS])=>o().tokens.custom.idToken&&t.includes(e.TokenType.CUSTOM)?{type:e.TokenType.CUSTOM,idToken:o().tokens.custom.idToken}:o().tokens.public.idToken&&t.includes(e.TokenType.PUBLIC)?{type:e.TokenType.PUBLIC,idToken:o().tokens.public.idToken}:o().tokens.guest.idToken&&t.includes(e.TokenType.GUEST)?{type:e.TokenType.GUEST,idToken:o().tokens.guest.idToken}:o().tokens.anonymous.idToken&&t.includes(e.TokenType.ANONYMOUS)?{type:e.TokenType.ANONYMOUS,idToken:o().tokens.anonymous.idToken}:null,getRefreshToken:e=>o().tokens[e]?.refreshToken||null,updatePublicTokens:(e,t,o)=>{n(e,t,!0,o)},updateAnonymousToken:(e,t)=>{s(e,!0,t)},updateGuestTokens:(e,t)=>{i(e,!0,t)},updateCustomToken:(e,t)=>{a(e,!0,t)},clearTokens:e=>{u(!0,e),c(!0,e),l(!0,e),d(!0,e)},clearPublicTokens:e=>{u(!0,e)},clearAnonymousTokens:e=>{c(!0,e)},clearGuestTokens:e=>{l(!0,e)},clearCustomTokens:e=>{d(!0,e)},silentUpdatePublicTokens:(e,t)=>{n(e,t,!1)},silentUpdateAnonymousToken:e=>{s(e,!1)},silentUpdateGuestTokens:e=>{i(e,!1)},silentUpdateCustomToken:e=>{a(e,!1)},silentClearPublicTokens:()=>{u(!1)},silentClearAnonymousTokens:()=>{c(!1)},silentClearGuestTokens:()=>{l(!1)},silentClearCustomTokens:()=>{d(!1)}}}));function w(){const t=E(e=>e.silentUpdatePublicTokens),n=E(e=>e.silentUpdateAnonymousToken),r=E(e=>e.silentUpdateGuestTokens),s=E(e=>e.silentUpdateCustomToken),i=E(e=>e.clearTokens),a=E(e=>e.silentClearPublicTokens),u=E(e=>e.silentClearAnonymousTokens),c=E(e=>e.silentClearGuestTokens),l=E(e=>e.silentClearCustomTokens),d=o.useRef(`widget-${Math.random().toString(36).substr(2,9)}`);return o.useEffect(()=>{const o=o=>{const{idToken:i,refreshToken:k,type:T,source:p}=o.detail;if(p!==d.current)switch(T){case e.TokenType.PUBLIC:if(i){if(!k)throw new Error("Refresh token is required for public tokens");t(i,k)}else a();break;case e.TokenType.ANONYMOUS:i?n(i):u();break;case e.TokenType.GUEST:i?r(i):c();break;case e.TokenType.CUSTOM:i?s(i):l()}};return document.addEventListener(C,o),()=>{document.removeEventListener(C,o)}},[t,n,r,s,i,a,u,c,l]),{eventSource:d.current}}function I(){const e=E(e=>e.getToken),t=E(e=>e.getMostPrivilegedToken),o=E(e=>e.getRefreshToken),n=E(e=>e.updatePublicTokens),r=E(e=>e.updateAnonymousToken),s=E(e=>e.updateGuestTokens),i=E(e=>e.updateCustomToken),a=E(e=>e.clearTokens),u=E(e=>e.clearPublicTokens),c=E(e=>e.clearCustomTokens),{eventSource:l}=w();return{getToken:e,getMostPrivilegedToken:t,getRefreshToken:o,updatePublicTokens:(e,t)=>n(e,t,l),updateAnonymousToken:e=>r(e,l),updateGuestTokens:e=>s(e,l),updateCustomToken:e=>i(e,l),clearTokens:()=>a(l),clearPublicTokens:()=>u(l),clearCustomTokens:()=>c(l)}}function O(e){return E(t=>t.tokens[e])}var P,_;function b(){const t=O(e.TokenType.PUBLIC),{refreshPublicTokens:o}=D(),{config:n}=k(),r=n.profileServiceUrl;return{getPublicProfile:async function(e){const t=`${r}/public/users/${e}/profile?fields=bio,photoURL,displayName,location,handle`;return await p("GET",t)},updatePublicProfile:async function(e){const s=`${r}/me/profile/personal`;await async function(e){const{method:t,url:o,options:n={},token:r}=e;if(!r)throw new Error("No authentication token found");const s={...T,...n.headers,Authorization:`Bearer ${r}`},i={...n,method:t,headers:s},a=await fetch(o,i);if(!a.ok){const e=await a.text();if(!e)throw new Error(`Error to process request - ${a.status}`);const{errors:t}=JSON.parse(e)||{};throw new Error(t?.[0]||"Internal server error")}const u=a.headers.get("content-type");if(!u||!u.includes("application/json"))return a;const c=await a.text();if(!c)return null;try{return JSON.parse(c)}catch(e){throw console.error(e),new Error("Invalid JSON response from server")}}({method:"PUT",url:s,options:{body:JSON.stringify(e)},token:t.idToken}),o({refreshTokenApiKey:n.refreshTokenApiKey})}}}e.AnalyticsWidgetType=void 0,(P=e.AnalyticsWidgetType||(e.AnalyticsWidgetType={})).AvatarProfile="avatar-profile",P.AvatarChat="avatar-chat",P.Comments="comments",P.GlobalProfile="global-profile",P.GroupChat="group-chat",P.Polls="polls",P.UniversalSnippet="universal-snippet",e.AnalyticsEvent=void 0,(_=e.AnalyticsEvent||(e.AnalyticsEvent={})).AuthenticationCompleted="Authentication Completed",_.AuthenticationStarted="Authentication Started",_.AuthenticationViewed="Authentication Viewed";const x=y()(g((t,o)=>({user:null,publicProfile:null,refreshedTokenLoaded:!1,setUser:e=>{t({user:e})},setPublicProfile:e=>{t({publicProfile:e})},setUserByTokenId:e=>{try{const o=s.jwtDecode(e),n={uid:o.user_id,displayName:o.safeDisplayName,email:o.email,photoURL:o.safePhotoURL,handle:o.handle};t({user:n})}catch(e){console.error(e)}},logout:()=>{try{const e=E.getState();e.clearPublicTokens(),e.clearCustomTokens(),t({user:null}),document.dispatchEvent(new Event("arena-comments-logout"))}catch(e){console.error(e)}},refreshPublicTokens:async t=>{try{const n=r.get(e.AuthCookie.PUBLIC_REFRESH_TOKEN);if(!n)throw new Error("No refresh token found");const s=`${"https://securetoken.googleapis.com/v1/token?key="}${t.refreshTokenApiKey}`,i=await fetch(s,{method:"POST",body:new URLSearchParams({refresh_token:n,grant_type:"refresh_token"})}),a=await i.json(),{setUserByTokenId:u}=o();u(a.id_token);E.getState().updatePublicTokens(a.id_token,a.refresh_token)}catch(e){console.error(e);const{logout:t}=o();t()}},loadStoredUser:async n=>{const s=r.get(e.AuthCookie.PUBLIC_ID_TOKEN),i=r.get(e.AuthCookie.PUBLIC_REFRESH_TOKEN),a=localStorage.getItem(e.AuthCookie.CUSTOM_ID_TOKEN),u=localStorage.getItem(e.AuthCookie.CUSTOM_USER);if(a&&u){const e=JSON.parse(u);t({user:e});E.getState().updateCustomToken(a)}else if(s){const{setUserByTokenId:e}=o();e(s)}else if(i&&n){const{refreshPublicTokens:e}=o();await e(n)}t({refreshedTokenLoaded:!0})},ssoV2Exchange:async(e,t,n)=>{try{const r=c(n??"production"),i=`${r.profileServiceUrl}/sso/sources/${e}/user`,a=await p("POST",i,{body:JSON.stringify({signedUserData:t})});if(a){const e=s.jwtDecode(a.token),{setUser:t,setPublicProfile:n}=o();t({uid:e?.sub,email:e?.email,displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle}),n({displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle});E.getState().updateCustomToken(a.token)}return a}catch(e){throw console.error("SSO V2 Exchange failed:",e),e}}})));function N(){return x(e=>e.user)}function D(){return{setUser:x(e=>e.setUser),setPublicProfile:x(e=>e.setPublicProfile),logout:x(e=>e.logout),refreshPublicTokens:x(e=>e.refreshPublicTokens),setUserByTokenId:x(e=>e.setUserByTokenId),loadStoredUser:x(e=>e.loadStoredUser),ssoV2Exchange:x(e=>e.ssoV2Exchange)}}function L({children:e}){const{config:t}=k(),r=N(),{setPublicProfile:s,loadStoredUser:i}=D(),{getPublicProfile:a}=b(),{mutateAsync:u}=n.useMutation({mutationFn:a}),c=o.useCallback(async()=>{if(r?.uid){const e=await u(r.uid);s(e)}},[r?.uid,u,s]);return o.useEffect(()=>{c()},[c]),o.useEffect(()=>{i(t)},[t,i]),e}const R="arenaAnonymousId",j="rs_anonymous_id",K="rs_initial_referrer",M="rs_initial_referring_domain";function B(){const e=localStorage.getItem(j);if(e)return e;const t=crypto.randomUUID();return localStorage.setItem(j,t),t}function G(e){const t={};return["utm_source","utm_medium","utm_campaign","utm_term","utm_content"].forEach(o=>{const n=e.searchParams.get(o);n&&(t[o]=n)}),Object.keys(t).length?t:void 0}function $(){const e=window,t=document,o=window.screen,n=new URL(e.location.href);!function(){if(!localStorage.getItem(K)){const e=document.referrer||"$direct",t="$direct"!==e?new URL(e).hostname:"";localStorage.setItem(K,e),localStorage.setItem(M,t)}}();const r=localStorage.getItem(K)||"$direct",s=localStorage.getItem(M)||"";return{channel:"web",anonymousId:B(),locale:navigator.language,userAgent:navigator.userAgent,timezone:Intl.DateTimeFormat().resolvedOptions().timeZone,os:{name:navigator.platform,version:void 0},page:{path:n.pathname,referrer:t.referrer||"$direct",referring_domain:t.referrer?new URL(t.referrer).hostname:"",search:n.search,title:t.title,url:n.toString(),initial_referrer:r,initial_referring_domain:s},screen:{density:e.devicePixelRatio||1,height:o.height,width:o.width,innerHeight:e.innerHeight,innerWidth:e.innerWidth},campaign:G(n)}}function F(e={}){const t={};e.userId&&(t.userId=e.userId);let o=null;try{o=localStorage.getItem(R)}catch(e){console.warn("Failed to access localStorage:",e)}if(e.anonymousId){t.anonymousId=e.anonymousId;try{localStorage.setItem(R,e.anonymousId)}catch(e){console.warn("Failed to save anonymousId to localStorage:",e)}}else if(o)t.anonymousId=o;else{const e="undefined"!=typeof crypto&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)});t.anonymousId=e;try{localStorage.setItem(R,e)}catch(e){console.warn("Failed to save new anonymousId to localStorage:",e)}}return t}function q(){const e=document.querySelector('link[rel="canonical"]');return function(e){try{const t=new URL(e);return t.search="",t.href}catch(t){return console.error("Error clearing search params from URL:",t),e}}(e?.href||window.location.href)}function J(e,t,o){return{properties:{widget_type:e,url:window.location.href,domain:window.location.hostname,title:window.document.title,canonical_url:q(),snippet_id:window.__ARENA__?.snippetId||null,...t},context:$(),timestamp:(new Date).toISOString(),integrations:{All:!0},...F(o)}}function V(e){return{"Content-Type":"application/json",Authorization:"Basic "+btoa(`${e}:`)}}function Y(e){const t=o.useCallback((t,o,n)=>{if(!e)return;const r=(s=e.rsWriteKey,i=e.rsDataPlaneUrl,{page:async(e,t,o)=>{const n=await fetch(`${i}/v1/page`,{method:"POST",headers:V(s),body:JSON.stringify({type:"page",...J(e,t,o)})});if(n.ok)return await n.text();throw new Error("Failed to send page event to Rudderstack")},track:async(e,t,o,n)=>{const r=await fetch(`${i}/v1/track`,{method:"POST",headers:V(s),body:JSON.stringify({event:t,type:"track",...J(e,o,n)})});if(r.ok)return await r.text();throw new Error("Failed to send track event to Rudderstack")}});var s,i;const a={site_id:e.siteId,widget_id:e.widgetId,trigger:e.trigger,...n};r.track(e.widgetType,t,a,o?{userId:o}:void 0)},[e]);return t}function H(){const{appName:n,appDescription:r,trackOptions:s,isOpen:i,closeDialog:a,onAuthCompleted:c}=u(),l=n||"Arena AI Chat",d=r||"Arena AI Chat",{setUser:T}=D(),{updatePublicTokens:p}=I(),{config:h}=k(),f=Y(s);let m=`${h.authIframeUrl}/?app-name=${l}&app-description=${d}`;return m+="&language=en",o.useEffect(()=>{const t=t=>{if("arena-authentication"===t.data?.source)if("canceled"!==t.data?.type)if("authentication-viewed"!==t.data?.type){if("authentication-started"===t.data?.type){const{authType:o}=t.data?.payload||{};return void f(e.AnalyticsEvent.AuthenticationStarted,void 0,{authType:o})}if("authentication-completed"===t.data?.type){const{idToken:o,refreshToken:n,user:r,authType:s,isSignup:i}=t.data?.payload||{};return r?(f(e.AnalyticsEvent.AuthenticationCompleted,r.uid,{is_signup:i,auth_type:s}),c?.(r),p(o,n),T(r),void a()):void console.error("Authentication completed but user data is missing")}}else f(e.AnalyticsEvent.AuthenticationViewed);else a()};return window.addEventListener("message",t),()=>window.removeEventListener("message",t)},[T,p,c,f,a]),i?t.jsx("iframe",{src:m,title:"Arena Authentication",style:{position:"fixed",top:0,left:0,width:"100vw",height:"100vh",zIndex:9999999999}}):null}function W({children:e}){const t=E(e=>e.tokens),n=E(e=>e.updateAnonymousToken),{getAnonymousIdentityToken:r}=function(){const{config:e}=k(),t=e.identityServiceUrl;return{getAnonymousIdentityToken:async function(){const e=`${t}/anonymous-token`;return await p("POST",e)}}}();return o.useEffect(()=>{t.anonymous.idToken||r().then(e=>{n(e.access_token)})},[t.anonymous.idToken,n,r]),e}e.AuthProvider=function({children:e,queryClient:o,environment:r}){return o=o||new n.QueryClient,t.jsx(n.QueryClientProvider,{client:o,children:t.jsx(d,{environment:r,children:t.jsx(L,{children:t.jsx(a,{children:t.jsxs(W,{children:[e,t.jsx(H,{})]})})})})})},e.useAuthDialog=u,e.usePublicProfile=function(){return x(e=>e.publicProfile)},e.useRefreshToken=function(e){return E(t=>t.tokens[e]?.refreshToken)},e.useRefreshedTokenLoaded=function(){return x(e=>e.refreshedTokenLoaded)},e.useToken=O,e.useTokenEventListener=w,e.useTokenStore=E,e.useTokenValue=function(e){return E(t=>t.tokens[e]?.idToken)},e.useTokens=I,e.useUpdateProfile=function(){const{updatePublicProfile:e}=b();return{updatePublicProfile:e}},e.useUser=N,e.useUserActions=D,e.useUserStore=x,e.useUserWithProfile=function(){return{user:x(e=>e.user),publicProfile:x(e=>e.publicProfile),refreshedTokenLoaded:x(e=>e.refreshedTokenLoaded)}}});
|
|
2
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.umd.js","sources":["../src/context/auth-dialog-provider.tsx","../src/config/index.ts","../src/context/config-provider.tsx","../src/utils/request.ts","../../../node_modules/.pnpm/zustand@5.0.8_@types+react@19.1.8_react@19.1.0/node_modules/zustand/esm/vanilla.mjs","../../../node_modules/.pnpm/zustand@5.0.8_@types+react@19.1.8_react@19.1.0/node_modules/zustand/esm/react.mjs","../../../node_modules/.pnpm/zustand@5.0.8_@types+react@19.1.8_react@19.1.0/node_modules/zustand/esm/middleware.mjs","../src/types/token.ts","../src/utils/dom-events.ts","../src/stores/token-store.ts","../src/hooks/use-token-event-listener.ts","../src/hooks/use-tokens.ts","../src/types/analytics.ts","../src/services/profile/use-profile-services.ts","../src/stores/user-store.ts","../src/hooks/use-user.ts","../src/context/user-provider.tsx","../src/utils/analytics.ts","../src/utils/url.ts","../src/hooks/use-track.ts","../src/dialog/index.tsx","../src/context/anonymous-token-provider.tsx","../src/services/auth/use-auth-services.ts","../src/context/index.tsx"],"sourcesContent":["import { createContext, useContext, useState, ReactNode } from 'react';\nimport { UserProps } from '../services/auth/types';\nimport { TrackOptions } from '../types/analytics';\n\ninterface AuthDialogContextType {\n  isOpen: boolean;\n  appName: string | undefined;\n  appDescription: string | undefined;\n  trackOptions: TrackOptions | undefined;\n  onAuthCompleted: ((user: UserProps) => void) | undefined;\n  openDialog: (options: OpenDialogOptions) => void;\n  closeDialog: () => void;\n  onOpenChange: (open: boolean) => void;\n}\n\nconst AuthDialogContext = createContext<AuthDialogContextType | undefined>(\n  undefined\n);\n\ntype OpenDialogOptions = {\n  trackOptions: TrackOptions;\n  appName?: string;\n  appDescription?: string;\n  onAuthCompleted?: () => (user: UserProps) => void;\n};\n\nexport const AuthDialogProvider = ({ children }: { children: ReactNode }) => {\n  const [isOpen, setIsOpen] = useState(false);\n  const [appName, setAppName] = useState<string | undefined>(undefined);\n  const [appDescription, setAppDescription] = useState<string | undefined>(\n    undefined\n  );\n  const [onAuthCompleted, setOnAuthCompleted] = useState<\n    ((user: UserProps) => void) | undefined\n  >(undefined);\n  const [trackOptions, setTrackOptions] = useState<TrackOptions | undefined>(\n    undefined\n  );\n  const openDialog = ({\n    trackOptions,\n    appName,\n    appDescription,\n    onAuthCompleted,\n  }: OpenDialogOptions) => {\n    setIsOpen(true);\n    setTrackOptions(trackOptions);\n    setAppName(appName);\n    setAppDescription(appDescription);\n    setOnAuthCompleted(onAuthCompleted);\n  };\n\n  const closeDialog = () => setIsOpen(false);\n  const onOpenChange = (open: boolean) => setIsOpen(open);\n\n  return (\n    <AuthDialogContext.Provider\n      value={{\n        isOpen,\n        appName,\n        appDescription,\n        trackOptions,\n        onAuthCompleted,\n        openDialog,\n        closeDialog,\n        onOpenChange,\n      }}\n    >\n      {children}\n    </AuthDialogContext.Provider>\n  );\n};\n\nexport const useAuthDialog = () => {\n  const context = useContext(AuthDialogContext);\n  if (!context) {\n    throw new Error('useAuthDialog must be used within an AuthDialogProvider');\n  }\n  return context;\n};\n","export interface Config {\n  profileServiceUrl: string;\n  identityServiceUrl: string;\n  refreshTokenApiKey: string;\n  authIframeUrl: string;\n  environment: 'development' | 'production';\n  debug: boolean;\n}\n\nexport type Environment = 'development' | 'production';\n\nexport const getConfig = (environment: Environment): Config => {\n  const isDev = environment === 'development';\n\n  return {\n    profileServiceUrl: isDev\n      ? process.env.PROFILE_SERVICE_URL_DEV ||\n        'https://profile-service-dev.arena.im'\n      : process.env.PROFILE_SERVICE_URL_PRD ||\n        'https://profile-service-prd.arena.im',\n    identityServiceUrl: isDev\n      ? process.env.IDENTITY_SERVICE_URL_DEV ||\n        'https://token-service-dev.arena.im'\n      : process.env.IDENTITY_SERVICE_URL_PRD ||\n        'https://token-service-prd.arena.im',\n    refreshTokenApiKey: isDev\n      ? process.env.FIREBASE_PUBLIC_API_KEY_DEV ||\n        'AIzaSyCJhWFCK3ics9kJ2eSgQD7kWHUsOsJyPdk'\n      : process.env.FIREBASE_PUBLIC_API_KEY_PRD ||\n        'AIzaSyD-9tSrQWn73S0qm6BqEH5-12Hq8L0eTsQ',\n    authIframeUrl: isDev\n      ? process.env.AUTH_IFRAME_URL_DEV || 'https://auth2.dev.arena.im'\n      : process.env.AUTH_IFRAME_URL_PRD || 'https://auth2.arena.im',\n    environment,\n    debug: environment === 'development',\n  };\n};\n","import { createContext, useContext, ReactNode } from 'react';\nimport { getConfig, Environment, Config } from '../config';\n\ninterface ConfigContextType {\n  config: Config;\n  environment: Environment;\n}\n\nconst ConfigContext = createContext<ConfigContextType | undefined>(undefined);\n\ninterface ConfigProviderProps {\n  children: ReactNode;\n  environment?: Environment;\n}\n\nexport const ConfigProvider = ({\n  children,\n  environment = 'development',\n}: ConfigProviderProps) => {\n  const config = getConfig(environment);\n\n  return (\n    <ConfigContext.Provider value={{ config, environment }}>\n      {children}\n    </ConfigContext.Provider>\n  );\n};\n\nexport const useConfig = () => {\n  const context = useContext(ConfigContext);\n  if (!context) {\n    throw new Error('useConfig must be used within a ConfigProvider');\n  }\n  return context;\n};\n","const defaultHeaders = {\n  'Content-Type': 'application/json',\n};\n\nexport async function request(\n  method: string,\n  url: string,\n  options: RequestInit = {}\n) {\n  const response = await fetch(url, {\n    ...options,\n    method,\n    headers: {\n      'Content-Type': 'application/json',\n      ...options.headers,\n    },\n  });\n\n  if (!response.ok) {\n    throw new Error(`Error: ${response.statusText}`);\n  }\n\n  return response.json();\n}\n\nexport async function securedRequest(params: {\n  method: string;\n  url: string;\n  options: RequestInit;\n  token: string;\n}) {\n  const { method, url, options = {}, token } = params;\n  if (!token) {\n    throw new Error('No authentication token found');\n  }\n\n  const headers = {\n    ...defaultHeaders,\n    ...options.headers,\n    Authorization: `Bearer ${token}`,\n  };\n\n  const payload = {\n    ...options,\n    method,\n    headers,\n  };\n\n  const response = await fetch(url, payload);\n\n  if (!response.ok) {\n    const text = await response.text();\n    if (!text) {\n      throw new Error(`Error to process request - ${response.status}`);\n    }\n\n    const { errors } = JSON.parse(text) || {};\n    const errorMessage = errors?.[0] || 'Internal server error';\n    throw new Error(errorMessage);\n  }\n\n  const contentType = response.headers.get('content-type');\n  if (!contentType || !contentType.includes('application/json')) {\n    return response;\n  }\n\n  const text = await response.text();\n  if (!text) {\n    return null;\n  }\n\n  try {\n    return JSON.parse(text);\n  } catch (error) {\n    console.error(error);\n    throw new Error('Invalid JSON response from server');\n  }\n}\n","const createStoreImpl = (createState) => {\n  let state;\n  const listeners = /* @__PURE__ */ new Set();\n  const setState = (partial, replace) => {\n    const nextState = typeof partial === \"function\" ? partial(state) : partial;\n    if (!Object.is(nextState, state)) {\n      const previousState = state;\n      state = (replace != null ? replace : typeof nextState !== \"object\" || nextState === null) ? nextState : Object.assign({}, state, nextState);\n      listeners.forEach((listener) => listener(state, previousState));\n    }\n  };\n  const getState = () => state;\n  const getInitialState = () => initialState;\n  const subscribe = (listener) => {\n    listeners.add(listener);\n    return () => listeners.delete(listener);\n  };\n  const api = { setState, getState, getInitialState, subscribe };\n  const initialState = state = createState(setState, getState, api);\n  return api;\n};\nconst createStore = ((createState) => createState ? createStoreImpl(createState) : createStoreImpl);\n\nexport { createStore };\n","import React from 'react';\nimport { createStore } from 'zustand/vanilla';\n\nconst identity = (arg) => arg;\nfunction useStore(api, selector = identity) {\n  const slice = React.useSyncExternalStore(\n    api.subscribe,\n    React.useCallback(() => selector(api.getState()), [api, selector]),\n    React.useCallback(() => selector(api.getInitialState()), [api, selector])\n  );\n  React.useDebugValue(slice);\n  return slice;\n}\nconst createImpl = (createState) => {\n  const api = createStore(createState);\n  const useBoundStore = (selector) => useStore(api, selector);\n  Object.assign(useBoundStore, api);\n  return useBoundStore;\n};\nconst create = ((createState) => createState ? createImpl(createState) : createImpl);\n\nexport { create, useStore };\n","const reduxImpl = (reducer, initial) => (set, _get, api) => {\n  api.dispatch = (action) => {\n    set((state) => reducer(state, action), false, action);\n    return action;\n  };\n  api.dispatchFromDevtools = true;\n  return { dispatch: (...args) => api.dispatch(...args), ...initial };\n};\nconst redux = reduxImpl;\n\nconst trackedConnections = /* @__PURE__ */ new Map();\nconst getTrackedConnectionState = (name) => {\n  const api = trackedConnections.get(name);\n  if (!api) return {};\n  return Object.fromEntries(\n    Object.entries(api.stores).map(([key, api2]) => [key, api2.getState()])\n  );\n};\nconst extractConnectionInformation = (store, extensionConnector, options) => {\n  if (store === void 0) {\n    return {\n      type: \"untracked\",\n      connection: extensionConnector.connect(options)\n    };\n  }\n  const existingConnection = trackedConnections.get(options.name);\n  if (existingConnection) {\n    return { type: \"tracked\", store, ...existingConnection };\n  }\n  const newConnection = {\n    connection: extensionConnector.connect(options),\n    stores: {}\n  };\n  trackedConnections.set(options.name, newConnection);\n  return { type: \"tracked\", store, ...newConnection };\n};\nconst removeStoreFromTrackedConnections = (name, store) => {\n  if (store === void 0) return;\n  const connectionInfo = trackedConnections.get(name);\n  if (!connectionInfo) return;\n  delete connectionInfo.stores[store];\n  if (Object.keys(connectionInfo.stores).length === 0) {\n    trackedConnections.delete(name);\n  }\n};\nconst findCallerName = (stack) => {\n  var _a, _b;\n  if (!stack) return void 0;\n  const traceLines = stack.split(\"\\n\");\n  const apiSetStateLineIndex = traceLines.findIndex(\n    (traceLine) => traceLine.includes(\"api.setState\")\n  );\n  if (apiSetStateLineIndex < 0) return void 0;\n  const callerLine = ((_a = traceLines[apiSetStateLineIndex + 1]) == null ? void 0 : _a.trim()) || \"\";\n  return (_b = /.+ (.+) .+/.exec(callerLine)) == null ? void 0 : _b[1];\n};\nconst devtoolsImpl = (fn, devtoolsOptions = {}) => (set, get, api) => {\n  const { enabled, anonymousActionType, store, ...options } = devtoolsOptions;\n  let extensionConnector;\n  try {\n    extensionConnector = (enabled != null ? enabled : (import.meta.env ? import.meta.env.MODE : void 0) !== \"production\") && window.__REDUX_DEVTOOLS_EXTENSION__;\n  } catch (e) {\n  }\n  if (!extensionConnector) {\n    return fn(set, get, api);\n  }\n  const { connection, ...connectionInformation } = extractConnectionInformation(store, extensionConnector, options);\n  let isRecording = true;\n  api.setState = ((state, replace, nameOrAction) => {\n    const r = set(state, replace);\n    if (!isRecording) return r;\n    const action = nameOrAction === void 0 ? {\n      type: anonymousActionType || findCallerName(new Error().stack) || \"anonymous\"\n    } : typeof nameOrAction === \"string\" ? { type: nameOrAction } : nameOrAction;\n    if (store === void 0) {\n      connection == null ? void 0 : connection.send(action, get());\n      return r;\n    }\n    connection == null ? void 0 : connection.send(\n      {\n        ...action,\n        type: `${store}/${action.type}`\n      },\n      {\n        ...getTrackedConnectionState(options.name),\n        [store]: api.getState()\n      }\n    );\n    return r;\n  });\n  api.devtools = {\n    cleanup: () => {\n      if (connection && typeof connection.unsubscribe === \"function\") {\n        connection.unsubscribe();\n      }\n      removeStoreFromTrackedConnections(options.name, store);\n    }\n  };\n  const setStateFromDevtools = (...a) => {\n    const originalIsRecording = isRecording;\n    isRecording = false;\n    set(...a);\n    isRecording = originalIsRecording;\n  };\n  const initialState = fn(api.setState, get, api);\n  if (connectionInformation.type === \"untracked\") {\n    connection == null ? void 0 : connection.init(initialState);\n  } else {\n    connectionInformation.stores[connectionInformation.store] = api;\n    connection == null ? void 0 : connection.init(\n      Object.fromEntries(\n        Object.entries(connectionInformation.stores).map(([key, store2]) => [\n          key,\n          key === connectionInformation.store ? initialState : store2.getState()\n        ])\n      )\n    );\n  }\n  if (api.dispatchFromDevtools && typeof api.dispatch === \"function\") {\n    let didWarnAboutReservedActionType = false;\n    const originalDispatch = api.dispatch;\n    api.dispatch = (...args) => {\n      if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\" && args[0].type === \"__setState\" && !didWarnAboutReservedActionType) {\n        console.warn(\n          '[zustand devtools middleware] \"__setState\" action type is reserved to set state from the devtools. Avoid using it.'\n        );\n        didWarnAboutReservedActionType = true;\n      }\n      originalDispatch(...args);\n    };\n  }\n  connection.subscribe((message) => {\n    var _a;\n    switch (message.type) {\n      case \"ACTION\":\n        if (typeof message.payload !== \"string\") {\n          console.error(\n            \"[zustand devtools middleware] Unsupported action format\"\n          );\n          return;\n        }\n        return parseJsonThen(\n          message.payload,\n          (action) => {\n            if (action.type === \"__setState\") {\n              if (store === void 0) {\n                setStateFromDevtools(action.state);\n                return;\n              }\n              if (Object.keys(action.state).length !== 1) {\n                console.error(\n                  `\n                    [zustand devtools middleware] Unsupported __setState action format.\n                    When using 'store' option in devtools(), the 'state' should have only one key, which is a value of 'store' that was passed in devtools(),\n                    and value of this only key should be a state object. Example: { \"type\": \"__setState\", \"state\": { \"abc123Store\": { \"foo\": \"bar\" } } }\n                    `\n                );\n              }\n              const stateFromDevtools = action.state[store];\n              if (stateFromDevtools === void 0 || stateFromDevtools === null) {\n                return;\n              }\n              if (JSON.stringify(api.getState()) !== JSON.stringify(stateFromDevtools)) {\n                setStateFromDevtools(stateFromDevtools);\n              }\n              return;\n            }\n            if (!api.dispatchFromDevtools) return;\n            if (typeof api.dispatch !== \"function\") return;\n            api.dispatch(action);\n          }\n        );\n      case \"DISPATCH\":\n        switch (message.payload.type) {\n          case \"RESET\":\n            setStateFromDevtools(initialState);\n            if (store === void 0) {\n              return connection == null ? void 0 : connection.init(api.getState());\n            }\n            return connection == null ? void 0 : connection.init(getTrackedConnectionState(options.name));\n          case \"COMMIT\":\n            if (store === void 0) {\n              connection == null ? void 0 : connection.init(api.getState());\n              return;\n            }\n            return connection == null ? void 0 : connection.init(getTrackedConnectionState(options.name));\n          case \"ROLLBACK\":\n            return parseJsonThen(message.state, (state) => {\n              if (store === void 0) {\n                setStateFromDevtools(state);\n                connection == null ? void 0 : connection.init(api.getState());\n                return;\n              }\n              setStateFromDevtools(state[store]);\n              connection == null ? void 0 : connection.init(getTrackedConnectionState(options.name));\n            });\n          case \"JUMP_TO_STATE\":\n          case \"JUMP_TO_ACTION\":\n            return parseJsonThen(message.state, (state) => {\n              if (store === void 0) {\n                setStateFromDevtools(state);\n                return;\n              }\n              if (JSON.stringify(api.getState()) !== JSON.stringify(state[store])) {\n                setStateFromDevtools(state[store]);\n              }\n            });\n          case \"IMPORT_STATE\": {\n            const { nextLiftedState } = message.payload;\n            const lastComputedState = (_a = nextLiftedState.computedStates.slice(-1)[0]) == null ? void 0 : _a.state;\n            if (!lastComputedState) return;\n            if (store === void 0) {\n              setStateFromDevtools(lastComputedState);\n            } else {\n              setStateFromDevtools(lastComputedState[store]);\n            }\n            connection == null ? void 0 : connection.send(\n              null,\n              // FIXME no-any\n              nextLiftedState\n            );\n            return;\n          }\n          case \"PAUSE_RECORDING\":\n            return isRecording = !isRecording;\n        }\n        return;\n    }\n  });\n  return initialState;\n};\nconst devtools = devtoolsImpl;\nconst parseJsonThen = (stringified, fn) => {\n  let parsed;\n  try {\n    parsed = JSON.parse(stringified);\n  } catch (e) {\n    console.error(\n      \"[zustand devtools middleware] Could not parse the received json\",\n      e\n    );\n  }\n  if (parsed !== void 0) fn(parsed);\n};\n\nconst subscribeWithSelectorImpl = (fn) => (set, get, api) => {\n  const origSubscribe = api.subscribe;\n  api.subscribe = ((selector, optListener, options) => {\n    let listener = selector;\n    if (optListener) {\n      const equalityFn = (options == null ? void 0 : options.equalityFn) || Object.is;\n      let currentSlice = selector(api.getState());\n      listener = (state) => {\n        const nextSlice = selector(state);\n        if (!equalityFn(currentSlice, nextSlice)) {\n          const previousSlice = currentSlice;\n          optListener(currentSlice = nextSlice, previousSlice);\n        }\n      };\n      if (options == null ? void 0 : options.fireImmediately) {\n        optListener(currentSlice, currentSlice);\n      }\n    }\n    return origSubscribe(listener);\n  });\n  const initialState = fn(set, get, api);\n  return initialState;\n};\nconst subscribeWithSelector = subscribeWithSelectorImpl;\n\nfunction combine(initialState, create) {\n  return (...args) => Object.assign({}, initialState, create(...args));\n}\n\nfunction createJSONStorage(getStorage, options) {\n  let storage;\n  try {\n    storage = getStorage();\n  } catch (e) {\n    return;\n  }\n  const persistStorage = {\n    getItem: (name) => {\n      var _a;\n      const parse = (str2) => {\n        if (str2 === null) {\n          return null;\n        }\n        return JSON.parse(str2, options == null ? void 0 : options.reviver);\n      };\n      const str = (_a = storage.getItem(name)) != null ? _a : null;\n      if (str instanceof Promise) {\n        return str.then(parse);\n      }\n      return parse(str);\n    },\n    setItem: (name, newValue) => storage.setItem(name, JSON.stringify(newValue, options == null ? void 0 : options.replacer)),\n    removeItem: (name) => storage.removeItem(name)\n  };\n  return persistStorage;\n}\nconst toThenable = (fn) => (input) => {\n  try {\n    const result = fn(input);\n    if (result instanceof Promise) {\n      return result;\n    }\n    return {\n      then(onFulfilled) {\n        return toThenable(onFulfilled)(result);\n      },\n      catch(_onRejected) {\n        return this;\n      }\n    };\n  } catch (e) {\n    return {\n      then(_onFulfilled) {\n        return this;\n      },\n      catch(onRejected) {\n        return toThenable(onRejected)(e);\n      }\n    };\n  }\n};\nconst persistImpl = (config, baseOptions) => (set, get, api) => {\n  let options = {\n    storage: createJSONStorage(() => localStorage),\n    partialize: (state) => state,\n    version: 0,\n    merge: (persistedState, currentState) => ({\n      ...currentState,\n      ...persistedState\n    }),\n    ...baseOptions\n  };\n  let hasHydrated = false;\n  const hydrationListeners = /* @__PURE__ */ new Set();\n  const finishHydrationListeners = /* @__PURE__ */ new Set();\n  let storage = options.storage;\n  if (!storage) {\n    return config(\n      (...args) => {\n        console.warn(\n          `[zustand persist middleware] Unable to update item '${options.name}', the given storage is currently unavailable.`\n        );\n        set(...args);\n      },\n      get,\n      api\n    );\n  }\n  const setItem = () => {\n    const state = options.partialize({ ...get() });\n    return storage.setItem(options.name, {\n      state,\n      version: options.version\n    });\n  };\n  const savedSetState = api.setState;\n  api.setState = (state, replace) => {\n    savedSetState(state, replace);\n    return setItem();\n  };\n  const configResult = config(\n    (...args) => {\n      set(...args);\n      return setItem();\n    },\n    get,\n    api\n  );\n  api.getInitialState = () => configResult;\n  let stateFromStorage;\n  const hydrate = () => {\n    var _a, _b;\n    if (!storage) return;\n    hasHydrated = false;\n    hydrationListeners.forEach((cb) => {\n      var _a2;\n      return cb((_a2 = get()) != null ? _a2 : configResult);\n    });\n    const postRehydrationCallback = ((_b = options.onRehydrateStorage) == null ? void 0 : _b.call(options, (_a = get()) != null ? _a : configResult)) || void 0;\n    return toThenable(storage.getItem.bind(storage))(options.name).then((deserializedStorageValue) => {\n      if (deserializedStorageValue) {\n        if (typeof deserializedStorageValue.version === \"number\" && deserializedStorageValue.version !== options.version) {\n          if (options.migrate) {\n            const migration = options.migrate(\n              deserializedStorageValue.state,\n              deserializedStorageValue.version\n            );\n            if (migration instanceof Promise) {\n              return migration.then((result) => [true, result]);\n            }\n            return [true, migration];\n          }\n          console.error(\n            `State loaded from storage couldn't be migrated since no migrate function was provided`\n          );\n        } else {\n          return [false, deserializedStorageValue.state];\n        }\n      }\n      return [false, void 0];\n    }).then((migrationResult) => {\n      var _a2;\n      const [migrated, migratedState] = migrationResult;\n      stateFromStorage = options.merge(\n        migratedState,\n        (_a2 = get()) != null ? _a2 : configResult\n      );\n      set(stateFromStorage, true);\n      if (migrated) {\n        return setItem();\n      }\n    }).then(() => {\n      postRehydrationCallback == null ? void 0 : postRehydrationCallback(stateFromStorage, void 0);\n      stateFromStorage = get();\n      hasHydrated = true;\n      finishHydrationListeners.forEach((cb) => cb(stateFromStorage));\n    }).catch((e) => {\n      postRehydrationCallback == null ? void 0 : postRehydrationCallback(void 0, e);\n    });\n  };\n  api.persist = {\n    setOptions: (newOptions) => {\n      options = {\n        ...options,\n        ...newOptions\n      };\n      if (newOptions.storage) {\n        storage = newOptions.storage;\n      }\n    },\n    clearStorage: () => {\n      storage == null ? void 0 : storage.removeItem(options.name);\n    },\n    getOptions: () => options,\n    rehydrate: () => hydrate(),\n    hasHydrated: () => hasHydrated,\n    onHydrate: (cb) => {\n      hydrationListeners.add(cb);\n      return () => {\n        hydrationListeners.delete(cb);\n      };\n    },\n    onFinishHydration: (cb) => {\n      finishHydrationListeners.add(cb);\n      return () => {\n        finishHydrationListeners.delete(cb);\n      };\n    }\n  };\n  if (!options.skipHydration) {\n    hydrate();\n  }\n  return stateFromStorage || configResult;\n};\nconst persist = persistImpl;\n\nexport { combine, createJSONStorage, devtools, persist, redux, subscribeWithSelector };\n","export enum TokenType {\n  ANONYMOUS = 'anonymous',\n  GUEST = 'guest',\n  PUBLIC = 'public',\n  CUSTOM = 'custom',\n}\n\nexport interface TokenPair {\n  idToken: string | null;\n  refreshToken?: string | null;\n}\n\nexport type TokensMap = Record<TokenType, TokenPair>;\n\nexport enum AuthCookie {\n  PUBLIC_ID_TOKEN = 'arena-auth-public-id-token',\n  PUBLIC_REFRESH_TOKEN = 'arena-auth-public-refresh-token',\n  ANONYMOUS_ID_TOKEN = 'arena-auth-anonymous-id-token',\n  GUEST_ID_TOKEN = 'arena-auth-guest-id-token',\n  CUSTOM_ID_TOKEN = 'arena-auth-custom-id-token',\n  CUSTOM_USER = 'arena-auth-custom-user',\n}\n","import { TokenType } from '../types/token';\n\nexport const TOKEN_UPDATED_EVENT = 'arena-auth-token-updated';\n\ninterface TokenEventParams {\n  idToken: string | null;\n  refreshToken?: string | null;\n  source?: string;\n}\n\nexport function dispatchTokenUpdatedEvent(\n  type: TokenType,\n  params: TokenEventParams\n) {\n  document.dispatchEvent(\n    new CustomEvent(TOKEN_UPDATED_EVENT, {\n      detail: { ...params, type },\n    })\n  );\n}\n","import { create } from 'zustand';\nimport { subscribeWithSelector } from 'zustand/middleware';\nimport Cookies from 'js-cookie';\nimport { AuthCookie, TokensMap, TokenType } from '../types/token';\nimport { dispatchTokenUpdatedEvent } from '../utils/dom-events';\n\ninterface TokenStore {\n  tokens: TokensMap;\n  getToken: (type: TokenType) => string | null;\n  getMostPrivilegedToken: (\n    options?: Array<TokenType>\n  ) => { type: TokenType; idToken: string } | null;\n  getRefreshToken: (type: TokenType) => string | null;\n  updatePublicTokens: (\n    idToken: string,\n    refreshToken: string,\n    source?: string\n  ) => void;\n  updateAnonymousToken: (idToken: string, source?: string) => void;\n  updateGuestTokens: (idToken: string, source?: string) => void;\n  updateCustomToken: (idToken: string, source?: string) => void;\n  clearTokens: (source?: string) => void;\n  clearPublicTokens: (source?: string) => void;\n  clearAnonymousTokens: (source?: string) => void;\n  clearGuestTokens: (source?: string) => void;\n  clearCustomTokens: (source?: string) => void;\n  silentUpdatePublicTokens: (idToken: string, refreshToken: string) => void;\n  silentUpdateAnonymousToken: (idToken: string) => void;\n  silentUpdateGuestTokens: (idToken: string) => void;\n  silentUpdateCustomToken: (idToken: string) => void;\n  silentClearPublicTokens: () => void;\n  silentClearAnonymousTokens: () => void;\n  silentClearGuestTokens: () => void;\n  silentClearCustomTokens: () => void;\n}\n\nconst defaultTokens: TokensMap = {\n  public: {\n    idToken: Cookies.get(AuthCookie.PUBLIC_ID_TOKEN) || null,\n    refreshToken: Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN) || null,\n  },\n  anonymous: {\n    idToken: Cookies.get(AuthCookie.ANONYMOUS_ID_TOKEN) || null,\n  },\n  guest: {\n    idToken: Cookies.get(AuthCookie.GUEST_ID_TOKEN) || null,\n  },\n  custom: {\n    idToken: Cookies.get(AuthCookie.CUSTOM_ID_TOKEN) || null,\n  },\n};\n\nexport const useTokenStore = create<TokenStore>()(\n  subscribeWithSelector((set, get) => {\n    const updatePublicTokensHelper = (\n      idToken: string,\n      refreshToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (\n        idToken === get().tokens.public.idToken &&\n        refreshToken === get().tokens.public.refreshToken\n      ) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          public: {\n            idToken,\n            refreshToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.PUBLIC_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      Cookies.set(AuthCookie.PUBLIC_REFRESH_TOKEN, refreshToken, {\n        expires: 30,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.PUBLIC, {\n          idToken,\n          refreshToken,\n          source,\n        });\n      }\n    };\n\n    const updateAnonymousTokenHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.anonymous.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          anonymous: {\n            idToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.ANONYMOUS_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.ANONYMOUS, { idToken, source });\n      }\n    };\n\n    const updateGuestTokensHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.guest.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          guest: {\n            idToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.GUEST_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.GUEST, { idToken, source });\n      }\n    };\n\n    const updateCustomTokenHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.custom.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          custom: { idToken },\n        },\n      }));\n\n      Cookies.set(AuthCookie.CUSTOM_ID_TOKEN, idToken);\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.CUSTOM, { idToken, source });\n      }\n    };\n\n    const clearPublicTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.PUBLIC_ID_TOKEN);\n      Cookies.remove(AuthCookie.PUBLIC_REFRESH_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          public: { idToken: null, refreshToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.PUBLIC, { idToken: null, source });\n      }\n    };\n\n    const clearAnonymousTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.ANONYMOUS_ID_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          anonymous: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.ANONYMOUS, {\n          idToken: null,\n          source,\n        });\n      }\n    };\n\n    const clearGuestTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.GUEST_ID_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          guest: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.GUEST, { idToken: null, source });\n      }\n    };\n\n    const clearCustomTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.CUSTOM_ID_TOKEN);\n      localStorage.removeItem(AuthCookie.CUSTOM_ID_TOKEN);\n      localStorage.removeItem(AuthCookie.CUSTOM_USER);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          custom: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.CUSTOM, { idToken: null, source });\n      }\n    };\n\n    return {\n      tokens: defaultTokens,\n\n      getToken: (type: TokenType) => {\n        return get().tokens[type]?.idToken || null;\n      },\n\n      getMostPrivilegedToken: (\n        options = [TokenType.PUBLIC, TokenType.GUEST, TokenType.ANONYMOUS]\n      ) => {\n        if (get().tokens.custom.idToken && options.includes(TokenType.CUSTOM)) {\n          return {\n            type: TokenType.CUSTOM,\n            idToken: get().tokens.custom.idToken!,\n          };\n        }\n        if (get().tokens.public.idToken && options.includes(TokenType.PUBLIC)) {\n          return {\n            type: TokenType.PUBLIC,\n            idToken: get().tokens.public.idToken!,\n          };\n        }\n        if (get().tokens.guest.idToken && options.includes(TokenType.GUEST)) {\n          return {\n            type: TokenType.GUEST,\n            idToken: get().tokens.guest.idToken!,\n          };\n        }\n        if (\n          get().tokens.anonymous.idToken &&\n          options.includes(TokenType.ANONYMOUS)\n        ) {\n          return {\n            type: TokenType.ANONYMOUS,\n            idToken: get().tokens.anonymous.idToken!,\n          };\n        }\n        return null;\n      },\n\n      getRefreshToken: (type: TokenType) => {\n        return get().tokens[type]?.refreshToken || null;\n      },\n\n      updatePublicTokens: (\n        idToken: string,\n        refreshToken: string,\n        source?: string\n      ) => {\n        updatePublicTokensHelper(idToken, refreshToken, true, source);\n      },\n\n      updateAnonymousToken: (idToken: string, source?: string) => {\n        updateAnonymousTokenHelper(idToken, true, source);\n      },\n\n      updateGuestTokens: (idToken: string, source?: string) => {\n        updateGuestTokensHelper(idToken, true, source);\n      },\n\n      updateCustomToken: (idToken: string, source?: string) => {\n        updateCustomTokenHelper(idToken, true, source);\n      },\n\n      clearTokens: (source?: string) => {\n        clearPublicTokensHelper(true, source);\n        clearAnonymousTokensHelper(true, source);\n        clearGuestTokensHelper(true, source);\n        clearCustomTokensHelper(true, source);\n      },\n\n      clearPublicTokens: (source?: string) => {\n        clearPublicTokensHelper(true, source);\n      },\n\n      clearAnonymousTokens: (source?: string) => {\n        clearAnonymousTokensHelper(true, source);\n      },\n\n      clearGuestTokens: (source?: string) => {\n        clearGuestTokensHelper(true, source);\n      },\n\n      clearCustomTokens: (source?: string) => {\n        clearCustomTokensHelper(true, source);\n      },\n\n      silentUpdatePublicTokens: (idToken: string, refreshToken: string) => {\n        updatePublicTokensHelper(idToken, refreshToken, false);\n      },\n\n      silentUpdateAnonymousToken: (idToken: string) => {\n        updateAnonymousTokenHelper(idToken, false);\n      },\n\n      silentUpdateGuestTokens: (idToken: string) => {\n        updateGuestTokensHelper(idToken, false);\n      },\n\n      silentUpdateCustomToken: (idToken: string) => {\n        updateCustomTokenHelper(idToken, false);\n      },\n\n      silentClearPublicTokens: () => {\n        clearPublicTokensHelper(false);\n      },\n\n      silentClearAnonymousTokens: () => {\n        clearAnonymousTokensHelper(false);\n      },\n\n      silentClearGuestTokens: () => {\n        clearGuestTokensHelper(false);\n      },\n\n      silentClearCustomTokens: () => {\n        clearCustomTokensHelper(false);\n      },\n    };\n  })\n);\n","import { useEffect, useRef } from 'react';\nimport { TokenType } from '../types/token';\nimport { useTokenStore } from '../stores/token-store';\nimport { TOKEN_UPDATED_EVENT } from '../utils/dom-events';\n\ninterface TokenUpdateEvent {\n  detail: {\n    idToken: string | null;\n    refreshToken?: string | null;\n    type: TokenType;\n    source?: string;\n  };\n}\n\nexport function useTokenEventListener() {\n  const updatePublicTokens = useTokenStore(\n    state => state.silentUpdatePublicTokens\n  );\n  const updateAnonymousToken = useTokenStore(\n    state => state.silentUpdateAnonymousToken\n  );\n  const updateGuestTokens = useTokenStore(\n    state => state.silentUpdateGuestTokens\n  );\n  const updateCustomToken = useTokenStore(\n    state => state.silentUpdateCustomToken\n  );\n  const clearTokens = useTokenStore(state => state.clearTokens);\n  const clearPublicTokens = useTokenStore(\n    state => state.silentClearPublicTokens\n  );\n  const clearAnonymousTokens = useTokenStore(\n    state => state.silentClearAnonymousTokens\n  );\n  const clearGuestTokens = useTokenStore(state => state.silentClearGuestTokens);\n  const clearCustomTokens = useTokenStore(\n    state => state.silentClearCustomTokens\n  );\n\n  const eventSourceRef = useRef<string>(\n    `widget-${Math.random().toString(36).substr(2, 9)}`\n  );\n\n  useEffect(() => {\n    const handleTokenUpdate = (\n      event: CustomEvent<TokenUpdateEvent['detail']>\n    ) => {\n      const { idToken, refreshToken, type, source } = event.detail;\n\n      if (source === eventSourceRef.current) {\n        return;\n      }\n\n      switch (type) {\n        case TokenType.PUBLIC:\n          if (idToken) {\n            if (!refreshToken) {\n              throw new Error('Refresh token is required for public tokens');\n            }\n            updatePublicTokens(idToken, refreshToken);\n          } else {\n            clearPublicTokens();\n          }\n          break;\n\n        case TokenType.ANONYMOUS:\n          if (idToken) {\n            updateAnonymousToken(idToken);\n          } else {\n            clearAnonymousTokens();\n          }\n          break;\n\n        case TokenType.GUEST:\n          if (idToken) {\n            updateGuestTokens(idToken);\n          } else {\n            clearGuestTokens();\n          }\n          break;\n\n        case TokenType.CUSTOM:\n          if (idToken) {\n            updateCustomToken(idToken);\n          } else {\n            clearCustomTokens();\n          }\n          break;\n      }\n    };\n\n    document.addEventListener(\n      TOKEN_UPDATED_EVENT,\n      handleTokenUpdate as EventListener\n    );\n\n    return () => {\n      document.removeEventListener(\n        TOKEN_UPDATED_EVENT,\n        handleTokenUpdate as EventListener\n      );\n    };\n  }, [\n    updatePublicTokens,\n    updateAnonymousToken,\n    updateGuestTokens,\n    updateCustomToken,\n    clearTokens,\n    clearPublicTokens,\n    clearAnonymousTokens,\n    clearGuestTokens,\n    clearCustomTokens,\n  ]);\n\n  return {\n    eventSource: eventSourceRef.current,\n  };\n}\n","import { useTokenStore } from '../stores/token-store';\nimport { useTokenEventListener } from './use-token-event-listener';\n\nexport function useTokens() {\n  const getToken = useTokenStore(state => state.getToken);\n  const getMostPrivilegedToken = useTokenStore(\n    state => state.getMostPrivilegedToken\n  );\n  const getRefreshToken = useTokenStore(state => state.getRefreshToken);\n  const updatePublicTokens = useTokenStore(state => state.updatePublicTokens);\n  const updateAnonymousToken = useTokenStore(\n    state => state.updateAnonymousToken\n  );\n  const updateGuestTokens = useTokenStore(state => state.updateGuestTokens);\n  const updateCustomToken = useTokenStore(state => state.updateCustomToken);\n  const clearTokens = useTokenStore(state => state.clearTokens);\n  const clearPublicTokens = useTokenStore(state => state.clearPublicTokens);\n  const clearCustomTokens = useTokenStore(state => state.clearCustomTokens);\n\n  const { eventSource } = useTokenEventListener();\n\n  return {\n    getToken,\n    getMostPrivilegedToken,\n    getRefreshToken,\n    updatePublicTokens: (idToken: string, refreshToken: string) =>\n      updatePublicTokens(idToken, refreshToken, eventSource),\n    updateAnonymousToken: (idToken: string) =>\n      updateAnonymousToken(idToken, eventSource),\n    updateGuestTokens: (idToken: string) =>\n      updateGuestTokens(idToken, eventSource),\n    updateCustomToken: (idToken: string) =>\n      updateCustomToken(idToken, eventSource),\n    clearTokens: () => clearTokens(eventSource),\n    clearPublicTokens: () => clearPublicTokens(eventSource),\n    clearCustomTokens: () => clearCustomTokens(eventSource),\n  };\n}\n\nexport function useToken(type: 'anonymous' | 'guest' | 'public' | 'custom') {\n  return useTokenStore(state => state.tokens[type]);\n}\n\nexport function useTokenValue(\n  type: 'anonymous' | 'guest' | 'public' | 'custom'\n) {\n  return useTokenStore(state => state.tokens[type]?.idToken);\n}\n\nexport function useRefreshToken(type: 'anonymous' | 'guest' | 'public') {\n  return useTokenStore(state => state.tokens[type]?.refreshToken);\n}\n","type Nullable<T> = T | null;\n\nexport enum AnalyticsWidgetType {\n  AvatarProfile = 'avatar-profile',\n  AvatarChat = 'avatar-chat',\n  Comments = 'comments',\n  GlobalProfile = 'global-profile',\n  GroupChat = 'group-chat',\n  Polls = 'polls',\n  UniversalSnippet = 'universal-snippet',\n}\n\nexport type TrackOptions = {\n  widgetId: string | null;\n  widgetType: AnalyticsWidgetType;\n  siteId: string;\n  rsWriteKey: string;\n  rsDataPlaneUrl: string;\n  trigger: string;\n};\n\nexport enum AnalyticsEvent {\n  AuthenticationCompleted = 'Authentication Completed',\n  AuthenticationStarted = 'Authentication Started',\n  AuthenticationViewed = 'Authentication Viewed',\n}\n\nexport type TrackProps = Nullable<Record<string, unknown>>;\n\nexport interface IdentityProps {\n  anonymousId?: string;\n  userId?: string;\n}\n\nexport interface RudderContext {\n  channel: 'web';\n  anonymousId?: string;\n  locale?: string;\n  userAgent?: string;\n  timezone?: string;\n  os?: { name: string; version?: string };\n  page?: {\n    path?: string;\n    referrer?: string;\n    referring_domain?: string;\n    search?: string;\n    title?: string;\n    url?: string;\n    initial_referrer?: string;\n    initial_referring_domain?: string;\n  };\n  screen?: {\n    density?: number;\n    height?: number;\n    width?: number;\n    innerHeight?: number;\n    innerWidth?: number;\n  };\n  campaign?: Record<string, string>;\n}\n","import { PublicProfile } from './types';\nimport { request, securedRequest } from '../../utils/request';\nimport { useConfig } from '../../context/config-provider';\nimport { useToken } from '../../hooks/use-tokens';\nimport { TokenType } from '../../types';\nimport { useUserActions } from '../../hooks/use-user';\n\nexport function useProfileServices() {\n  const token = useToken(TokenType.PUBLIC);\n  const { refreshPublicTokens } = useUserActions();\n  const { config } = useConfig();\n  const profileUrl = config.profileServiceUrl;\n\n  async function getPublicProfile(userId?: string): Promise<PublicProfile> {\n    const fields = 'bio,photoURL,displayName,location,handle';\n    const url = `${profileUrl}/public/users/${userId}/profile?fields=${fields}`;\n    return await request('GET', url);\n  }\n\n  async function updatePublicProfile(\n    params: Omit<PublicProfile, 'metadata'>\n  ): Promise<void> {\n    const url = `${profileUrl}/me/profile/personal`;\n    await securedRequest({\n      method: 'PUT',\n      url,\n      options: {\n        body: JSON.stringify(params),\n      },\n      token: token.idToken!,\n    });\n    refreshPublicTokens({ refreshTokenApiKey: config.refreshTokenApiKey });\n  }\n  return {\n    getPublicProfile,\n    updatePublicProfile,\n  };\n}\n","import { create } from 'zustand';\nimport { subscribeWithSelector } from 'zustand/middleware';\nimport Cookies from 'js-cookie';\nimport {\n  UserProps,\n  FirebaseUser,\n  SsoUserProps,\n  SsoV2ExchangeResponse,\n} from '../services/auth/types';\nimport { jwtDecode } from 'jwt-decode';\nimport { type PublicProfile } from '../services/profile/types';\nimport { useTokenStore } from './token-store';\nimport { AuthCookie } from '../types/token';\nimport { request } from '../utils/request';\nimport { Environment, getConfig } from '../config';\n\ninterface UserStore {\n  user: UserProps | null;\n  publicProfile: PublicProfile | null;\n  refreshedTokenLoaded: boolean;\n  setUser: (user: UserProps | null) => void;\n  setPublicProfile: (publicProfile: PublicProfile | null) => void;\n  logout: () => void;\n  refreshPublicTokens: (config: {\n    refreshTokenApiKey: string;\n  }) => Promise<void>;\n  setUserByTokenId: (idToken: string) => void;\n  loadStoredUser: (config?: { refreshTokenApiKey: string }) => Promise<void>;\n  ssoV2Exchange: (\n    ssoSourceID: string,\n    jwt: string,\n    env?: Environment\n  ) => Promise<SsoV2ExchangeResponse>;\n}\n\nexport const useUserStore = create<UserStore>()(\n  subscribeWithSelector((set, get) => ({\n    user: null,\n    publicProfile: null,\n    refreshedTokenLoaded: false,\n\n    setUser: (user: UserProps | null) => {\n      set({ user });\n    },\n\n    setPublicProfile: (publicProfile: PublicProfile | null) => {\n      set({ publicProfile });\n    },\n\n    setUserByTokenId: (idToken: string) => {\n      try {\n        const user = jwtDecode<FirebaseUser>(idToken);\n        const userProps: UserProps = {\n          uid: user.user_id,\n          displayName: user.safeDisplayName,\n          email: user.email,\n          photoURL: user.safePhotoURL,\n          handle: user.handle,\n        };\n        set({ user: userProps });\n      } catch (error) {\n        console.error(error);\n      }\n    },\n\n    logout: () => {\n      try {\n        const tokenStore = useTokenStore.getState();\n        tokenStore.clearPublicTokens();\n        tokenStore.clearCustomTokens();\n        set({ user: null });\n        document.dispatchEvent(new Event('arena-comments-logout'));\n      } catch (error) {\n        console.error(error);\n      }\n    },\n\n    refreshPublicTokens: async (config: { refreshTokenApiKey: string }) => {\n      try {\n        const refreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n\n        if (!refreshToken) {\n          throw new Error('No refresh token found');\n        }\n\n        const prefix = 'https://securetoken.googleapis.com/v1/token?key=';\n        const apiKey = config.refreshTokenApiKey;\n        const url = `${prefix}${apiKey}`;\n        const response = await fetch(url, {\n          method: 'POST',\n          body: new URLSearchParams({\n            refresh_token: refreshToken,\n            grant_type: 'refresh_token',\n          }),\n        });\n        const data = await response.json();\n\n        const { setUserByTokenId } = get();\n        setUserByTokenId(data.id_token);\n\n        const tokenStore = useTokenStore.getState();\n        tokenStore.updatePublicTokens(data.id_token, data.refresh_token);\n      } catch (error) {\n        console.error(error);\n        const { logout } = get();\n        logout();\n      }\n    },\n\n    loadStoredUser: async (config?: { refreshTokenApiKey: string }) => {\n      const publicIdToken = Cookies.get(AuthCookie.PUBLIC_ID_TOKEN);\n      const publicRefreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n      const customIdToken = localStorage.getItem(AuthCookie.CUSTOM_ID_TOKEN);\n      const customUser = localStorage.getItem(AuthCookie.CUSTOM_USER);\n\n      if (!!customIdToken && !!customUser) {\n        const parsedUser = JSON.parse(customUser);\n\n        set({ user: parsedUser });\n\n        const tokenStore = useTokenStore.getState();\n        tokenStore.updateCustomToken(customIdToken);\n      } else {\n        if (publicIdToken) {\n          const { setUserByTokenId } = get();\n          setUserByTokenId(publicIdToken);\n        } else if (publicRefreshToken && config) {\n          const { refreshPublicTokens } = get();\n          await refreshPublicTokens(config);\n        }\n      }\n\n      set({ refreshedTokenLoaded: true });\n    },\n\n    ssoV2Exchange: async (\n      ssoSourceID: string,\n      jwt: string,\n      env?: Environment\n    ) => {\n      try {\n        const config = getConfig(env ?? 'production');\n        const profileUrl = config.profileServiceUrl;\n\n        const url = `${profileUrl}/sso/sources/${ssoSourceID}/user`;\n        const response: SsoV2ExchangeResponse = await request('POST', url, {\n          body: JSON.stringify({ signedUserData: jwt }),\n        });\n\n        if (response) {\n          const decodedUser = jwtDecode<SsoUserProps>(response.token);\n\n          const { setUser, setPublicProfile } = get();\n\n          setUser({\n            uid: decodedUser?.sub,\n            email: decodedUser?.email,\n            displayName: decodedUser?.displayName,\n            photoURL: decodedUser?.photoURL,\n            handle: decodedUser?.handle,\n          });\n\n          setPublicProfile({\n            displayName: decodedUser?.displayName,\n            photoURL: decodedUser?.photoURL,\n            handle: decodedUser?.handle,\n          });\n\n          const tokenStore = useTokenStore.getState();\n          tokenStore.updateCustomToken(response.token);\n        }\n\n        return response;\n      } catch (error) {\n        console.error('SSO V2 Exchange failed:', error);\n        throw error;\n      }\n    },\n  }))\n);\n","import { useProfileServices } from '../services/profile/use-profile-services';\nimport { useUserStore } from '../stores/user-store';\n\nexport function useUser() {\n  return useUserStore(state => state.user);\n}\n\nexport function usePublicProfile() {\n  return useUserStore(state => state.publicProfile);\n}\n\nexport function useRefreshedTokenLoaded() {\n  return useUserStore(state => state.refreshedTokenLoaded);\n}\n\nexport function useUserActions() {\n  const setUser = useUserStore(state => state.setUser);\n  const setPublicProfile = useUserStore(state => state.setPublicProfile);\n  const logout = useUserStore(state => state.logout);\n  const refreshPublicTokens = useUserStore(state => state.refreshPublicTokens);\n  const setUserByTokenId = useUserStore(state => state.setUserByTokenId);\n  const loadStoredUser = useUserStore(state => state.loadStoredUser);\n  const ssoV2Exchange = useUserStore(state => state.ssoV2Exchange);\n  \n\n  return {\n    setUser,\n    setPublicProfile,\n    logout,\n    refreshPublicTokens,\n    setUserByTokenId,\n    loadStoredUser,\n    ssoV2Exchange,\n  };\n}\n\nexport function useUpdateProfile() {\n  const { updatePublicProfile } = useProfileServices();\n  return {\n    updatePublicProfile,\n  };\n}\n\nexport function useUserWithProfile() {\n  const user = useUserStore(state => state.user);\n  const publicProfile = useUserStore(state => state.publicProfile);\n  const refreshedTokenLoaded = useUserStore(\n    state => state.refreshedTokenLoaded\n  );\n\n  return {\n    user,\n    publicProfile,\n    refreshedTokenLoaded,\n  };\n}\n\n","import React, { useCallback, useEffect } from 'react';\nimport { useConfig } from './config-provider';\nimport { useUser, useUserActions } from '../hooks/use-user';\nimport { useMutation } from '@tanstack/react-query';\nimport { useProfileServices } from '../services/profile/use-profile-services';\n\nexport function UserProvider({ children }: { children: React.ReactNode }) {\n  const { config } = useConfig();\n  const user = useUser();\n  const { setPublicProfile, loadStoredUser } = useUserActions();\n  const { getPublicProfile: getPublicProfileService } = useProfileServices();\n  const { mutateAsync: getPublicProfile } = useMutation({\n    mutationFn: getPublicProfileService,\n  });\n\n  const loadPublicProfile = useCallback(async () => {\n    if (user?.uid) {\n      const profile = await getPublicProfile(user.uid);\n      setPublicProfile(profile);\n    }\n  }, [user?.uid, getPublicProfile, setPublicProfile]);\n\n  useEffect(() => {\n    loadPublicProfile();\n  }, [loadPublicProfile]);\n\n  useEffect(() => {\n    loadStoredUser(config);\n  }, [config, loadStoredUser]);\n\n  return children;\n}\n","import type {\n  AnalyticsWidgetType,\n  AnalyticsEvent,\n  IdentityProps,\n  RudderContext,\n  TrackProps,\n} from '../types/analytics';\n\nimport { removeParamsFromUrl } from '../utils/url';\n\nconst ANONYMOUS_ID_KEY = 'arenaAnonymousId';\n\nconst LS_KEYS = {\n  anon: 'rs_anonymous_id',\n  initReferrer: 'rs_initial_referrer',\n  initDomain: 'rs_initial_referring_domain',\n} as const;\n\nfunction generateUUID(): string {\n  if (typeof crypto !== 'undefined' && crypto.randomUUID) {\n    return crypto.randomUUID();\n  }\n\n  return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {\n    const r = (Math.random() * 16) | 0;\n    const v = c === 'x' ? r : (r & 0x3) | 0x8;\n    return v.toString(16);\n  });\n}\n\nfunction getOrSetAnonymousId(): string {\n  const existing = localStorage.getItem(LS_KEYS.anon);\n  if (existing) return existing;\n  const id = crypto.randomUUID();\n  localStorage.setItem(LS_KEYS.anon, id);\n  return id;\n}\n\nfunction rememberInitialReferrer(): void {\n  if (!localStorage.getItem(LS_KEYS.initReferrer)) {\n    const ref = document.referrer || '$direct';\n    const domain = ref && ref !== '$direct' ? new URL(ref).hostname : '';\n    localStorage.setItem(LS_KEYS.initReferrer, ref);\n    localStorage.setItem(LS_KEYS.initDomain, domain);\n  }\n}\n\nfunction parseCampaign(u: URL): Record<string, string> | undefined {\n  const keys = [\n    'utm_source',\n    'utm_medium',\n    'utm_campaign',\n    'utm_term',\n    'utm_content',\n  ];\n  const out: Record<string, string> = {};\n  keys.forEach(k => {\n    const v = u.searchParams.get(k);\n    if (v) out[k] = v;\n  });\n  return Object.keys(out).length ? out : undefined;\n}\n\nexport function buildRudderContext(): RudderContext {\n  const w = window;\n  const d = document;\n  const s = window.screen;\n  const url = new URL(w.location.href);\n\n  rememberInitialReferrer();\n\n  const initial_referrer =\n    localStorage.getItem(LS_KEYS.initReferrer) || '$direct';\n  const initial_referring_domain =\n    localStorage.getItem(LS_KEYS.initDomain) || '';\n\n  return {\n    channel: 'web',\n    anonymousId: getOrSetAnonymousId(),\n    locale: navigator.language,\n    userAgent: navigator.userAgent,\n    timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n    os: { name: navigator.platform, version: undefined },\n    page: {\n      path: url.pathname,\n      referrer: d.referrer || '$direct',\n      referring_domain: d.referrer ? new URL(d.referrer).hostname : '',\n      search: url.search,\n      title: d.title,\n      url: url.toString(),\n      initial_referrer,\n      initial_referring_domain,\n    },\n    screen: {\n      density: (w.devicePixelRatio || 1) ?? 1,\n      height: s.height,\n      width: s.width,\n      innerHeight: w.innerHeight,\n      innerWidth: w.innerWidth,\n    },\n    campaign: parseCampaign(url),\n  };\n}\n\nfunction getIdentifier(options: IdentityProps = {}): IdentityProps {\n  const identifier: IdentityProps = {};\n\n  if (options.userId) {\n    identifier.userId = options.userId;\n  }\n\n  let currentAnonymousId: string | null = null;\n\n  try {\n    currentAnonymousId = localStorage.getItem(ANONYMOUS_ID_KEY);\n  } catch (error) {\n    console.warn('Failed to access localStorage:', error);\n  }\n\n  if (options.anonymousId) {\n    identifier.anonymousId = options.anonymousId;\n    try {\n      localStorage.setItem(ANONYMOUS_ID_KEY, options.anonymousId);\n    } catch (error) {\n      console.warn('Failed to save anonymousId to localStorage:', error);\n    }\n  } else if (currentAnonymousId) {\n    identifier.anonymousId = currentAnonymousId;\n  } else {\n    const newAnonymousId = generateUUID();\n    identifier.anonymousId = newAnonymousId;\n    try {\n      localStorage.setItem(ANONYMOUS_ID_KEY, newAnonymousId);\n    } catch (error) {\n      console.warn('Failed to save new anonymousId to localStorage:', error);\n    }\n  }\n\n  return identifier;\n}\n\nfunction getCanonicalUrl(): string {\n  const canonicalMeta = document.querySelector(\n    'link[rel=\"canonical\"]'\n  ) as HTMLLinkElement;\n  const rawUrl = canonicalMeta?.href || window.location.href;\n  return removeParamsFromUrl(rawUrl);\n}\n\nfunction getEventProperties(\n  widgetType: string,\n  properties: TrackProps,\n  identity?: IdentityProps\n) {\n  return {\n    properties: {\n      widget_type: widgetType,\n      url: window.location.href,\n      domain: window.location.hostname,\n      title: window.document.title,\n      canonical_url: getCanonicalUrl(),\n      snippet_id: window.__ARENA__?.snippetId || null,\n      ...properties,\n    },\n    context: buildRudderContext(),\n    timestamp: new Date().toISOString(),\n    integrations: { All: true },\n    ...getIdentifier(identity),\n  };\n}\n\nfunction getEventHeaders(writeKey: string) {\n  return {\n    'Content-Type': 'application/json',\n    Authorization: 'Basic ' + btoa(`${writeKey}:`),\n  };\n}\n\nexport function getAnalytics(writeKey: string, dataPlaneUrl: string) {\n  return {\n    page: async (\n      widgetType: AnalyticsWidgetType,\n      properties: TrackProps,\n      identity?: IdentityProps\n    ) => {\n      const response = await fetch(`${dataPlaneUrl}/v1/page`, {\n        method: 'POST',\n        headers: getEventHeaders(writeKey),\n        body: JSON.stringify({\n          type: 'page',\n          ...getEventProperties(widgetType, properties, identity),\n        }),\n      });\n\n      if (response.ok) {\n        const data = await response.text();\n        return data;\n      } else {\n        throw new Error('Failed to send page event to Rudderstack');\n      }\n    },\n    track: async (\n      widgetType: AnalyticsWidgetType,\n      event: AnalyticsEvent,\n      properties: TrackProps,\n      identity?: IdentityProps\n    ) => {\n      const response = await fetch(`${dataPlaneUrl}/v1/track`, {\n        method: 'POST',\n        headers: getEventHeaders(writeKey),\n        body: JSON.stringify({\n          event,\n          type: 'track',\n          ...getEventProperties(widgetType, properties, identity),\n        }),\n      });\n\n      if (response.ok) {\n        const data = await response.text();\n        return data;\n      } else {\n        throw new Error('Failed to send track event to Rudderstack');\n      }\n    },\n  };\n}\n","export function removeParamsFromUrl(url: string): string {\n  try {\n    const urlObj = new URL(url);\n\n    urlObj.search = '';\n\n    return urlObj.href;\n  } catch (error) {\n    console.error('Error clearing search params from URL:', error);\n    return url;\n  }\n}\n","import { useCallback } from 'react';\nimport { getAnalytics } from '../utils/analytics';\nimport { AnalyticsEvent, TrackOptions } from '../types/analytics';\n\nexport function useTrack(trackOptions?: TrackOptions) {\n  const track = useCallback(\n    (\n      event: AnalyticsEvent,\n      userId?: string,\n      properties?: Record<string, string | null>\n    ) => {\n      if (!trackOptions) return;\n\n      const analytics = getAnalytics(\n        trackOptions.rsWriteKey,\n        trackOptions.rsDataPlaneUrl\n      );\n\n      const trackProperties: Record<string, string | null> = {\n        site_id: trackOptions.siteId,\n        widget_id: trackOptions.widgetId,\n        trigger: trackOptions.trigger,\n        ...properties,\n      };\n\n      analytics.track(\n        trackOptions.widgetType,\n        event,\n        trackProperties,\n        userId ? { userId } : undefined\n      );\n    },\n    [trackOptions]\n  );\n\n  return track;\n}\n","import { useAuthDialog } from '../context/auth-dialog-provider';\nimport { useEffect } from 'react';\nimport { useUserActions } from '../hooks/use-user';\nimport { useConfig } from '../context/config-provider';\nimport { useTokens } from '../hooks/use-tokens';\nimport { AnalyticsEvent } from '../types/analytics';\nimport { useTrack } from '../hooks/use-track';\n\nexport default function AuthDialog() {\n  const {\n    appName,\n    appDescription,\n    trackOptions,\n    isOpen,\n    closeDialog,\n    onAuthCompleted,\n  } = useAuthDialog();\n  const frameAppName = appName || 'Arena AI Chat';\n  const frameAppDescription = appDescription || 'Arena AI Chat';\n  const { setUser } = useUserActions();\n  const { updatePublicTokens } = useTokens();\n  const { config } = useConfig();\n  const language = 'en';\n  const track = useTrack(trackOptions);\n\n  let iframeUrl = `${config.authIframeUrl}/?app-name=${frameAppName}&app-description=${frameAppDescription}`;\n  if (language) {\n    iframeUrl += `&language=${language}`;\n  }\n\n  useEffect(() => {\n    const handler = (message: MessageEvent) => {\n      if (message.data?.source !== 'arena-authentication') return;\n\n      if (message.data?.type === 'canceled') {\n        closeDialog();\n        return;\n      }\n\n      if (message.data?.type === 'authentication-viewed') {\n        track(AnalyticsEvent.AuthenticationViewed);\n        return;\n      }\n\n      if (message.data?.type === 'authentication-started') {\n        const { authType } = message.data?.payload || {};\n        track(AnalyticsEvent.AuthenticationStarted, undefined, {\n          authType: authType,\n        });\n        return;\n      }\n\n      if (message.data?.type === 'authentication-completed') {\n        const { idToken, refreshToken, user, authType, isSignup } =\n          message.data?.payload || {};\n\n        if (!user) {\n          console.error('Authentication completed but user data is missing');\n          return;\n        }\n\n        track(AnalyticsEvent.AuthenticationCompleted, user.uid, {\n          is_signup: isSignup,\n          auth_type: authType,\n        });\n        onAuthCompleted?.(user);\n        updatePublicTokens(idToken, refreshToken);\n        setUser(user);\n        closeDialog();\n        return;\n      }\n    };\n\n    window.addEventListener('message', handler);\n\n    return () => window.removeEventListener('message', handler);\n  }, [setUser, updatePublicTokens, onAuthCompleted, track, closeDialog]);\n\n  return isOpen ? (\n    <iframe\n      src={iframeUrl}\n      title=\"Arena Authentication\"\n      style={{\n        position: 'fixed',\n        top: 0,\n        left: 0,\n        width: '100vw',\n        height: '100vh',\n        zIndex: 9999999999,\n      }}\n    ></iframe>\n  ) : null;\n}\n","import React, { useEffect } from 'react';\nimport { useTokenStore } from '../stores/token-store';\nimport { useAuthServices } from '../services/auth/use-auth-services';\nimport { ExchangeTokensResponse } from '../services/auth/types';\n\nexport function AnonymousTokenProvider({\n  children,\n}: {\n  children: React.ReactNode;\n}) {\n  const tokens = useTokenStore(state => state.tokens);\n  const updateAnonymousToken = useTokenStore(\n    state => state.updateAnonymousToken\n  );\n  const { getAnonymousIdentityToken } = useAuthServices();\n\n  useEffect(() => {\n    if (!tokens.anonymous.idToken) {\n      getAnonymousIdentityToken().then((token: ExchangeTokensResponse) => {\n        updateAnonymousToken(token.access_token);\n      });\n    }\n  }, [\n    tokens.anonymous.idToken,\n    updateAnonymousToken,\n    getAnonymousIdentityToken,\n  ]);\n\n  return children;\n}\n","import { ExchangeTokensResponse } from './types';\nimport { request } from '../../utils/request';\nimport { useConfig } from '../../context/config-provider';\n\nexport function useAuthServices() {\n  const { config } = useConfig();\n  const identityUrl = config.identityServiceUrl;\n\n  async function getAnonymousIdentityToken(): Promise<ExchangeTokensResponse> {\n    const url = `${identityUrl}/anonymous-token`;\n    return await request('POST', url);\n  }\n\n  return {\n    getAnonymousIdentityToken,\n  };\n}\n","import { AuthDialogProvider } from './auth-dialog-provider';\nimport { QueryClient, QueryClientProvider } from '@tanstack/react-query';\nimport { UserProvider } from './user-provider';\nimport { ConfigProvider } from './config-provider';\nimport AuthDialog from '../dialog';\nimport { AnonymousTokenProvider } from './anonymous-token-provider';\n\nexport function AuthProvider({\n  children,\n  queryClient,\n  environment,\n}: {\n  children: React.ReactNode;\n  queryClient?: QueryClient;\n  environment?: 'production' | 'development';\n}) {\n  queryClient = queryClient || new QueryClient();\n\n  return (\n    <QueryClientProvider client={queryClient}>\n      <ConfigProvider environment={environment}>\n        <UserProvider>\n          <AuthDialogProvider>\n            <AnonymousTokenProvider>\n              {children}\n              <AuthDialog />\n            </AnonymousTokenProvider>\n          </AuthDialogProvider>\n        </UserProvider>\n      </ConfigProvider>\n    </QueryClientProvider>\n  );\n}\n\nexport { useAuthDialog } from './auth-dialog-provider';\n"],"names":["AuthDialogContext","createContext","undefined","AuthDialogProvider","children","isOpen","setIsOpen","useState","appName","setAppName","appDescription","setAppDescription","onAuthCompleted","setOnAuthCompleted","trackOptions","setTrackOptions","_jsx","Provider","value","openDialog","closeDialog","onOpenChange","open","useAuthDialog","context","useContext","Error","getConfig","environment","isDev","profileServiceUrl","identityServiceUrl","refreshTokenApiKey","authIframeUrl","debug","ConfigContext","ConfigProvider","config","useConfig","defaultHeaders","async","request","method","url","options","response","fetch","headers","ok","statusText","json","createStoreImpl","createState","state","listeners","Set","setState","partial","replace","nextState","Object","is","previousState","assign","forEach","listener","getState","api","getInitialState","initialState","subscribe","add","delete","identity","arg","createImpl","createStore","useBoundStore","selector","slice","React","useSyncExternalStore","useCallback","useDebugValue","useStore","create","subscribeWithSelector","fn","set","get","origSubscribe","optListener","equalityFn","currentSlice","nextSlice","previousSlice","fireImmediately","TokenType","AuthCookie","TOKEN_UPDATED_EVENT","dispatchTokenUpdatedEvent","type","params","document","dispatchEvent","CustomEvent","detail","defaultTokens","public","idToken","Cookies","PUBLIC_ID_TOKEN","refreshToken","PUBLIC_REFRESH_TOKEN","anonymous","ANONYMOUS_ID_TOKEN","guest","GUEST_ID_TOKEN","custom","CUSTOM_ID_TOKEN","useTokenStore","updatePublicTokensHelper","source","tokens","expires","PUBLIC","updateAnonymousTokenHelper","ANONYMOUS","updateGuestTokensHelper","GUEST","updateCustomTokenHelper","CUSTOM","clearPublicTokensHelper","remove","clearAnonymousTokensHelper","clearGuestTokensHelper","clearCustomTokensHelper","localStorage","removeItem","CUSTOM_USER","getToken","getMostPrivilegedToken","includes","getRefreshToken","updatePublicTokens","updateAnonymousToken","updateGuestTokens","updateCustomToken","clearTokens","clearPublicTokens","clearAnonymousTokens","clearGuestTokens","clearCustomTokens","silentUpdatePublicTokens","silentUpdateAnonymousToken","silentUpdateGuestTokens","silentUpdateCustomToken","silentClearPublicTokens","silentClearAnonymousTokens","silentClearGuestTokens","silentClearCustomTokens","useTokenEventListener","eventSourceRef","useRef","Math","random","toString","substr","useEffect","handleTokenUpdate","event","current","addEventListener","removeEventListener","eventSource","useTokens","useToken","AnalyticsWidgetType","AnalyticsEvent","useProfileServices","token","refreshPublicTokens","useUserActions","profileUrl","getPublicProfile","userId","updatePublicProfile","Authorization","payload","text","status","errors","JSON","parse","contentType","error","console","securedRequest","body","stringify","useUserStore","user","publicProfile","refreshedTokenLoaded","setUser","setPublicProfile","setUserByTokenId","jwtDecode","userProps","uid","user_id","displayName","safeDisplayName","email","photoURL","safePhotoURL","handle","logout","tokenStore","Event","URLSearchParams","refresh_token","grant_type","data","id_token","loadStoredUser","publicIdToken","publicRefreshToken","customIdToken","getItem","customUser","parsedUser","ssoV2Exchange","ssoSourceID","jwt","env","signedUserData","decodedUser","sub","useUser","UserProvider","getPublicProfileService","mutateAsync","useMutation","mutationFn","loadPublicProfile","profile","ANONYMOUS_ID_KEY","LS_KEYS","getOrSetAnonymousId","existing","id","crypto","randomUUID","setItem","parseCampaign","u","out","k","v","searchParams","keys","length","buildRudderContext","w","window","d","s","screen","URL","location","href","ref","referrer","domain","hostname","rememberInitialReferrer","initial_referrer","initial_referring_domain","channel","anonymousId","locale","navigator","language","userAgent","timezone","Intl","DateTimeFormat","resolvedOptions","timeZone","os","name","platform","version","page","path","pathname","referring_domain","search","title","density","devicePixelRatio","height","width","innerHeight","innerWidth","campaign","getIdentifier","identifier","currentAnonymousId","warn","newAnonymousId","c","r","getCanonicalUrl","canonicalMeta","querySelector","urlObj","removeParamsFromUrl","getEventProperties","widgetType","properties","widget_type","canonical_url","snippet_id","__ARENA__","snippetId","timestamp","Date","toISOString","integrations","All","getEventHeaders","writeKey","btoa","useTrack","track","analytics","rsWriteKey","dataPlaneUrl","rsDataPlaneUrl","trackProperties","site_id","siteId","widget_id","widgetId","trigger","AuthDialog","frameAppName","frameAppDescription","iframeUrl","handler","message","authType","AuthenticationStarted","isSignup","AuthenticationCompleted","is_signup","auth_type","AuthenticationViewed","src","style","position","top","left","zIndex","AnonymousTokenProvider","getAnonymousIdentityToken","identityUrl","useAuthServices","then","access_token","queryClient","QueryClient","QueryClientProvider","client","_jsxs"],"mappings":"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","x_google_ignoreList":[4,5,6]}
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("react/jsx-runtime"),require("react"),require("@tanstack/react-query"),require("js-cookie"),require("jwt-decode")):"function"==typeof define&&define.amd?define(["exports","react/jsx-runtime","react","@tanstack/react-query","js-cookie","jwt-decode"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).ArenaReactSDK={},e.jsxRuntime,e.React,e.ReactQuery,e.Cookies,e.jwtDecode)}(this,function(e,t,o,n,r,s){"use strict";const i=o.createContext(void 0),a=({children:e})=>{const[n,r]=o.useState(!1),[s,a]=o.useState(void 0),[u,c]=o.useState(void 0),[l,d]=o.useState(void 0),[k,T]=o.useState(void 0),[p,h]=o.useState(void 0);return t.jsx(i.Provider,{value:{isOpen:n,appName:s,language:p,appDescription:u,trackOptions:k,onAuthCompleted:l,openDialog:({trackOptions:e,appName:t,language:o,appDescription:n,onAuthCompleted:s})=>{r(!0),T(e),a(t),h(o),c(n),d(s)},closeDialog:()=>r(!1),onOpenChange:e=>r(e)},children:e})},u=()=>{const e=o.useContext(i);if(!e)throw new Error("useAuthDialog must be used within an AuthDialogProvider");return e},c=e=>{const t="development"===e;return{profileServiceUrl:t?"https://profile-service-dev.arena.im":"https://profile-service-prd.arena.im",identityServiceUrl:t?"https://token-service-dev.arena.im":"https://token-service-prd.arena.im",refreshTokenApiKey:t?"AIzaSyCJhWFCK3ics9kJ2eSgQD7kWHUsOsJyPdk":"AIzaSyD_a4tNVdFVqgGbTfOGCaZ5pvUHErcE79c",authIframeUrl:t?"https://auth2.dev.arena.im":"https://auth2.arena.im",environment:e,debug:"development"===e}},l=o.createContext(void 0),d=({children:e,environment:o="development"})=>{const n=c(o);return t.jsx(l.Provider,{value:{config:n,environment:o},children:e})},k=()=>{const e=o.useContext(l);if(!e)throw new Error("useConfig must be used within a ConfigProvider");return e},T={"Content-Type":"application/json"};async function p(e,t,o={}){const n=await fetch(t,{...o,method:e,headers:{"Content-Type":"application/json",...o.headers}});if(!n.ok)throw new Error(`Error: ${n.statusText}`);return n.json()}const h=e=>{let t;const o=new Set,n=(e,n)=>{const r="function"==typeof e?e(t):e;if(!Object.is(r,t)){const e=t;t=(null!=n?n:"object"!=typeof r||null===r)?r:Object.assign({},t,r),o.forEach(o=>o(t,e))}},r=()=>t,s={setState:n,getState:r,getInitialState:()=>i,subscribe:e=>(o.add(e),()=>o.delete(e))},i=t=e(n,r,s);return s},f=e=>e;const m=e=>{const t=(e=>e?h(e):h)(e),n=e=>function(e,t=f){const n=o.useSyncExternalStore(e.subscribe,o.useCallback(()=>t(e.getState()),[e,t]),o.useCallback(()=>t(e.getInitialState()),[e,t]));return o.useDebugValue(n),n}(t,e);return Object.assign(n,t),n},y=e=>m,g=e=>(t,o,n)=>{const r=n.subscribe;n.subscribe=(e,t,o)=>{let s=e;if(t){const r=(null==o?void 0:o.equalityFn)||Object.is;let i=e(n.getState());s=o=>{const n=e(o);if(!r(i,n)){const e=i;t(i=n,e)}},(null==o?void 0:o.fireImmediately)&&t(i,i)}return r(s)};return e(t,o,n)};var S,U;e.TokenType=void 0,(S=e.TokenType||(e.TokenType={})).ANONYMOUS="anonymous",S.GUEST="guest",S.PUBLIC="public",S.CUSTOM="custom",e.AuthCookie=void 0,(U=e.AuthCookie||(e.AuthCookie={})).PUBLIC_ID_TOKEN="arena-auth-public-id-token",U.PUBLIC_REFRESH_TOKEN="arena-auth-public-refresh-token",U.ANONYMOUS_ID_TOKEN="arena-auth-anonymous-id-token",U.GUEST_ID_TOKEN="arena-auth-guest-id-token",U.CUSTOM_ID_TOKEN="arena-auth-custom-id-token",U.CUSTOM_USER="arena-auth-custom-user";const C="arena-auth-token-updated";function v(e,t){document.dispatchEvent(new CustomEvent(C,{detail:{...t,type:e}}))}const A={public:{idToken:r.get(e.AuthCookie.PUBLIC_ID_TOKEN)||null,refreshToken:r.get(e.AuthCookie.PUBLIC_REFRESH_TOKEN)||null},anonymous:{idToken:r.get(e.AuthCookie.ANONYMOUS_ID_TOKEN)||null},guest:{idToken:r.get(e.AuthCookie.GUEST_ID_TOKEN)||null},custom:{idToken:r.get(e.AuthCookie.CUSTOM_ID_TOKEN)||null}},E=y()(g((t,o)=>{const n=(n,s,i=!0,a)=>{n===o().tokens.public.idToken&&s===o().tokens.public.refreshToken||(t(e=>({tokens:{...e.tokens,public:{idToken:n,refreshToken:s}}})),r.set(e.AuthCookie.PUBLIC_ID_TOKEN,n,{expires:1/24}),r.set(e.AuthCookie.PUBLIC_REFRESH_TOKEN,s,{expires:30}),i&&v(e.TokenType.PUBLIC,{idToken:n,refreshToken:s,source:a}))},s=(n,s=!0,i)=>{n!==o().tokens.anonymous.idToken&&(t(e=>({tokens:{...e.tokens,anonymous:{idToken:n}}})),r.set(e.AuthCookie.ANONYMOUS_ID_TOKEN,n,{expires:1/24}),s&&v(e.TokenType.ANONYMOUS,{idToken:n,source:i}))},i=(n,s=!0,i)=>{n!==o().tokens.guest.idToken&&(t(e=>({tokens:{...e.tokens,guest:{idToken:n}}})),r.set(e.AuthCookie.GUEST_ID_TOKEN,n,{expires:1/24}),s&&v(e.TokenType.GUEST,{idToken:n,source:i}))},a=(n,s=!0,i)=>{n!==o().tokens.custom.idToken&&(t(e=>({tokens:{...e.tokens,custom:{idToken:n}}})),r.set(e.AuthCookie.CUSTOM_ID_TOKEN,n),s&&v(e.TokenType.CUSTOM,{idToken:n,source:i}))},u=(o=!0,n)=>{r.remove(e.AuthCookie.PUBLIC_ID_TOKEN),r.remove(e.AuthCookie.PUBLIC_REFRESH_TOKEN),t(e=>({tokens:{...e.tokens,public:{idToken:null,refreshToken:null}}})),o&&v(e.TokenType.PUBLIC,{idToken:null,source:n})},c=(o=!0,n)=>{r.remove(e.AuthCookie.ANONYMOUS_ID_TOKEN),t(e=>({tokens:{...e.tokens,anonymous:{idToken:null}}})),o&&v(e.TokenType.ANONYMOUS,{idToken:null,source:n})},l=(o=!0,n)=>{r.remove(e.AuthCookie.GUEST_ID_TOKEN),t(e=>({tokens:{...e.tokens,guest:{idToken:null}}})),o&&v(e.TokenType.GUEST,{idToken:null,source:n})},d=(o=!0,n)=>{r.remove(e.AuthCookie.CUSTOM_ID_TOKEN),localStorage.removeItem(e.AuthCookie.CUSTOM_ID_TOKEN),localStorage.removeItem(e.AuthCookie.CUSTOM_USER),t(e=>({tokens:{...e.tokens,custom:{idToken:null}}})),o&&v(e.TokenType.CUSTOM,{idToken:null,source:n})};return{tokens:A,getToken:e=>o().tokens[e]?.idToken||null,getMostPrivilegedToken:(t=[e.TokenType.PUBLIC,e.TokenType.GUEST,e.TokenType.ANONYMOUS])=>o().tokens.custom.idToken&&t.includes(e.TokenType.CUSTOM)?{type:e.TokenType.CUSTOM,idToken:o().tokens.custom.idToken}:o().tokens.public.idToken&&t.includes(e.TokenType.PUBLIC)?{type:e.TokenType.PUBLIC,idToken:o().tokens.public.idToken}:o().tokens.guest.idToken&&t.includes(e.TokenType.GUEST)?{type:e.TokenType.GUEST,idToken:o().tokens.guest.idToken}:o().tokens.anonymous.idToken&&t.includes(e.TokenType.ANONYMOUS)?{type:e.TokenType.ANONYMOUS,idToken:o().tokens.anonymous.idToken}:null,getRefreshToken:e=>o().tokens[e]?.refreshToken||null,updatePublicTokens:(e,t,o)=>{n(e,t,!0,o)},updateAnonymousToken:(e,t)=>{s(e,!0,t)},updateGuestTokens:(e,t)=>{i(e,!0,t)},updateCustomToken:(e,t)=>{a(e,!0,t)},clearTokens:e=>{u(!0,e),c(!0,e),l(!0,e),d(!0,e)},clearPublicTokens:e=>{u(!0,e)},clearAnonymousTokens:e=>{c(!0,e)},clearGuestTokens:e=>{l(!0,e)},clearCustomTokens:e=>{d(!0,e)},silentUpdatePublicTokens:(e,t)=>{n(e,t,!1)},silentUpdateAnonymousToken:e=>{s(e,!1)},silentUpdateGuestTokens:e=>{i(e,!1)},silentUpdateCustomToken:e=>{a(e,!1)},silentClearPublicTokens:()=>{u(!1)},silentClearAnonymousTokens:()=>{c(!1)},silentClearGuestTokens:()=>{l(!1)},silentClearCustomTokens:()=>{d(!1)}}}));function w(){const t=E(e=>e.silentUpdatePublicTokens),n=E(e=>e.silentUpdateAnonymousToken),r=E(e=>e.silentUpdateGuestTokens),s=E(e=>e.silentUpdateCustomToken),i=E(e=>e.clearTokens),a=E(e=>e.silentClearPublicTokens),u=E(e=>e.silentClearAnonymousTokens),c=E(e=>e.silentClearGuestTokens),l=E(e=>e.silentClearCustomTokens),d=o.useRef(`widget-${Math.random().toString(36).substr(2,9)}`);return o.useEffect(()=>{const o=o=>{const{idToken:i,refreshToken:k,type:T,source:p}=o.detail;if(p!==d.current)switch(T){case e.TokenType.PUBLIC:if(i){if(!k)throw new Error("Refresh token is required for public tokens");t(i,k)}else a();break;case e.TokenType.ANONYMOUS:i?n(i):u();break;case e.TokenType.GUEST:i?r(i):c();break;case e.TokenType.CUSTOM:i?s(i):l()}};return document.addEventListener(C,o),()=>{document.removeEventListener(C,o)}},[t,n,r,s,i,a,u,c,l]),{eventSource:d.current}}function I(){const e=E(e=>e.getToken),t=E(e=>e.getMostPrivilegedToken),o=E(e=>e.getRefreshToken),n=E(e=>e.updatePublicTokens),r=E(e=>e.updateAnonymousToken),s=E(e=>e.updateGuestTokens),i=E(e=>e.updateCustomToken),a=E(e=>e.clearTokens),u=E(e=>e.clearPublicTokens),c=E(e=>e.clearCustomTokens),{eventSource:l}=w();return{getToken:e,getMostPrivilegedToken:t,getRefreshToken:o,updatePublicTokens:(e,t)=>n(e,t,l),updateAnonymousToken:e=>r(e,l),updateGuestTokens:e=>s(e,l),updateCustomToken:e=>i(e,l),clearTokens:()=>a(l),clearPublicTokens:()=>u(l),clearCustomTokens:()=>c(l)}}function O(e){return E(t=>t.tokens[e])}var P,_;function b(){const t=O(e.TokenType.PUBLIC),{refreshPublicTokens:o}=D(),{config:n}=k(),r=n.profileServiceUrl;return{getPublicProfile:async function(e){const t=`${r}/public/users/${e}/profile?fields=bio,photoURL,displayName,location,handle`;return await p("GET",t)},updatePublicProfile:async function(e){const s=`${r}/me/profile/personal`;await async function(e){const{method:t,url:o,options:n={},token:r}=e;if(!r)throw new Error("No authentication token found");const s={...T,...n.headers,Authorization:`Bearer ${r}`},i={...n,method:t,headers:s},a=await fetch(o,i);if(!a.ok){const e=await a.text();if(!e)throw new Error(`Error to process request - ${a.status}`);const{errors:t}=JSON.parse(e)||{};throw new Error(t?.[0]||"Internal server error")}const u=a.headers.get("content-type");if(!u||!u.includes("application/json"))return a;const c=await a.text();if(!c)return null;try{return JSON.parse(c)}catch(e){throw console.error(e),new Error("Invalid JSON response from server")}}({method:"PUT",url:s,options:{body:JSON.stringify(e)},token:t.idToken}),o({refreshTokenApiKey:n.refreshTokenApiKey})}}}e.AnalyticsWidgetType=void 0,(P=e.AnalyticsWidgetType||(e.AnalyticsWidgetType={})).AvatarProfile="avatar-profile",P.AvatarChat="avatar-chat",P.Comments="comments",P.GlobalProfile="global-profile",P.GroupChat="group-chat",P.Polls="polls",P.UniversalSnippet="universal-snippet",e.AnalyticsEvent=void 0,(_=e.AnalyticsEvent||(e.AnalyticsEvent={})).AuthenticationCompleted="Authentication Completed",_.AuthenticationStarted="Authentication Started",_.AuthenticationViewed="Authentication Viewed";const x=y()(g((t,o)=>({user:null,publicProfile:null,refreshedTokenLoaded:!1,setUser:e=>{t({user:e})},setPublicProfile:e=>{t({publicProfile:e})},setUserByTokenId:e=>{try{const o=s.jwtDecode(e),n={uid:o.user_id,displayName:o.safeDisplayName,email:o.email,photoURL:o.safePhotoURL,handle:o.handle};t({user:n})}catch(e){console.error(e)}},logout:()=>{try{const e=E.getState();e.clearPublicTokens(),e.clearCustomTokens(),t({user:null}),document.dispatchEvent(new Event("arena-comments-logout"))}catch(e){console.error(e)}},refreshPublicTokens:async t=>{try{const n=r.get(e.AuthCookie.PUBLIC_REFRESH_TOKEN);if(!n)throw new Error("No refresh token found");const s=`${"https://securetoken.googleapis.com/v1/token?key="}${t.refreshTokenApiKey}`,i=await fetch(s,{method:"POST",body:new URLSearchParams({refresh_token:n,grant_type:"refresh_token"})}),a=await i.json(),{setUserByTokenId:u}=o();u(a.id_token);E.getState().updatePublicTokens(a.id_token,a.refresh_token)}catch(e){console.error(e);const{logout:t}=o();t()}},loadStoredUser:async n=>{const s=r.get(e.AuthCookie.PUBLIC_ID_TOKEN),i=r.get(e.AuthCookie.PUBLIC_REFRESH_TOKEN),a=localStorage.getItem(e.AuthCookie.CUSTOM_ID_TOKEN),u=localStorage.getItem(e.AuthCookie.CUSTOM_USER);if(a&&u){const e=JSON.parse(u);t({user:e});E.getState().updateCustomToken(a)}else if(s){const{setUserByTokenId:e}=o();e(s)}else if(i&&n){const{refreshPublicTokens:e}=o();await e(n)}t({refreshedTokenLoaded:!0})},ssoV2Exchange:async(e,t,n)=>{try{const r=c(n??"production"),i=`${r.profileServiceUrl}/sso/sources/${e}/user`,a=await p("POST",i,{body:JSON.stringify({signedUserData:t})});if(a){const e=s.jwtDecode(a.token),{setUser:t,setPublicProfile:n}=o();t({uid:e?.sub,email:e?.email,displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle}),n({displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle});E.getState().updateCustomToken(a.token)}return a}catch(e){throw console.error("SSO V2 Exchange failed:",e),e}}})));function N(){return x(e=>e.user)}function D(){return{setUser:x(e=>e.setUser),setPublicProfile:x(e=>e.setPublicProfile),logout:x(e=>e.logout),refreshPublicTokens:x(e=>e.refreshPublicTokens),setUserByTokenId:x(e=>e.setUserByTokenId),loadStoredUser:x(e=>e.loadStoredUser),ssoV2Exchange:x(e=>e.ssoV2Exchange)}}function L({children:e}){const{config:t}=k(),r=N(),{setPublicProfile:s,loadStoredUser:i}=D(),{getPublicProfile:a}=b(),{mutateAsync:u}=n.useMutation({mutationFn:a}),c=o.useCallback(async()=>{if(r?.uid){const e=await u(r.uid);s(e)}},[r?.uid,u,s]);return o.useEffect(()=>{c()},[c]),o.useEffect(()=>{i(t)},[t,i]),e}const R="arenaAnonymousId",j="rs_anonymous_id",K="rs_initial_referrer",M="rs_initial_referring_domain";function B(){const e=localStorage.getItem(j);if(e)return e;const t=crypto.randomUUID();return localStorage.setItem(j,t),t}function G(e){const t={};return["utm_source","utm_medium","utm_campaign","utm_term","utm_content"].forEach(o=>{const n=e.searchParams.get(o);n&&(t[o]=n)}),Object.keys(t).length?t:void 0}function $(){const e=window,t=document,o=window.screen,n=new URL(e.location.href);!function(){if(!localStorage.getItem(K)){const e=document.referrer||"$direct",t="$direct"!==e?new URL(e).hostname:"";localStorage.setItem(K,e),localStorage.setItem(M,t)}}();const r=localStorage.getItem(K)||"$direct",s=localStorage.getItem(M)||"";return{channel:"web",anonymousId:B(),locale:navigator.language,userAgent:navigator.userAgent,timezone:Intl.DateTimeFormat().resolvedOptions().timeZone,os:{name:navigator.platform,version:void 0},page:{path:n.pathname,referrer:t.referrer||"$direct",referring_domain:t.referrer?new URL(t.referrer).hostname:"",search:n.search,title:t.title,url:n.toString(),initial_referrer:r,initial_referring_domain:s},screen:{density:e.devicePixelRatio||1,height:o.height,width:o.width,innerHeight:e.innerHeight,innerWidth:e.innerWidth},campaign:G(n)}}function F(e={}){const t={};e.userId&&(t.userId=e.userId);let o=null;try{o=localStorage.getItem(R)}catch(e){console.warn("Failed to access localStorage:",e)}if(e.anonymousId){t.anonymousId=e.anonymousId;try{localStorage.setItem(R,e.anonymousId)}catch(e){console.warn("Failed to save anonymousId to localStorage:",e)}}else if(o)t.anonymousId=o;else{const e="undefined"!=typeof crypto&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)});t.anonymousId=e;try{localStorage.setItem(R,e)}catch(e){console.warn("Failed to save new anonymousId to localStorage:",e)}}return t}function q(){const e=document.querySelector('link[rel="canonical"]');return function(e){try{const t=new URL(e);return t.search="",t.href}catch(t){return console.error("Error clearing search params from URL:",t),e}}(e?.href||window.location.href)}function J(e,t,o){return{properties:{widget_type:e,url:window.location.href,domain:window.location.hostname,title:window.document.title,canonical_url:q(),snippet_id:window.__ARENA__?.snippetId||null,...t},context:$(),timestamp:(new Date).toISOString(),integrations:{All:!0},...F(o)}}function V(e){return{"Content-Type":"application/json",Authorization:"Basic "+btoa(`${e}:`)}}function Y(e){const t=o.useCallback((t,o,n)=>{if(!e)return;const r=(s=e.rsWriteKey,i=e.rsDataPlaneUrl,{page:async(e,t,o)=>{const n=await fetch(`${i}/v1/page`,{method:"POST",headers:V(s),body:JSON.stringify({type:"page",...J(e,t,o)})});if(n.ok)return await n.text();throw new Error("Failed to send page event to Rudderstack")},track:async(e,t,o,n)=>{const r=await fetch(`${i}/v1/track`,{method:"POST",headers:V(s),body:JSON.stringify({event:t,type:"track",...J(e,o,n)})});if(r.ok)return await r.text();throw new Error("Failed to send track event to Rudderstack")}});var s,i;const a={site_id:e.siteId,widget_id:e.widgetId,trigger:e.trigger,...n};r.track(e.widgetType,t,a,o?{userId:o}:void 0)},[e]);return t}function H(){const{appName:n,appDescription:r,language:s,trackOptions:i,isOpen:a,closeDialog:c,onAuthCompleted:l}=u(),d=n||"Arena AI Chat",T=r||"Arena AI Chat",{setUser:p}=D(),{updatePublicTokens:h}=I(),{config:f}=k(),m=Y(i),y=`${f.authIframeUrl}/?app-name=${d}&app-description=${T}&language=${s??"en"}`;return o.useEffect(()=>{const t=t=>{if("arena-authentication"===t.data?.source)if("canceled"!==t.data?.type)if("authentication-viewed"!==t.data?.type){if("authentication-started"===t.data?.type){const{authType:o}=t.data?.payload||{};return void m(e.AnalyticsEvent.AuthenticationStarted,void 0,{authType:o})}if("authentication-completed"===t.data?.type){const{idToken:o,refreshToken:n,user:r,authType:s,isSignup:i}=t.data?.payload||{};return r?(m(e.AnalyticsEvent.AuthenticationCompleted,r.uid,{is_signup:i,auth_type:s}),l?.(r),h(o,n),p(r),void c()):void console.error("Authentication completed but user data is missing")}}else m(e.AnalyticsEvent.AuthenticationViewed);else c()};return window.addEventListener("message",t),()=>window.removeEventListener("message",t)},[p,h,l,m,c]),a?t.jsx("iframe",{src:y,title:"Arena Authentication",style:{position:"fixed",top:0,left:0,width:"100vw",height:"100vh",zIndex:9999999999}}):null}function W({children:e}){const t=E(e=>e.tokens),n=E(e=>e.updateAnonymousToken),{getAnonymousIdentityToken:r}=function(){const{config:e}=k(),t=e.identityServiceUrl;return{getAnonymousIdentityToken:async function(){const e=`${t}/anonymous-token`;return await p("POST",e)}}}();return o.useEffect(()=>{t.anonymous.idToken||r().then(e=>{n(e.access_token)})},[t.anonymous.idToken,n,r]),e}e.AuthProvider=function({children:e,queryClient:o,environment:r}){return o=o||new n.QueryClient,t.jsx(n.QueryClientProvider,{client:o,children:t.jsx(d,{environment:r,children:t.jsx(L,{children:t.jsx(a,{children:t.jsxs(W,{children:[e,t.jsx(H,{})]})})})})})},e.useAuthDialog=u,e.usePublicProfile=function(){return x(e=>e.publicProfile)},e.useRefreshToken=function(e){return E(t=>t.tokens[e]?.refreshToken)},e.useRefreshedTokenLoaded=function(){return x(e=>e.refreshedTokenLoaded)},e.useToken=O,e.useTokenEventListener=w,e.useTokenStore=E,e.useTokenValue=function(e){return E(t=>t.tokens[e]?.idToken)},e.useTokens=I,e.useUpdateProfile=function(){const{updatePublicProfile:e}=b();return{updatePublicProfile:e}},e.useUser=N,e.useUserActions=D,e.useUserStore=x,e.useUserWithProfile=function(){return{user:x(e=>e.user),publicProfile:x(e=>e.publicProfile),refreshedTokenLoaded:x(e=>e.refreshedTokenLoaded)}}});
|
|
2
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.umd.js","sources":["../src/context/auth-dialog-provider.tsx","../src/config/index.ts","../src/context/config-provider.tsx","../src/utils/request.ts","../../../node_modules/.pnpm/zustand@5.0.8_@types+react@19.1.8_react@19.1.0/node_modules/zustand/esm/vanilla.mjs","../../../node_modules/.pnpm/zustand@5.0.8_@types+react@19.1.8_react@19.1.0/node_modules/zustand/esm/react.mjs","../../../node_modules/.pnpm/zustand@5.0.8_@types+react@19.1.8_react@19.1.0/node_modules/zustand/esm/middleware.mjs","../src/types/token.ts","../src/utils/dom-events.ts","../src/stores/token-store.ts","../src/hooks/use-token-event-listener.ts","../src/hooks/use-tokens.ts","../src/types/analytics.ts","../src/services/profile/use-profile-services.ts","../src/stores/user-store.ts","../src/hooks/use-user.ts","../src/context/user-provider.tsx","../src/utils/analytics.ts","../src/utils/url.ts","../src/hooks/use-track.ts","../src/dialog/index.tsx","../src/context/anonymous-token-provider.tsx","../src/services/auth/use-auth-services.ts","../src/context/index.tsx"],"sourcesContent":["import { createContext, useContext, useState, ReactNode } from 'react';\nimport { UserProps } from '../services/auth/types';\nimport { TrackOptions } from '../types/analytics';\n\ninterface AuthDialogContextType {\n  isOpen: boolean;\n  appName: string | undefined;\n  appDescription: string | undefined;\n  language: string | undefined;\n  trackOptions: TrackOptions | undefined;\n  onAuthCompleted: ((user: UserProps) => void) | undefined;\n  openDialog: (options: OpenDialogOptions) => void;\n  closeDialog: () => void;\n  onOpenChange: (open: boolean) => void;\n}\n\nconst AuthDialogContext = createContext<AuthDialogContextType | undefined>(\n  undefined\n);\n\ntype OpenDialogOptions = {\n  trackOptions: TrackOptions;\n  appName?: string;\n  language?: string;\n  appDescription?: string;\n  onAuthCompleted?: () => (user: UserProps) => void;\n};\n\nexport const AuthDialogProvider = ({ children }: { children: ReactNode }) => {\n  const [isOpen, setIsOpen] = useState(false);\n  const [appName, setAppName] = useState<string | undefined>(undefined);\n  const [appDescription, setAppDescription] = useState<string | undefined>(\n    undefined\n  );\n  const [onAuthCompleted, setOnAuthCompleted] = useState<\n    ((user: UserProps) => void) | undefined\n  >(undefined);\n  const [trackOptions, setTrackOptions] = useState<TrackOptions | undefined>(\n    undefined\n  );\n  const [language, setLanguage] = useState<string | undefined>(\n    undefined\n  );\n  const openDialog = ({\n    trackOptions,\n    appName,\n    language,\n    appDescription,\n    onAuthCompleted,\n  }: OpenDialogOptions) => {\n    setIsOpen(true);\n    setTrackOptions(trackOptions);\n    setAppName(appName);\n    setLanguage(language);\n    setAppDescription(appDescription);\n    setOnAuthCompleted(onAuthCompleted);\n  };\n\n  const closeDialog = () => setIsOpen(false);\n  const onOpenChange = (open: boolean) => setIsOpen(open);\n\n  return (\n    <AuthDialogContext.Provider\n      value={{\n        isOpen,\n        appName,\n        language,\n        appDescription,\n        trackOptions,\n        onAuthCompleted,\n        openDialog,\n        closeDialog,\n        onOpenChange,\n      }}\n    >\n      {children}\n    </AuthDialogContext.Provider>\n  );\n};\n\nexport const useAuthDialog = () => {\n  const context = useContext(AuthDialogContext);\n  if (!context) {\n    throw new Error('useAuthDialog must be used within an AuthDialogProvider');\n  }\n  return context;\n};\n","export interface Config {\n  profileServiceUrl: string;\n  identityServiceUrl: string;\n  refreshTokenApiKey: string;\n  authIframeUrl: string;\n  environment: 'development' | 'production';\n  debug: boolean;\n}\n\nexport type Environment = 'development' | 'production';\n\nexport const getConfig = (environment: Environment): Config => {\n  const isDev = environment === 'development';\n\n  return {\n    profileServiceUrl: isDev\n      ? process.env.PROFILE_SERVICE_URL_DEV ||\n        'https://profile-service-dev.arena.im'\n      : process.env.PROFILE_SERVICE_URL_PRD ||\n        'https://profile-service-prd.arena.im',\n    identityServiceUrl: isDev\n      ? process.env.IDENTITY_SERVICE_URL_DEV ||\n        'https://token-service-dev.arena.im'\n      : process.env.IDENTITY_SERVICE_URL_PRD ||\n        'https://token-service-prd.arena.im',\n    refreshTokenApiKey: isDev\n      ? process.env.FIREBASE_PUBLIC_API_KEY_DEV ||\n        'AIzaSyCJhWFCK3ics9kJ2eSgQD7kWHUsOsJyPdk'\n      : process.env.FIREBASE_PUBLIC_API_KEY_PRD ||\n        'AIzaSyD-9tSrQWn73S0qm6BqEH5-12Hq8L0eTsQ',\n    authIframeUrl: isDev\n      ? process.env.AUTH_IFRAME_URL_DEV || 'https://auth2.dev.arena.im'\n      : process.env.AUTH_IFRAME_URL_PRD || 'https://auth2.arena.im',\n    environment,\n    debug: environment === 'development',\n  };\n};\n","import { createContext, useContext, ReactNode } from 'react';\nimport { getConfig, Environment, Config } from '../config';\n\ninterface ConfigContextType {\n  config: Config;\n  environment: Environment;\n}\n\nconst ConfigContext = createContext<ConfigContextType | undefined>(undefined);\n\ninterface ConfigProviderProps {\n  children: ReactNode;\n  environment?: Environment;\n}\n\nexport const ConfigProvider = ({\n  children,\n  environment = 'development',\n}: ConfigProviderProps) => {\n  const config = getConfig(environment);\n\n  return (\n    <ConfigContext.Provider value={{ config, environment }}>\n      {children}\n    </ConfigContext.Provider>\n  );\n};\n\nexport const useConfig = () => {\n  const context = useContext(ConfigContext);\n  if (!context) {\n    throw new Error('useConfig must be used within a ConfigProvider');\n  }\n  return context;\n};\n","const defaultHeaders = {\n  'Content-Type': 'application/json',\n};\n\nexport async function request(\n  method: string,\n  url: string,\n  options: RequestInit = {}\n) {\n  const response = await fetch(url, {\n    ...options,\n    method,\n    headers: {\n      'Content-Type': 'application/json',\n      ...options.headers,\n    },\n  });\n\n  if (!response.ok) {\n    throw new Error(`Error: ${response.statusText}`);\n  }\n\n  return response.json();\n}\n\nexport async function securedRequest(params: {\n  method: string;\n  url: string;\n  options: RequestInit;\n  token: string;\n}) {\n  const { method, url, options = {}, token } = params;\n  if (!token) {\n    throw new Error('No authentication token found');\n  }\n\n  const headers = {\n    ...defaultHeaders,\n    ...options.headers,\n    Authorization: `Bearer ${token}`,\n  };\n\n  const payload = {\n    ...options,\n    method,\n    headers,\n  };\n\n  const response = await fetch(url, payload);\n\n  if (!response.ok) {\n    const text = await response.text();\n    if (!text) {\n      throw new Error(`Error to process request - ${response.status}`);\n    }\n\n    const { errors } = JSON.parse(text) || {};\n    const errorMessage = errors?.[0] || 'Internal server error';\n    throw new Error(errorMessage);\n  }\n\n  const contentType = response.headers.get('content-type');\n  if (!contentType || !contentType.includes('application/json')) {\n    return response;\n  }\n\n  const text = await response.text();\n  if (!text) {\n    return null;\n  }\n\n  try {\n    return JSON.parse(text);\n  } catch (error) {\n    console.error(error);\n    throw new Error('Invalid JSON response from server');\n  }\n}\n","const createStoreImpl = (createState) => {\n  let state;\n  const listeners = /* @__PURE__ */ new Set();\n  const setState = (partial, replace) => {\n    const nextState = typeof partial === \"function\" ? partial(state) : partial;\n    if (!Object.is(nextState, state)) {\n      const previousState = state;\n      state = (replace != null ? replace : typeof nextState !== \"object\" || nextState === null) ? nextState : Object.assign({}, state, nextState);\n      listeners.forEach((listener) => listener(state, previousState));\n    }\n  };\n  const getState = () => state;\n  const getInitialState = () => initialState;\n  const subscribe = (listener) => {\n    listeners.add(listener);\n    return () => listeners.delete(listener);\n  };\n  const api = { setState, getState, getInitialState, subscribe };\n  const initialState = state = createState(setState, getState, api);\n  return api;\n};\nconst createStore = ((createState) => createState ? createStoreImpl(createState) : createStoreImpl);\n\nexport { createStore };\n","import React from 'react';\nimport { createStore } from 'zustand/vanilla';\n\nconst identity = (arg) => arg;\nfunction useStore(api, selector = identity) {\n  const slice = React.useSyncExternalStore(\n    api.subscribe,\n    React.useCallback(() => selector(api.getState()), [api, selector]),\n    React.useCallback(() => selector(api.getInitialState()), [api, selector])\n  );\n  React.useDebugValue(slice);\n  return slice;\n}\nconst createImpl = (createState) => {\n  const api = createStore(createState);\n  const useBoundStore = (selector) => useStore(api, selector);\n  Object.assign(useBoundStore, api);\n  return useBoundStore;\n};\nconst create = ((createState) => createState ? createImpl(createState) : createImpl);\n\nexport { create, useStore };\n","const reduxImpl = (reducer, initial) => (set, _get, api) => {\n  api.dispatch = (action) => {\n    set((state) => reducer(state, action), false, action);\n    return action;\n  };\n  api.dispatchFromDevtools = true;\n  return { dispatch: (...args) => api.dispatch(...args), ...initial };\n};\nconst redux = reduxImpl;\n\nconst trackedConnections = /* @__PURE__ */ new Map();\nconst getTrackedConnectionState = (name) => {\n  const api = trackedConnections.get(name);\n  if (!api) return {};\n  return Object.fromEntries(\n    Object.entries(api.stores).map(([key, api2]) => [key, api2.getState()])\n  );\n};\nconst extractConnectionInformation = (store, extensionConnector, options) => {\n  if (store === void 0) {\n    return {\n      type: \"untracked\",\n      connection: extensionConnector.connect(options)\n    };\n  }\n  const existingConnection = trackedConnections.get(options.name);\n  if (existingConnection) {\n    return { type: \"tracked\", store, ...existingConnection };\n  }\n  const newConnection = {\n    connection: extensionConnector.connect(options),\n    stores: {}\n  };\n  trackedConnections.set(options.name, newConnection);\n  return { type: \"tracked\", store, ...newConnection };\n};\nconst removeStoreFromTrackedConnections = (name, store) => {\n  if (store === void 0) return;\n  const connectionInfo = trackedConnections.get(name);\n  if (!connectionInfo) return;\n  delete connectionInfo.stores[store];\n  if (Object.keys(connectionInfo.stores).length === 0) {\n    trackedConnections.delete(name);\n  }\n};\nconst findCallerName = (stack) => {\n  var _a, _b;\n  if (!stack) return void 0;\n  const traceLines = stack.split(\"\\n\");\n  const apiSetStateLineIndex = traceLines.findIndex(\n    (traceLine) => traceLine.includes(\"api.setState\")\n  );\n  if (apiSetStateLineIndex < 0) return void 0;\n  const callerLine = ((_a = traceLines[apiSetStateLineIndex + 1]) == null ? void 0 : _a.trim()) || \"\";\n  return (_b = /.+ (.+) .+/.exec(callerLine)) == null ? void 0 : _b[1];\n};\nconst devtoolsImpl = (fn, devtoolsOptions = {}) => (set, get, api) => {\n  const { enabled, anonymousActionType, store, ...options } = devtoolsOptions;\n  let extensionConnector;\n  try {\n    extensionConnector = (enabled != null ? enabled : (import.meta.env ? import.meta.env.MODE : void 0) !== \"production\") && window.__REDUX_DEVTOOLS_EXTENSION__;\n  } catch (e) {\n  }\n  if (!extensionConnector) {\n    return fn(set, get, api);\n  }\n  const { connection, ...connectionInformation } = extractConnectionInformation(store, extensionConnector, options);\n  let isRecording = true;\n  api.setState = ((state, replace, nameOrAction) => {\n    const r = set(state, replace);\n    if (!isRecording) return r;\n    const action = nameOrAction === void 0 ? {\n      type: anonymousActionType || findCallerName(new Error().stack) || \"anonymous\"\n    } : typeof nameOrAction === \"string\" ? { type: nameOrAction } : nameOrAction;\n    if (store === void 0) {\n      connection == null ? void 0 : connection.send(action, get());\n      return r;\n    }\n    connection == null ? void 0 : connection.send(\n      {\n        ...action,\n        type: `${store}/${action.type}`\n      },\n      {\n        ...getTrackedConnectionState(options.name),\n        [store]: api.getState()\n      }\n    );\n    return r;\n  });\n  api.devtools = {\n    cleanup: () => {\n      if (connection && typeof connection.unsubscribe === \"function\") {\n        connection.unsubscribe();\n      }\n      removeStoreFromTrackedConnections(options.name, store);\n    }\n  };\n  const setStateFromDevtools = (...a) => {\n    const originalIsRecording = isRecording;\n    isRecording = false;\n    set(...a);\n    isRecording = originalIsRecording;\n  };\n  const initialState = fn(api.setState, get, api);\n  if (connectionInformation.type === \"untracked\") {\n    connection == null ? void 0 : connection.init(initialState);\n  } else {\n    connectionInformation.stores[connectionInformation.store] = api;\n    connection == null ? void 0 : connection.init(\n      Object.fromEntries(\n        Object.entries(connectionInformation.stores).map(([key, store2]) => [\n          key,\n          key === connectionInformation.store ? initialState : store2.getState()\n        ])\n      )\n    );\n  }\n  if (api.dispatchFromDevtools && typeof api.dispatch === \"function\") {\n    let didWarnAboutReservedActionType = false;\n    const originalDispatch = api.dispatch;\n    api.dispatch = (...args) => {\n      if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\" && args[0].type === \"__setState\" && !didWarnAboutReservedActionType) {\n        console.warn(\n          '[zustand devtools middleware] \"__setState\" action type is reserved to set state from the devtools. Avoid using it.'\n        );\n        didWarnAboutReservedActionType = true;\n      }\n      originalDispatch(...args);\n    };\n  }\n  connection.subscribe((message) => {\n    var _a;\n    switch (message.type) {\n      case \"ACTION\":\n        if (typeof message.payload !== \"string\") {\n          console.error(\n            \"[zustand devtools middleware] Unsupported action format\"\n          );\n          return;\n        }\n        return parseJsonThen(\n          message.payload,\n          (action) => {\n            if (action.type === \"__setState\") {\n              if (store === void 0) {\n                setStateFromDevtools(action.state);\n                return;\n              }\n              if (Object.keys(action.state).length !== 1) {\n                console.error(\n                  `\n                    [zustand devtools middleware] Unsupported __setState action format.\n                    When using 'store' option in devtools(), the 'state' should have only one key, which is a value of 'store' that was passed in devtools(),\n                    and value of this only key should be a state object. Example: { \"type\": \"__setState\", \"state\": { \"abc123Store\": { \"foo\": \"bar\" } } }\n                    `\n                );\n              }\n              const stateFromDevtools = action.state[store];\n              if (stateFromDevtools === void 0 || stateFromDevtools === null) {\n                return;\n              }\n              if (JSON.stringify(api.getState()) !== JSON.stringify(stateFromDevtools)) {\n                setStateFromDevtools(stateFromDevtools);\n              }\n              return;\n            }\n            if (!api.dispatchFromDevtools) return;\n            if (typeof api.dispatch !== \"function\") return;\n            api.dispatch(action);\n          }\n        );\n      case \"DISPATCH\":\n        switch (message.payload.type) {\n          case \"RESET\":\n            setStateFromDevtools(initialState);\n            if (store === void 0) {\n              return connection == null ? void 0 : connection.init(api.getState());\n            }\n            return connection == null ? void 0 : connection.init(getTrackedConnectionState(options.name));\n          case \"COMMIT\":\n            if (store === void 0) {\n              connection == null ? void 0 : connection.init(api.getState());\n              return;\n            }\n            return connection == null ? void 0 : connection.init(getTrackedConnectionState(options.name));\n          case \"ROLLBACK\":\n            return parseJsonThen(message.state, (state) => {\n              if (store === void 0) {\n                setStateFromDevtools(state);\n                connection == null ? void 0 : connection.init(api.getState());\n                return;\n              }\n              setStateFromDevtools(state[store]);\n              connection == null ? void 0 : connection.init(getTrackedConnectionState(options.name));\n            });\n          case \"JUMP_TO_STATE\":\n          case \"JUMP_TO_ACTION\":\n            return parseJsonThen(message.state, (state) => {\n              if (store === void 0) {\n                setStateFromDevtools(state);\n                return;\n              }\n              if (JSON.stringify(api.getState()) !== JSON.stringify(state[store])) {\n                setStateFromDevtools(state[store]);\n              }\n            });\n          case \"IMPORT_STATE\": {\n            const { nextLiftedState } = message.payload;\n            const lastComputedState = (_a = nextLiftedState.computedStates.slice(-1)[0]) == null ? void 0 : _a.state;\n            if (!lastComputedState) return;\n            if (store === void 0) {\n              setStateFromDevtools(lastComputedState);\n            } else {\n              setStateFromDevtools(lastComputedState[store]);\n            }\n            connection == null ? void 0 : connection.send(\n              null,\n              // FIXME no-any\n              nextLiftedState\n            );\n            return;\n          }\n          case \"PAUSE_RECORDING\":\n            return isRecording = !isRecording;\n        }\n        return;\n    }\n  });\n  return initialState;\n};\nconst devtools = devtoolsImpl;\nconst parseJsonThen = (stringified, fn) => {\n  let parsed;\n  try {\n    parsed = JSON.parse(stringified);\n  } catch (e) {\n    console.error(\n      \"[zustand devtools middleware] Could not parse the received json\",\n      e\n    );\n  }\n  if (parsed !== void 0) fn(parsed);\n};\n\nconst subscribeWithSelectorImpl = (fn) => (set, get, api) => {\n  const origSubscribe = api.subscribe;\n  api.subscribe = ((selector, optListener, options) => {\n    let listener = selector;\n    if (optListener) {\n      const equalityFn = (options == null ? void 0 : options.equalityFn) || Object.is;\n      let currentSlice = selector(api.getState());\n      listener = (state) => {\n        const nextSlice = selector(state);\n        if (!equalityFn(currentSlice, nextSlice)) {\n          const previousSlice = currentSlice;\n          optListener(currentSlice = nextSlice, previousSlice);\n        }\n      };\n      if (options == null ? void 0 : options.fireImmediately) {\n        optListener(currentSlice, currentSlice);\n      }\n    }\n    return origSubscribe(listener);\n  });\n  const initialState = fn(set, get, api);\n  return initialState;\n};\nconst subscribeWithSelector = subscribeWithSelectorImpl;\n\nfunction combine(initialState, create) {\n  return (...args) => Object.assign({}, initialState, create(...args));\n}\n\nfunction createJSONStorage(getStorage, options) {\n  let storage;\n  try {\n    storage = getStorage();\n  } catch (e) {\n    return;\n  }\n  const persistStorage = {\n    getItem: (name) => {\n      var _a;\n      const parse = (str2) => {\n        if (str2 === null) {\n          return null;\n        }\n        return JSON.parse(str2, options == null ? void 0 : options.reviver);\n      };\n      const str = (_a = storage.getItem(name)) != null ? _a : null;\n      if (str instanceof Promise) {\n        return str.then(parse);\n      }\n      return parse(str);\n    },\n    setItem: (name, newValue) => storage.setItem(name, JSON.stringify(newValue, options == null ? void 0 : options.replacer)),\n    removeItem: (name) => storage.removeItem(name)\n  };\n  return persistStorage;\n}\nconst toThenable = (fn) => (input) => {\n  try {\n    const result = fn(input);\n    if (result instanceof Promise) {\n      return result;\n    }\n    return {\n      then(onFulfilled) {\n        return toThenable(onFulfilled)(result);\n      },\n      catch(_onRejected) {\n        return this;\n      }\n    };\n  } catch (e) {\n    return {\n      then(_onFulfilled) {\n        return this;\n      },\n      catch(onRejected) {\n        return toThenable(onRejected)(e);\n      }\n    };\n  }\n};\nconst persistImpl = (config, baseOptions) => (set, get, api) => {\n  let options = {\n    storage: createJSONStorage(() => localStorage),\n    partialize: (state) => state,\n    version: 0,\n    merge: (persistedState, currentState) => ({\n      ...currentState,\n      ...persistedState\n    }),\n    ...baseOptions\n  };\n  let hasHydrated = false;\n  const hydrationListeners = /* @__PURE__ */ new Set();\n  const finishHydrationListeners = /* @__PURE__ */ new Set();\n  let storage = options.storage;\n  if (!storage) {\n    return config(\n      (...args) => {\n        console.warn(\n          `[zustand persist middleware] Unable to update item '${options.name}', the given storage is currently unavailable.`\n        );\n        set(...args);\n      },\n      get,\n      api\n    );\n  }\n  const setItem = () => {\n    const state = options.partialize({ ...get() });\n    return storage.setItem(options.name, {\n      state,\n      version: options.version\n    });\n  };\n  const savedSetState = api.setState;\n  api.setState = (state, replace) => {\n    savedSetState(state, replace);\n    return setItem();\n  };\n  const configResult = config(\n    (...args) => {\n      set(...args);\n      return setItem();\n    },\n    get,\n    api\n  );\n  api.getInitialState = () => configResult;\n  let stateFromStorage;\n  const hydrate = () => {\n    var _a, _b;\n    if (!storage) return;\n    hasHydrated = false;\n    hydrationListeners.forEach((cb) => {\n      var _a2;\n      return cb((_a2 = get()) != null ? _a2 : configResult);\n    });\n    const postRehydrationCallback = ((_b = options.onRehydrateStorage) == null ? void 0 : _b.call(options, (_a = get()) != null ? _a : configResult)) || void 0;\n    return toThenable(storage.getItem.bind(storage))(options.name).then((deserializedStorageValue) => {\n      if (deserializedStorageValue) {\n        if (typeof deserializedStorageValue.version === \"number\" && deserializedStorageValue.version !== options.version) {\n          if (options.migrate) {\n            const migration = options.migrate(\n              deserializedStorageValue.state,\n              deserializedStorageValue.version\n            );\n            if (migration instanceof Promise) {\n              return migration.then((result) => [true, result]);\n            }\n            return [true, migration];\n          }\n          console.error(\n            `State loaded from storage couldn't be migrated since no migrate function was provided`\n          );\n        } else {\n          return [false, deserializedStorageValue.state];\n        }\n      }\n      return [false, void 0];\n    }).then((migrationResult) => {\n      var _a2;\n      const [migrated, migratedState] = migrationResult;\n      stateFromStorage = options.merge(\n        migratedState,\n        (_a2 = get()) != null ? _a2 : configResult\n      );\n      set(stateFromStorage, true);\n      if (migrated) {\n        return setItem();\n      }\n    }).then(() => {\n      postRehydrationCallback == null ? void 0 : postRehydrationCallback(stateFromStorage, void 0);\n      stateFromStorage = get();\n      hasHydrated = true;\n      finishHydrationListeners.forEach((cb) => cb(stateFromStorage));\n    }).catch((e) => {\n      postRehydrationCallback == null ? void 0 : postRehydrationCallback(void 0, e);\n    });\n  };\n  api.persist = {\n    setOptions: (newOptions) => {\n      options = {\n        ...options,\n        ...newOptions\n      };\n      if (newOptions.storage) {\n        storage = newOptions.storage;\n      }\n    },\n    clearStorage: () => {\n      storage == null ? void 0 : storage.removeItem(options.name);\n    },\n    getOptions: () => options,\n    rehydrate: () => hydrate(),\n    hasHydrated: () => hasHydrated,\n    onHydrate: (cb) => {\n      hydrationListeners.add(cb);\n      return () => {\n        hydrationListeners.delete(cb);\n      };\n    },\n    onFinishHydration: (cb) => {\n      finishHydrationListeners.add(cb);\n      return () => {\n        finishHydrationListeners.delete(cb);\n      };\n    }\n  };\n  if (!options.skipHydration) {\n    hydrate();\n  }\n  return stateFromStorage || configResult;\n};\nconst persist = persistImpl;\n\nexport { combine, createJSONStorage, devtools, persist, redux, subscribeWithSelector };\n","export enum TokenType {\n  ANONYMOUS = 'anonymous',\n  GUEST = 'guest',\n  PUBLIC = 'public',\n  CUSTOM = 'custom',\n}\n\nexport interface TokenPair {\n  idToken: string | null;\n  refreshToken?: string | null;\n}\n\nexport type TokensMap = Record<TokenType, TokenPair>;\n\nexport enum AuthCookie {\n  PUBLIC_ID_TOKEN = 'arena-auth-public-id-token',\n  PUBLIC_REFRESH_TOKEN = 'arena-auth-public-refresh-token',\n  ANONYMOUS_ID_TOKEN = 'arena-auth-anonymous-id-token',\n  GUEST_ID_TOKEN = 'arena-auth-guest-id-token',\n  CUSTOM_ID_TOKEN = 'arena-auth-custom-id-token',\n  CUSTOM_USER = 'arena-auth-custom-user',\n}\n","import { TokenType } from '../types/token';\n\nexport const TOKEN_UPDATED_EVENT = 'arena-auth-token-updated';\n\ninterface TokenEventParams {\n  idToken: string | null;\n  refreshToken?: string | null;\n  source?: string;\n}\n\nexport function dispatchTokenUpdatedEvent(\n  type: TokenType,\n  params: TokenEventParams\n) {\n  document.dispatchEvent(\n    new CustomEvent(TOKEN_UPDATED_EVENT, {\n      detail: { ...params, type },\n    })\n  );\n}\n","import { create } from 'zustand';\nimport { subscribeWithSelector } from 'zustand/middleware';\nimport Cookies from 'js-cookie';\nimport { AuthCookie, TokensMap, TokenType } from '../types/token';\nimport { dispatchTokenUpdatedEvent } from '../utils/dom-events';\n\ninterface TokenStore {\n  tokens: TokensMap;\n  getToken: (type: TokenType) => string | null;\n  getMostPrivilegedToken: (\n    options?: Array<TokenType>\n  ) => { type: TokenType; idToken: string } | null;\n  getRefreshToken: (type: TokenType) => string | null;\n  updatePublicTokens: (\n    idToken: string,\n    refreshToken: string,\n    source?: string\n  ) => void;\n  updateAnonymousToken: (idToken: string, source?: string) => void;\n  updateGuestTokens: (idToken: string, source?: string) => void;\n  updateCustomToken: (idToken: string, source?: string) => void;\n  clearTokens: (source?: string) => void;\n  clearPublicTokens: (source?: string) => void;\n  clearAnonymousTokens: (source?: string) => void;\n  clearGuestTokens: (source?: string) => void;\n  clearCustomTokens: (source?: string) => void;\n  silentUpdatePublicTokens: (idToken: string, refreshToken: string) => void;\n  silentUpdateAnonymousToken: (idToken: string) => void;\n  silentUpdateGuestTokens: (idToken: string) => void;\n  silentUpdateCustomToken: (idToken: string) => void;\n  silentClearPublicTokens: () => void;\n  silentClearAnonymousTokens: () => void;\n  silentClearGuestTokens: () => void;\n  silentClearCustomTokens: () => void;\n}\n\nconst defaultTokens: TokensMap = {\n  public: {\n    idToken: Cookies.get(AuthCookie.PUBLIC_ID_TOKEN) || null,\n    refreshToken: Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN) || null,\n  },\n  anonymous: {\n    idToken: Cookies.get(AuthCookie.ANONYMOUS_ID_TOKEN) || null,\n  },\n  guest: {\n    idToken: Cookies.get(AuthCookie.GUEST_ID_TOKEN) || null,\n  },\n  custom: {\n    idToken: Cookies.get(AuthCookie.CUSTOM_ID_TOKEN) || null,\n  },\n};\n\nexport const useTokenStore = create<TokenStore>()(\n  subscribeWithSelector((set, get) => {\n    const updatePublicTokensHelper = (\n      idToken: string,\n      refreshToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (\n        idToken === get().tokens.public.idToken &&\n        refreshToken === get().tokens.public.refreshToken\n      ) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          public: {\n            idToken,\n            refreshToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.PUBLIC_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      Cookies.set(AuthCookie.PUBLIC_REFRESH_TOKEN, refreshToken, {\n        expires: 30,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.PUBLIC, {\n          idToken,\n          refreshToken,\n          source,\n        });\n      }\n    };\n\n    const updateAnonymousTokenHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.anonymous.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          anonymous: {\n            idToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.ANONYMOUS_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.ANONYMOUS, { idToken, source });\n      }\n    };\n\n    const updateGuestTokensHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.guest.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          guest: {\n            idToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.GUEST_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.GUEST, { idToken, source });\n      }\n    };\n\n    const updateCustomTokenHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.custom.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          custom: { idToken },\n        },\n      }));\n\n      Cookies.set(AuthCookie.CUSTOM_ID_TOKEN, idToken);\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.CUSTOM, { idToken, source });\n      }\n    };\n\n    const clearPublicTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.PUBLIC_ID_TOKEN);\n      Cookies.remove(AuthCookie.PUBLIC_REFRESH_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          public: { idToken: null, refreshToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.PUBLIC, { idToken: null, source });\n      }\n    };\n\n    const clearAnonymousTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.ANONYMOUS_ID_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          anonymous: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.ANONYMOUS, {\n          idToken: null,\n          source,\n        });\n      }\n    };\n\n    const clearGuestTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.GUEST_ID_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          guest: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.GUEST, { idToken: null, source });\n      }\n    };\n\n    const clearCustomTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.CUSTOM_ID_TOKEN);\n      localStorage.removeItem(AuthCookie.CUSTOM_ID_TOKEN);\n      localStorage.removeItem(AuthCookie.CUSTOM_USER);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          custom: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.CUSTOM, { idToken: null, source });\n      }\n    };\n\n    return {\n      tokens: defaultTokens,\n\n      getToken: (type: TokenType) => {\n        return get().tokens[type]?.idToken || null;\n      },\n\n      getMostPrivilegedToken: (\n        options = [TokenType.PUBLIC, TokenType.GUEST, TokenType.ANONYMOUS]\n      ) => {\n        if (get().tokens.custom.idToken && options.includes(TokenType.CUSTOM)) {\n          return {\n            type: TokenType.CUSTOM,\n            idToken: get().tokens.custom.idToken!,\n          };\n        }\n        if (get().tokens.public.idToken && options.includes(TokenType.PUBLIC)) {\n          return {\n            type: TokenType.PUBLIC,\n            idToken: get().tokens.public.idToken!,\n          };\n        }\n        if (get().tokens.guest.idToken && options.includes(TokenType.GUEST)) {\n          return {\n            type: TokenType.GUEST,\n            idToken: get().tokens.guest.idToken!,\n          };\n        }\n        if (\n          get().tokens.anonymous.idToken &&\n          options.includes(TokenType.ANONYMOUS)\n        ) {\n          return {\n            type: TokenType.ANONYMOUS,\n            idToken: get().tokens.anonymous.idToken!,\n          };\n        }\n        return null;\n      },\n\n      getRefreshToken: (type: TokenType) => {\n        return get().tokens[type]?.refreshToken || null;\n      },\n\n      updatePublicTokens: (\n        idToken: string,\n        refreshToken: string,\n        source?: string\n      ) => {\n        updatePublicTokensHelper(idToken, refreshToken, true, source);\n      },\n\n      updateAnonymousToken: (idToken: string, source?: string) => {\n        updateAnonymousTokenHelper(idToken, true, source);\n      },\n\n      updateGuestTokens: (idToken: string, source?: string) => {\n        updateGuestTokensHelper(idToken, true, source);\n      },\n\n      updateCustomToken: (idToken: string, source?: string) => {\n        updateCustomTokenHelper(idToken, true, source);\n      },\n\n      clearTokens: (source?: string) => {\n        clearPublicTokensHelper(true, source);\n        clearAnonymousTokensHelper(true, source);\n        clearGuestTokensHelper(true, source);\n        clearCustomTokensHelper(true, source);\n      },\n\n      clearPublicTokens: (source?: string) => {\n        clearPublicTokensHelper(true, source);\n      },\n\n      clearAnonymousTokens: (source?: string) => {\n        clearAnonymousTokensHelper(true, source);\n      },\n\n      clearGuestTokens: (source?: string) => {\n        clearGuestTokensHelper(true, source);\n      },\n\n      clearCustomTokens: (source?: string) => {\n        clearCustomTokensHelper(true, source);\n      },\n\n      silentUpdatePublicTokens: (idToken: string, refreshToken: string) => {\n        updatePublicTokensHelper(idToken, refreshToken, false);\n      },\n\n      silentUpdateAnonymousToken: (idToken: string) => {\n        updateAnonymousTokenHelper(idToken, false);\n      },\n\n      silentUpdateGuestTokens: (idToken: string) => {\n        updateGuestTokensHelper(idToken, false);\n      },\n\n      silentUpdateCustomToken: (idToken: string) => {\n        updateCustomTokenHelper(idToken, false);\n      },\n\n      silentClearPublicTokens: () => {\n        clearPublicTokensHelper(false);\n      },\n\n      silentClearAnonymousTokens: () => {\n        clearAnonymousTokensHelper(false);\n      },\n\n      silentClearGuestTokens: () => {\n        clearGuestTokensHelper(false);\n      },\n\n      silentClearCustomTokens: () => {\n        clearCustomTokensHelper(false);\n      },\n    };\n  })\n);\n","import { useEffect, useRef } from 'react';\nimport { TokenType } from '../types/token';\nimport { useTokenStore } from '../stores/token-store';\nimport { TOKEN_UPDATED_EVENT } from '../utils/dom-events';\n\ninterface TokenUpdateEvent {\n  detail: {\n    idToken: string | null;\n    refreshToken?: string | null;\n    type: TokenType;\n    source?: string;\n  };\n}\n\nexport function useTokenEventListener() {\n  const updatePublicTokens = useTokenStore(\n    state => state.silentUpdatePublicTokens\n  );\n  const updateAnonymousToken = useTokenStore(\n    state => state.silentUpdateAnonymousToken\n  );\n  const updateGuestTokens = useTokenStore(\n    state => state.silentUpdateGuestTokens\n  );\n  const updateCustomToken = useTokenStore(\n    state => state.silentUpdateCustomToken\n  );\n  const clearTokens = useTokenStore(state => state.clearTokens);\n  const clearPublicTokens = useTokenStore(\n    state => state.silentClearPublicTokens\n  );\n  const clearAnonymousTokens = useTokenStore(\n    state => state.silentClearAnonymousTokens\n  );\n  const clearGuestTokens = useTokenStore(state => state.silentClearGuestTokens);\n  const clearCustomTokens = useTokenStore(\n    state => state.silentClearCustomTokens\n  );\n\n  const eventSourceRef = useRef<string>(\n    `widget-${Math.random().toString(36).substr(2, 9)}`\n  );\n\n  useEffect(() => {\n    const handleTokenUpdate = (\n      event: CustomEvent<TokenUpdateEvent['detail']>\n    ) => {\n      const { idToken, refreshToken, type, source } = event.detail;\n\n      if (source === eventSourceRef.current) {\n        return;\n      }\n\n      switch (type) {\n        case TokenType.PUBLIC:\n          if (idToken) {\n            if (!refreshToken) {\n              throw new Error('Refresh token is required for public tokens');\n            }\n            updatePublicTokens(idToken, refreshToken);\n          } else {\n            clearPublicTokens();\n          }\n          break;\n\n        case TokenType.ANONYMOUS:\n          if (idToken) {\n            updateAnonymousToken(idToken);\n          } else {\n            clearAnonymousTokens();\n          }\n          break;\n\n        case TokenType.GUEST:\n          if (idToken) {\n            updateGuestTokens(idToken);\n          } else {\n            clearGuestTokens();\n          }\n          break;\n\n        case TokenType.CUSTOM:\n          if (idToken) {\n            updateCustomToken(idToken);\n          } else {\n            clearCustomTokens();\n          }\n          break;\n      }\n    };\n\n    document.addEventListener(\n      TOKEN_UPDATED_EVENT,\n      handleTokenUpdate as EventListener\n    );\n\n    return () => {\n      document.removeEventListener(\n        TOKEN_UPDATED_EVENT,\n        handleTokenUpdate as EventListener\n      );\n    };\n  }, [\n    updatePublicTokens,\n    updateAnonymousToken,\n    updateGuestTokens,\n    updateCustomToken,\n    clearTokens,\n    clearPublicTokens,\n    clearAnonymousTokens,\n    clearGuestTokens,\n    clearCustomTokens,\n  ]);\n\n  return {\n    eventSource: eventSourceRef.current,\n  };\n}\n","import { useTokenStore } from '../stores/token-store';\nimport { useTokenEventListener } from './use-token-event-listener';\n\nexport function useTokens() {\n  const getToken = useTokenStore(state => state.getToken);\n  const getMostPrivilegedToken = useTokenStore(\n    state => state.getMostPrivilegedToken\n  );\n  const getRefreshToken = useTokenStore(state => state.getRefreshToken);\n  const updatePublicTokens = useTokenStore(state => state.updatePublicTokens);\n  const updateAnonymousToken = useTokenStore(\n    state => state.updateAnonymousToken\n  );\n  const updateGuestTokens = useTokenStore(state => state.updateGuestTokens);\n  const updateCustomToken = useTokenStore(state => state.updateCustomToken);\n  const clearTokens = useTokenStore(state => state.clearTokens);\n  const clearPublicTokens = useTokenStore(state => state.clearPublicTokens);\n  const clearCustomTokens = useTokenStore(state => state.clearCustomTokens);\n\n  const { eventSource } = useTokenEventListener();\n\n  return {\n    getToken,\n    getMostPrivilegedToken,\n    getRefreshToken,\n    updatePublicTokens: (idToken: string, refreshToken: string) =>\n      updatePublicTokens(idToken, refreshToken, eventSource),\n    updateAnonymousToken: (idToken: string) =>\n      updateAnonymousToken(idToken, eventSource),\n    updateGuestTokens: (idToken: string) =>\n      updateGuestTokens(idToken, eventSource),\n    updateCustomToken: (idToken: string) =>\n      updateCustomToken(idToken, eventSource),\n    clearTokens: () => clearTokens(eventSource),\n    clearPublicTokens: () => clearPublicTokens(eventSource),\n    clearCustomTokens: () => clearCustomTokens(eventSource),\n  };\n}\n\nexport function useToken(type: 'anonymous' | 'guest' | 'public' | 'custom') {\n  return useTokenStore(state => state.tokens[type]);\n}\n\nexport function useTokenValue(\n  type: 'anonymous' | 'guest' | 'public' | 'custom'\n) {\n  return useTokenStore(state => state.tokens[type]?.idToken);\n}\n\nexport function useRefreshToken(type: 'anonymous' | 'guest' | 'public') {\n  return useTokenStore(state => state.tokens[type]?.refreshToken);\n}\n","type Nullable<T> = T | null;\n\nexport enum AnalyticsWidgetType {\n  AvatarProfile = 'avatar-profile',\n  AvatarChat = 'avatar-chat',\n  Comments = 'comments',\n  GlobalProfile = 'global-profile',\n  GroupChat = 'group-chat',\n  Polls = 'polls',\n  UniversalSnippet = 'universal-snippet',\n}\n\nexport type TrackOptions = {\n  widgetId: string | null;\n  widgetType: AnalyticsWidgetType;\n  siteId: string;\n  rsWriteKey: string;\n  rsDataPlaneUrl: string;\n  trigger: string;\n};\n\nexport enum AnalyticsEvent {\n  AuthenticationCompleted = 'Authentication Completed',\n  AuthenticationStarted = 'Authentication Started',\n  AuthenticationViewed = 'Authentication Viewed',\n}\n\nexport type TrackProps = Nullable<Record<string, unknown>>;\n\nexport interface IdentityProps {\n  anonymousId?: string;\n  userId?: string;\n}\n\nexport interface RudderContext {\n  channel: 'web';\n  anonymousId?: string;\n  locale?: string;\n  userAgent?: string;\n  timezone?: string;\n  os?: { name: string; version?: string };\n  page?: {\n    path?: string;\n    referrer?: string;\n    referring_domain?: string;\n    search?: string;\n    title?: string;\n    url?: string;\n    initial_referrer?: string;\n    initial_referring_domain?: string;\n  };\n  screen?: {\n    density?: number;\n    height?: number;\n    width?: number;\n    innerHeight?: number;\n    innerWidth?: number;\n  };\n  campaign?: Record<string, string>;\n}\n","import { PublicProfile } from './types';\nimport { request, securedRequest } from '../../utils/request';\nimport { useConfig } from '../../context/config-provider';\nimport { useToken } from '../../hooks/use-tokens';\nimport { TokenType } from '../../types';\nimport { useUserActions } from '../../hooks/use-user';\n\nexport function useProfileServices() {\n  const token = useToken(TokenType.PUBLIC);\n  const { refreshPublicTokens } = useUserActions();\n  const { config } = useConfig();\n  const profileUrl = config.profileServiceUrl;\n\n  async function getPublicProfile(userId?: string): Promise<PublicProfile> {\n    const fields = 'bio,photoURL,displayName,location,handle';\n    const url = `${profileUrl}/public/users/${userId}/profile?fields=${fields}`;\n    return await request('GET', url);\n  }\n\n  async function updatePublicProfile(\n    params: Omit<PublicProfile, 'metadata'>\n  ): Promise<void> {\n    const url = `${profileUrl}/me/profile/personal`;\n    await securedRequest({\n      method: 'PUT',\n      url,\n      options: {\n        body: JSON.stringify(params),\n      },\n      token: token.idToken!,\n    });\n    refreshPublicTokens({ refreshTokenApiKey: config.refreshTokenApiKey });\n  }\n  return {\n    getPublicProfile,\n    updatePublicProfile,\n  };\n}\n","import { create } from 'zustand';\nimport { subscribeWithSelector } from 'zustand/middleware';\nimport Cookies from 'js-cookie';\nimport {\n  UserProps,\n  FirebaseUser,\n  SsoUserProps,\n  SsoV2ExchangeResponse,\n} from '../services/auth/types';\nimport { jwtDecode } from 'jwt-decode';\nimport { type PublicProfile } from '../services/profile/types';\nimport { useTokenStore } from './token-store';\nimport { AuthCookie } from '../types/token';\nimport { request } from '../utils/request';\nimport { Environment, getConfig } from '../config';\n\ninterface UserStore {\n  user: UserProps | null;\n  publicProfile: PublicProfile | null;\n  refreshedTokenLoaded: boolean;\n  setUser: (user: UserProps | null) => void;\n  setPublicProfile: (publicProfile: PublicProfile | null) => void;\n  logout: () => void;\n  refreshPublicTokens: (config: {\n    refreshTokenApiKey: string;\n  }) => Promise<void>;\n  setUserByTokenId: (idToken: string) => void;\n  loadStoredUser: (config?: { refreshTokenApiKey: string }) => Promise<void>;\n  ssoV2Exchange: (\n    ssoSourceID: string,\n    jwt: string,\n    env?: Environment\n  ) => Promise<SsoV2ExchangeResponse>;\n}\n\nexport const useUserStore = create<UserStore>()(\n  subscribeWithSelector((set, get) => ({\n    user: null,\n    publicProfile: null,\n    refreshedTokenLoaded: false,\n\n    setUser: (user: UserProps | null) => {\n      set({ user });\n    },\n\n    setPublicProfile: (publicProfile: PublicProfile | null) => {\n      set({ publicProfile });\n    },\n\n    setUserByTokenId: (idToken: string) => {\n      try {\n        const user = jwtDecode<FirebaseUser>(idToken);\n        const userProps: UserProps = {\n          uid: user.user_id,\n          displayName: user.safeDisplayName,\n          email: user.email,\n          photoURL: user.safePhotoURL,\n          handle: user.handle,\n        };\n        set({ user: userProps });\n      } catch (error) {\n        console.error(error);\n      }\n    },\n\n    logout: () => {\n      try {\n        const tokenStore = useTokenStore.getState();\n        tokenStore.clearPublicTokens();\n        tokenStore.clearCustomTokens();\n        set({ user: null });\n        document.dispatchEvent(new Event('arena-comments-logout'));\n      } catch (error) {\n        console.error(error);\n      }\n    },\n\n    refreshPublicTokens: async (config: { refreshTokenApiKey: string }) => {\n      try {\n        const refreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n\n        if (!refreshToken) {\n          throw new Error('No refresh token found');\n        }\n\n        const prefix = 'https://securetoken.googleapis.com/v1/token?key=';\n        const apiKey = config.refreshTokenApiKey;\n        const url = `${prefix}${apiKey}`;\n        const response = await fetch(url, {\n          method: 'POST',\n          body: new URLSearchParams({\n            refresh_token: refreshToken,\n            grant_type: 'refresh_token',\n          }),\n        });\n        const data = await response.json();\n\n        const { setUserByTokenId } = get();\n        setUserByTokenId(data.id_token);\n\n        const tokenStore = useTokenStore.getState();\n        tokenStore.updatePublicTokens(data.id_token, data.refresh_token);\n      } catch (error) {\n        console.error(error);\n        const { logout } = get();\n        logout();\n      }\n    },\n\n    loadStoredUser: async (config?: { refreshTokenApiKey: string }) => {\n      const publicIdToken = Cookies.get(AuthCookie.PUBLIC_ID_TOKEN);\n      const publicRefreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n      const customIdToken = localStorage.getItem(AuthCookie.CUSTOM_ID_TOKEN);\n      const customUser = localStorage.getItem(AuthCookie.CUSTOM_USER);\n\n      if (!!customIdToken && !!customUser) {\n        const parsedUser = JSON.parse(customUser);\n\n        set({ user: parsedUser });\n\n        const tokenStore = useTokenStore.getState();\n        tokenStore.updateCustomToken(customIdToken);\n      } else {\n        if (publicIdToken) {\n          const { setUserByTokenId } = get();\n          setUserByTokenId(publicIdToken);\n        } else if (publicRefreshToken && config) {\n          const { refreshPublicTokens } = get();\n          await refreshPublicTokens(config);\n        }\n      }\n\n      set({ refreshedTokenLoaded: true });\n    },\n\n    ssoV2Exchange: async (\n      ssoSourceID: string,\n      jwt: string,\n      env?: Environment\n    ) => {\n      try {\n        const config = getConfig(env ?? 'production');\n        const profileUrl = config.profileServiceUrl;\n\n        const url = `${profileUrl}/sso/sources/${ssoSourceID}/user`;\n        const response: SsoV2ExchangeResponse = await request('POST', url, {\n          body: JSON.stringify({ signedUserData: jwt }),\n        });\n\n        if (response) {\n          const decodedUser = jwtDecode<SsoUserProps>(response.token);\n\n          const { setUser, setPublicProfile } = get();\n\n          setUser({\n            uid: decodedUser?.sub,\n            email: decodedUser?.email,\n            displayName: decodedUser?.displayName,\n            photoURL: decodedUser?.photoURL,\n            handle: decodedUser?.handle,\n          });\n\n          setPublicProfile({\n            displayName: decodedUser?.displayName,\n            photoURL: decodedUser?.photoURL,\n            handle: decodedUser?.handle,\n          });\n\n          const tokenStore = useTokenStore.getState();\n          tokenStore.updateCustomToken(response.token);\n        }\n\n        return response;\n      } catch (error) {\n        console.error('SSO V2 Exchange failed:', error);\n        throw error;\n      }\n    },\n  }))\n);\n","import { useProfileServices } from '../services/profile/use-profile-services';\nimport { useUserStore } from '../stores/user-store';\n\nexport function useUser() {\n  return useUserStore(state => state.user);\n}\n\nexport function usePublicProfile() {\n  return useUserStore(state => state.publicProfile);\n}\n\nexport function useRefreshedTokenLoaded() {\n  return useUserStore(state => state.refreshedTokenLoaded);\n}\n\nexport function useUserActions() {\n  const setUser = useUserStore(state => state.setUser);\n  const setPublicProfile = useUserStore(state => state.setPublicProfile);\n  const logout = useUserStore(state => state.logout);\n  const refreshPublicTokens = useUserStore(state => state.refreshPublicTokens);\n  const setUserByTokenId = useUserStore(state => state.setUserByTokenId);\n  const loadStoredUser = useUserStore(state => state.loadStoredUser);\n  const ssoV2Exchange = useUserStore(state => state.ssoV2Exchange);\n  \n\n  return {\n    setUser,\n    setPublicProfile,\n    logout,\n    refreshPublicTokens,\n    setUserByTokenId,\n    loadStoredUser,\n    ssoV2Exchange,\n  };\n}\n\nexport function useUpdateProfile() {\n  const { updatePublicProfile } = useProfileServices();\n  return {\n    updatePublicProfile,\n  };\n}\n\nexport function useUserWithProfile() {\n  const user = useUserStore(state => state.user);\n  const publicProfile = useUserStore(state => state.publicProfile);\n  const refreshedTokenLoaded = useUserStore(\n    state => state.refreshedTokenLoaded\n  );\n\n  return {\n    user,\n    publicProfile,\n    refreshedTokenLoaded,\n  };\n}\n\n","import React, { useCallback, useEffect } from 'react';\nimport { useConfig } from './config-provider';\nimport { useUser, useUserActions } from '../hooks/use-user';\nimport { useMutation } from '@tanstack/react-query';\nimport { useProfileServices } from '../services/profile/use-profile-services';\n\nexport function UserProvider({ children }: { children: React.ReactNode }) {\n  const { config } = useConfig();\n  const user = useUser();\n  const { setPublicProfile, loadStoredUser } = useUserActions();\n  const { getPublicProfile: getPublicProfileService } = useProfileServices();\n  const { mutateAsync: getPublicProfile } = useMutation({\n    mutationFn: getPublicProfileService,\n  });\n\n  const loadPublicProfile = useCallback(async () => {\n    if (user?.uid) {\n      const profile = await getPublicProfile(user.uid);\n      setPublicProfile(profile);\n    }\n  }, [user?.uid, getPublicProfile, setPublicProfile]);\n\n  useEffect(() => {\n    loadPublicProfile();\n  }, [loadPublicProfile]);\n\n  useEffect(() => {\n    loadStoredUser(config);\n  }, [config, loadStoredUser]);\n\n  return children;\n}\n","import type {\n  AnalyticsWidgetType,\n  AnalyticsEvent,\n  IdentityProps,\n  RudderContext,\n  TrackProps,\n} from '../types/analytics';\n\nimport { removeParamsFromUrl } from '../utils/url';\n\nconst ANONYMOUS_ID_KEY = 'arenaAnonymousId';\n\nconst LS_KEYS = {\n  anon: 'rs_anonymous_id',\n  initReferrer: 'rs_initial_referrer',\n  initDomain: 'rs_initial_referring_domain',\n} as const;\n\nfunction generateUUID(): string {\n  if (typeof crypto !== 'undefined' && crypto.randomUUID) {\n    return crypto.randomUUID();\n  }\n\n  return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {\n    const r = (Math.random() * 16) | 0;\n    const v = c === 'x' ? r : (r & 0x3) | 0x8;\n    return v.toString(16);\n  });\n}\n\nfunction getOrSetAnonymousId(): string {\n  const existing = localStorage.getItem(LS_KEYS.anon);\n  if (existing) return existing;\n  const id = crypto.randomUUID();\n  localStorage.setItem(LS_KEYS.anon, id);\n  return id;\n}\n\nfunction rememberInitialReferrer(): void {\n  if (!localStorage.getItem(LS_KEYS.initReferrer)) {\n    const ref = document.referrer || '$direct';\n    const domain = ref && ref !== '$direct' ? new URL(ref).hostname : '';\n    localStorage.setItem(LS_KEYS.initReferrer, ref);\n    localStorage.setItem(LS_KEYS.initDomain, domain);\n  }\n}\n\nfunction parseCampaign(u: URL): Record<string, string> | undefined {\n  const keys = [\n    'utm_source',\n    'utm_medium',\n    'utm_campaign',\n    'utm_term',\n    'utm_content',\n  ];\n  const out: Record<string, string> = {};\n  keys.forEach(k => {\n    const v = u.searchParams.get(k);\n    if (v) out[k] = v;\n  });\n  return Object.keys(out).length ? out : undefined;\n}\n\nexport function buildRudderContext(): RudderContext {\n  const w = window;\n  const d = document;\n  const s = window.screen;\n  const url = new URL(w.location.href);\n\n  rememberInitialReferrer();\n\n  const initial_referrer =\n    localStorage.getItem(LS_KEYS.initReferrer) || '$direct';\n  const initial_referring_domain =\n    localStorage.getItem(LS_KEYS.initDomain) || '';\n\n  return {\n    channel: 'web',\n    anonymousId: getOrSetAnonymousId(),\n    locale: navigator.language,\n    userAgent: navigator.userAgent,\n    timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n    os: { name: navigator.platform, version: undefined },\n    page: {\n      path: url.pathname,\n      referrer: d.referrer || '$direct',\n      referring_domain: d.referrer ? new URL(d.referrer).hostname : '',\n      search: url.search,\n      title: d.title,\n      url: url.toString(),\n      initial_referrer,\n      initial_referring_domain,\n    },\n    screen: {\n      density: (w.devicePixelRatio || 1) ?? 1,\n      height: s.height,\n      width: s.width,\n      innerHeight: w.innerHeight,\n      innerWidth: w.innerWidth,\n    },\n    campaign: parseCampaign(url),\n  };\n}\n\nfunction getIdentifier(options: IdentityProps = {}): IdentityProps {\n  const identifier: IdentityProps = {};\n\n  if (options.userId) {\n    identifier.userId = options.userId;\n  }\n\n  let currentAnonymousId: string | null = null;\n\n  try {\n    currentAnonymousId = localStorage.getItem(ANONYMOUS_ID_KEY);\n  } catch (error) {\n    console.warn('Failed to access localStorage:', error);\n  }\n\n  if (options.anonymousId) {\n    identifier.anonymousId = options.anonymousId;\n    try {\n      localStorage.setItem(ANONYMOUS_ID_KEY, options.anonymousId);\n    } catch (error) {\n      console.warn('Failed to save anonymousId to localStorage:', error);\n    }\n  } else if (currentAnonymousId) {\n    identifier.anonymousId = currentAnonymousId;\n  } else {\n    const newAnonymousId = generateUUID();\n    identifier.anonymousId = newAnonymousId;\n    try {\n      localStorage.setItem(ANONYMOUS_ID_KEY, newAnonymousId);\n    } catch (error) {\n      console.warn('Failed to save new anonymousId to localStorage:', error);\n    }\n  }\n\n  return identifier;\n}\n\nfunction getCanonicalUrl(): string {\n  const canonicalMeta = document.querySelector(\n    'link[rel=\"canonical\"]'\n  ) as HTMLLinkElement;\n  const rawUrl = canonicalMeta?.href || window.location.href;\n  return removeParamsFromUrl(rawUrl);\n}\n\nfunction getEventProperties(\n  widgetType: string,\n  properties: TrackProps,\n  identity?: IdentityProps\n) {\n  return {\n    properties: {\n      widget_type: widgetType,\n      url: window.location.href,\n      domain: window.location.hostname,\n      title: window.document.title,\n      canonical_url: getCanonicalUrl(),\n      snippet_id: window.__ARENA__?.snippetId || null,\n      ...properties,\n    },\n    context: buildRudderContext(),\n    timestamp: new Date().toISOString(),\n    integrations: { All: true },\n    ...getIdentifier(identity),\n  };\n}\n\nfunction getEventHeaders(writeKey: string) {\n  return {\n    'Content-Type': 'application/json',\n    Authorization: 'Basic ' + btoa(`${writeKey}:`),\n  };\n}\n\nexport function getAnalytics(writeKey: string, dataPlaneUrl: string) {\n  return {\n    page: async (\n      widgetType: AnalyticsWidgetType,\n      properties: TrackProps,\n      identity?: IdentityProps\n    ) => {\n      const response = await fetch(`${dataPlaneUrl}/v1/page`, {\n        method: 'POST',\n        headers: getEventHeaders(writeKey),\n        body: JSON.stringify({\n          type: 'page',\n          ...getEventProperties(widgetType, properties, identity),\n        }),\n      });\n\n      if (response.ok) {\n        const data = await response.text();\n        return data;\n      } else {\n        throw new Error('Failed to send page event to Rudderstack');\n      }\n    },\n    track: async (\n      widgetType: AnalyticsWidgetType,\n      event: AnalyticsEvent,\n      properties: TrackProps,\n      identity?: IdentityProps\n    ) => {\n      const response = await fetch(`${dataPlaneUrl}/v1/track`, {\n        method: 'POST',\n        headers: getEventHeaders(writeKey),\n        body: JSON.stringify({\n          event,\n          type: 'track',\n          ...getEventProperties(widgetType, properties, identity),\n        }),\n      });\n\n      if (response.ok) {\n        const data = await response.text();\n        return data;\n      } else {\n        throw new Error('Failed to send track event to Rudderstack');\n      }\n    },\n  };\n}\n","export function removeParamsFromUrl(url: string): string {\n  try {\n    const urlObj = new URL(url);\n\n    urlObj.search = '';\n\n    return urlObj.href;\n  } catch (error) {\n    console.error('Error clearing search params from URL:', error);\n    return url;\n  }\n}\n","import { useCallback } from 'react';\nimport { getAnalytics } from '../utils/analytics';\nimport { AnalyticsEvent, TrackOptions } from '../types/analytics';\n\nexport function useTrack(trackOptions?: TrackOptions) {\n  const track = useCallback(\n    (\n      event: AnalyticsEvent,\n      userId?: string,\n      properties?: Record<string, string | null>\n    ) => {\n      if (!trackOptions) return;\n\n      const analytics = getAnalytics(\n        trackOptions.rsWriteKey,\n        trackOptions.rsDataPlaneUrl\n      );\n\n      const trackProperties: Record<string, string | null> = {\n        site_id: trackOptions.siteId,\n        widget_id: trackOptions.widgetId,\n        trigger: trackOptions.trigger,\n        ...properties,\n      };\n\n      analytics.track(\n        trackOptions.widgetType,\n        event,\n        trackProperties,\n        userId ? { userId } : undefined\n      );\n    },\n    [trackOptions]\n  );\n\n  return track;\n}\n","import { useAuthDialog } from '../context/auth-dialog-provider';\nimport { useEffect } from 'react';\nimport { useUserActions } from '../hooks/use-user';\nimport { useConfig } from '../context/config-provider';\nimport { useTokens } from '../hooks/use-tokens';\nimport { AnalyticsEvent } from '../types/analytics';\nimport { useTrack } from '../hooks/use-track';\n\nexport default function AuthDialog() {\n  const {\n    appName,\n    appDescription,\n    language,\n    trackOptions,\n    isOpen,\n    closeDialog,\n    onAuthCompleted,\n  } = useAuthDialog();\n  const frameAppName = appName || 'Arena AI Chat';\n  const frameAppDescription = appDescription || 'Arena AI Chat';\n  const { setUser } = useUserActions();\n  const { updatePublicTokens } = useTokens();\n  const { config } = useConfig();\n\n  const track = useTrack(trackOptions);\n\n  const iframeUrl = `${config.authIframeUrl}/?app-name=${frameAppName}&app-description=${frameAppDescription}&language=${language ?? 'en'}`;\n\n  useEffect(() => {\n    const handler = (message: MessageEvent) => {\n      if (message.data?.source !== 'arena-authentication') return;\n\n      if (message.data?.type === 'canceled') {\n        closeDialog();\n        return;\n      }\n\n      if (message.data?.type === 'authentication-viewed') {\n        track(AnalyticsEvent.AuthenticationViewed);\n        return;\n      }\n\n      if (message.data?.type === 'authentication-started') {\n        const { authType } = message.data?.payload || {};\n        track(AnalyticsEvent.AuthenticationStarted, undefined, {\n          authType: authType,\n        });\n        return;\n      }\n\n      if (message.data?.type === 'authentication-completed') {\n        const { idToken, refreshToken, user, authType, isSignup } =\n          message.data?.payload || {};\n\n        if (!user) {\n          console.error('Authentication completed but user data is missing');\n          return;\n        }\n\n        track(AnalyticsEvent.AuthenticationCompleted, user.uid, {\n          is_signup: isSignup,\n          auth_type: authType,\n        });\n        onAuthCompleted?.(user);\n        updatePublicTokens(idToken, refreshToken);\n        setUser(user);\n        closeDialog();\n        return;\n      }\n    };\n\n    window.addEventListener('message', handler);\n\n    return () => window.removeEventListener('message', handler);\n  }, [setUser, updatePublicTokens, onAuthCompleted, track, closeDialog]);\n\n  return isOpen ? (\n    <iframe\n      src={iframeUrl}\n      title=\"Arena Authentication\"\n      style={{\n        position: 'fixed',\n        top: 0,\n        left: 0,\n        width: '100vw',\n        height: '100vh',\n        zIndex: 9999999999,\n      }}\n    ></iframe>\n  ) : null;\n}\n","import React, { useEffect } from 'react';\nimport { useTokenStore } from '../stores/token-store';\nimport { useAuthServices } from '../services/auth/use-auth-services';\nimport { ExchangeTokensResponse } from '../services/auth/types';\n\nexport function AnonymousTokenProvider({\n  children,\n}: {\n  children: React.ReactNode;\n}) {\n  const tokens = useTokenStore(state => state.tokens);\n  const updateAnonymousToken = useTokenStore(\n    state => state.updateAnonymousToken\n  );\n  const { getAnonymousIdentityToken } = useAuthServices();\n\n  useEffect(() => {\n    if (!tokens.anonymous.idToken) {\n      getAnonymousIdentityToken().then((token: ExchangeTokensResponse) => {\n        updateAnonymousToken(token.access_token);\n      });\n    }\n  }, [\n    tokens.anonymous.idToken,\n    updateAnonymousToken,\n    getAnonymousIdentityToken,\n  ]);\n\n  return children;\n}\n","import { ExchangeTokensResponse } from './types';\nimport { request } from '../../utils/request';\nimport { useConfig } from '../../context/config-provider';\n\nexport function useAuthServices() {\n  const { config } = useConfig();\n  const identityUrl = config.identityServiceUrl;\n\n  async function getAnonymousIdentityToken(): Promise<ExchangeTokensResponse> {\n    const url = `${identityUrl}/anonymous-token`;\n    return await request('POST', url);\n  }\n\n  return {\n    getAnonymousIdentityToken,\n  };\n}\n","import { AuthDialogProvider } from './auth-dialog-provider';\nimport { QueryClient, QueryClientProvider } from '@tanstack/react-query';\nimport { UserProvider } from './user-provider';\nimport { ConfigProvider } from './config-provider';\nimport AuthDialog from '../dialog';\nimport { AnonymousTokenProvider } from './anonymous-token-provider';\n\nexport function AuthProvider({\n  children,\n  queryClient,\n  environment,\n}: {\n  children: React.ReactNode;\n  queryClient?: QueryClient;\n  environment?: 'production' | 'development';\n}) {\n  queryClient = queryClient || new QueryClient();\n\n  return (\n    <QueryClientProvider client={queryClient}>\n      <ConfigProvider environment={environment}>\n        <UserProvider>\n          <AuthDialogProvider>\n            <AnonymousTokenProvider>\n              {children}\n              <AuthDialog />\n            </AnonymousTokenProvider>\n          </AuthDialogProvider>\n        </UserProvider>\n      </ConfigProvider>\n    </QueryClientProvider>\n  );\n}\n\nexport { useAuthDialog } from './auth-dialog-provider';\n"],"names":["AuthDialogContext","createContext","undefined","AuthDialogProvider","children","isOpen","setIsOpen","useState","appName","setAppName","appDescription","setAppDescription","onAuthCompleted","setOnAuthCompleted","trackOptions","setTrackOptions","language","setLanguage","_jsx","Provider","value","openDialog","closeDialog","onOpenChange","open","useAuthDialog","context","useContext","Error","getConfig","environment","isDev","profileServiceUrl","identityServiceUrl","refreshTokenApiKey","authIframeUrl","debug","ConfigContext","ConfigProvider","config","useConfig","defaultHeaders","async","request","method","url","options","response","fetch","headers","ok","statusText","json","createStoreImpl","createState","state","listeners","Set","setState","partial","replace","nextState","Object","is","previousState","assign","forEach","listener","getState","api","getInitialState","initialState","subscribe","add","delete","identity","arg","createImpl","createStore","useBoundStore","selector","slice","React","useSyncExternalStore","useCallback","useDebugValue","useStore","create","subscribeWithSelector","fn","set","get","origSubscribe","optListener","equalityFn","currentSlice","nextSlice","previousSlice","fireImmediately","TokenType","AuthCookie","TOKEN_UPDATED_EVENT","dispatchTokenUpdatedEvent","type","params","document","dispatchEvent","CustomEvent","detail","defaultTokens","public","idToken","Cookies","PUBLIC_ID_TOKEN","refreshToken","PUBLIC_REFRESH_TOKEN","anonymous","ANONYMOUS_ID_TOKEN","guest","GUEST_ID_TOKEN","custom","CUSTOM_ID_TOKEN","useTokenStore","updatePublicTokensHelper","source","tokens","expires","PUBLIC","updateAnonymousTokenHelper","ANONYMOUS","updateGuestTokensHelper","GUEST","updateCustomTokenHelper","CUSTOM","clearPublicTokensHelper","remove","clearAnonymousTokensHelper","clearGuestTokensHelper","clearCustomTokensHelper","localStorage","removeItem","CUSTOM_USER","getToken","getMostPrivilegedToken","includes","getRefreshToken","updatePublicTokens","updateAnonymousToken","updateGuestTokens","updateCustomToken","clearTokens","clearPublicTokens","clearAnonymousTokens","clearGuestTokens","clearCustomTokens","silentUpdatePublicTokens","silentUpdateAnonymousToken","silentUpdateGuestTokens","silentUpdateCustomToken","silentClearPublicTokens","silentClearAnonymousTokens","silentClearGuestTokens","silentClearCustomTokens","useTokenEventListener","eventSourceRef","useRef","Math","random","toString","substr","useEffect","handleTokenUpdate","event","current","addEventListener","removeEventListener","eventSource","useTokens","useToken","AnalyticsWidgetType","AnalyticsEvent","useProfileServices","token","refreshPublicTokens","useUserActions","profileUrl","getPublicProfile","userId","updatePublicProfile","Authorization","payload","text","status","errors","JSON","parse","contentType","error","console","securedRequest","body","stringify","useUserStore","user","publicProfile","refreshedTokenLoaded","setUser","setPublicProfile","setUserByTokenId","jwtDecode","userProps","uid","user_id","displayName","safeDisplayName","email","photoURL","safePhotoURL","handle","logout","tokenStore","Event","URLSearchParams","refresh_token","grant_type","data","id_token","loadStoredUser","publicIdToken","publicRefreshToken","customIdToken","getItem","customUser","parsedUser","ssoV2Exchange","ssoSourceID","jwt","env","signedUserData","decodedUser","sub","useUser","UserProvider","getPublicProfileService","mutateAsync","useMutation","mutationFn","loadPublicProfile","profile","ANONYMOUS_ID_KEY","LS_KEYS","getOrSetAnonymousId","existing","id","crypto","randomUUID","setItem","parseCampaign","u","out","k","v","searchParams","keys","length","buildRudderContext","w","window","d","s","screen","URL","location","href","ref","referrer","domain","hostname","rememberInitialReferrer","initial_referrer","initial_referring_domain","channel","anonymousId","locale","navigator","userAgent","timezone","Intl","DateTimeFormat","resolvedOptions","timeZone","os","name","platform","version","page","path","pathname","referring_domain","search","title","density","devicePixelRatio","height","width","innerHeight","innerWidth","campaign","getIdentifier","identifier","currentAnonymousId","warn","newAnonymousId","c","r","getCanonicalUrl","canonicalMeta","querySelector","urlObj","removeParamsFromUrl","getEventProperties","widgetType","properties","widget_type","canonical_url","snippet_id","__ARENA__","snippetId","timestamp","Date","toISOString","integrations","All","getEventHeaders","writeKey","btoa","useTrack","track","analytics","rsWriteKey","dataPlaneUrl","rsDataPlaneUrl","trackProperties","site_id","siteId","widget_id","widgetId","trigger","AuthDialog","frameAppName","frameAppDescription","iframeUrl","handler","message","authType","AuthenticationStarted","isSignup","AuthenticationCompleted","is_signup","auth_type","AuthenticationViewed","src","style","position","top","left","zIndex","AnonymousTokenProvider","getAnonymousIdentityToken","identityUrl","useAuthServices","then","access_token","queryClient","QueryClient","QueryClientProvider","client","_jsxs"],"mappings":"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","x_google_ignoreList":[4,5,6]}
|