@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.esm.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{jsx as e,jsxs as t}from"react/jsx-runtime";import{createContext as n,useContext as o,useState as r,useRef as i,useEffect as s,useCallback as a}from"react";import{useMutation as c,QueryClient as u,QueryClientProvider as l}from"@tanstack/react-query";import{create as d}from"zustand";import{subscribeWithSelector as k}from"zustand/middleware";import p from"js-cookie";import{jwtDecode as m}from"jwt-decode";const T=n(void 0),h=({children:t})=>{const[n,o]=r(!1),[i,s]=r(void 0),[a,c]=r(void 0),[u,l]=r(void 0),[d,k]=r(void 0);return e(T.Provider,{value:{isOpen:n,appName:i,appDescription:a,trackOptions:d,onAuthCompleted:u,openDialog:({trackOptions:e,appName:t,appDescription:n,onAuthCompleted:r})=>{o(!0),k(e),s(t),c(n),l(r)},closeDialog:()=>o(!1),onOpenChange:e=>o(e)},children:t})},f=()=>{const e=o(T);if(!e)throw new Error("useAuthDialog must be used within an AuthDialogProvider");return e},g=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}},y=n(void 0),U=({children:t,environment:n="development"})=>{const o=g(n);return e(y.Provider,{value:{config:o,environment:n},children:t})},S=()=>{const e=o(y);if(!e)throw new Error("useConfig must be used within a ConfigProvider");return e},v={"Content-Type":"application/json"};async function I(e,t,n={}){const o=await fetch(t,{...n,method:e,headers:{"Content-Type":"application/json",...n.headers}});if(!o.ok)throw new Error(`Error: ${o.statusText}`);return o.json()}var w,_;!function(e){e.ANONYMOUS="anonymous",e.GUEST="guest",e.PUBLIC="public",e.CUSTOM="custom"}(w||(w={})),function(e){e.PUBLIC_ID_TOKEN="arena-auth-public-id-token",e.PUBLIC_REFRESH_TOKEN="arena-auth-public-refresh-token",e.ANONYMOUS_ID_TOKEN="arena-auth-anonymous-id-token",e.GUEST_ID_TOKEN="arena-auth-guest-id-token",e.CUSTOM_ID_TOKEN="arena-auth-custom-id-token",e.CUSTOM_USER="arena-auth-custom-user"}(_||(_={}));const O="arena-auth-token-updated";function P(e,t){document.dispatchEvent(new CustomEvent(O,{detail:{...t,type:e}}))}const E={public:{idToken:p.get(_.PUBLIC_ID_TOKEN)||null,refreshToken:p.get(_.PUBLIC_REFRESH_TOKEN)||null},anonymous:{idToken:p.get(_.ANONYMOUS_ID_TOKEN)||null},guest:{idToken:p.get(_.GUEST_ID_TOKEN)||null},custom:{idToken:p.get(_.CUSTOM_ID_TOKEN)||null}},C=d()(k((e,t)=>{const n=(n,o,r=!0,i)=>{n===t().tokens.public.idToken&&o===t().tokens.public.refreshToken||(e(e=>({tokens:{...e.tokens,public:{idToken:n,refreshToken:o}}})),p.set(_.PUBLIC_ID_TOKEN,n,{expires:1/24}),p.set(_.PUBLIC_REFRESH_TOKEN,o,{expires:30}),r&&P(w.PUBLIC,{idToken:n,refreshToken:o,source:i}))},o=(n,o=!0,r)=>{n!==t().tokens.anonymous.idToken&&(e(e=>({tokens:{...e.tokens,anonymous:{idToken:n}}})),p.set(_.ANONYMOUS_ID_TOKEN,n,{expires:1/24}),o&&P(w.ANONYMOUS,{idToken:n,source:r}))},r=(n,o=!0,r)=>{n!==t().tokens.guest.idToken&&(e(e=>({tokens:{...e.tokens,guest:{idToken:n}}})),p.set(_.GUEST_ID_TOKEN,n,{expires:1/24}),o&&P(w.GUEST,{idToken:n,source:r}))},i=(n,o=!0,r)=>{n!==t().tokens.custom.idToken&&(e(e=>({tokens:{...e.tokens,custom:{idToken:n}}})),p.set(_.CUSTOM_ID_TOKEN,n),o&&P(w.CUSTOM,{idToken:n,source:r}))},s=(t=!0,n)=>{p.remove(_.PUBLIC_ID_TOKEN),p.remove(_.PUBLIC_REFRESH_TOKEN),e(e=>({tokens:{...e.tokens,public:{idToken:null,refreshToken:null}}})),t&&P(w.PUBLIC,{idToken:null,source:n})},a=(t=!0,n)=>{p.remove(_.ANONYMOUS_ID_TOKEN),e(e=>({tokens:{...e.tokens,anonymous:{idToken:null}}})),t&&P(w.ANONYMOUS,{idToken:null,source:n})},c=(t=!0,n)=>{p.remove(_.GUEST_ID_TOKEN),e(e=>({tokens:{...e.tokens,guest:{idToken:null}}})),t&&P(w.GUEST,{idToken:null,source:n})},u=(t=!0,n)=>{p.remove(_.CUSTOM_ID_TOKEN),localStorage.removeItem(_.CUSTOM_ID_TOKEN),localStorage.removeItem(_.CUSTOM_USER),e(e=>({tokens:{...e.tokens,custom:{idToken:null}}})),t&&P(w.CUSTOM,{idToken:null,source:n})};return{tokens:E,getToken:e=>t().tokens[e]?.idToken||null,getMostPrivilegedToken:(e=[w.PUBLIC,w.GUEST,w.ANONYMOUS])=>t().tokens.custom.idToken&&e.includes(w.CUSTOM)?{type:w.CUSTOM,idToken:t().tokens.custom.idToken}:t().tokens.public.idToken&&e.includes(w.PUBLIC)?{type:w.PUBLIC,idToken:t().tokens.public.idToken}:t().tokens.guest.idToken&&e.includes(w.GUEST)?{type:w.GUEST,idToken:t().tokens.guest.idToken}:t().tokens.anonymous.idToken&&e.includes(w.ANONYMOUS)?{type:w.ANONYMOUS,idToken:t().tokens.anonymous.idToken}:null,getRefreshToken:e=>t().tokens[e]?.refreshToken||null,updatePublicTokens:(e,t,o)=>{n(e,t,!0,o)},updateAnonymousToken:(e,t)=>{o(e,!0,t)},updateGuestTokens:(e,t)=>{r(e,!0,t)},updateCustomToken:(e,t)=>{i(e,!0,t)},clearTokens:e=>{s(!0,e),a(!0,e),c(!0,e),u(!0,e)},clearPublicTokens:e=>{s(!0,e)},clearAnonymousTokens:e=>{a(!0,e)},clearGuestTokens:e=>{c(!0,e)},clearCustomTokens:e=>{u(!0,e)},silentUpdatePublicTokens:(e,t)=>{n(e,t,!1)},silentUpdateAnonymousToken:e=>{o(e,!1)},silentUpdateGuestTokens:e=>{r(e,!1)},silentUpdateCustomToken:e=>{i(e,!1)},silentClearPublicTokens:()=>{s(!1)},silentClearAnonymousTokens:()=>{a(!1)},silentClearGuestTokens:()=>{c(!1)},silentClearCustomTokens:()=>{u(!1)}}}));function N(){const e=C(e=>e.silentUpdatePublicTokens),t=C(e=>e.silentUpdateAnonymousToken),n=C(e=>e.silentUpdateGuestTokens),o=C(e=>e.silentUpdateCustomToken),r=C(e=>e.clearTokens),a=C(e=>e.silentClearPublicTokens),c=C(e=>e.silentClearAnonymousTokens),u=C(e=>e.silentClearGuestTokens),l=C(e=>e.silentClearCustomTokens),d=i(`widget-${Math.random().toString(36).substr(2,9)}`);return s(()=>{const r=r=>{const{idToken:i,refreshToken:s,type:k,source:p}=r.detail;if(p!==d.current)switch(k){case w.PUBLIC:if(i){if(!s)throw new Error("Refresh token is required for public tokens");e(i,s)}else a();break;case w.ANONYMOUS:i?t(i):c();break;case w.GUEST:i?n(i):u();break;case w.CUSTOM:i?o(i):l()}};return document.addEventListener(O,r),()=>{document.removeEventListener(O,r)}},[e,t,n,o,r,a,c,u,l]),{eventSource:d.current}}function b(){const e=C(e=>e.getToken),t=C(e=>e.getMostPrivilegedToken),n=C(e=>e.getRefreshToken),o=C(e=>e.updatePublicTokens),r=C(e=>e.updateAnonymousToken),i=C(e=>e.updateGuestTokens),s=C(e=>e.updateCustomToken),a=C(e=>e.clearTokens),c=C(e=>e.clearPublicTokens),u=C(e=>e.clearCustomTokens),{eventSource:l}=N();return{getToken:e,getMostPrivilegedToken:t,getRefreshToken:n,updatePublicTokens:(e,t)=>o(e,t,l),updateAnonymousToken:e=>r(e,l),updateGuestTokens:e=>i(e,l),updateCustomToken:e=>s(e,l),clearTokens:()=>a(l),clearPublicTokens:()=>c(l),clearCustomTokens:()=>u(l)}}function A(e){return C(t=>t.tokens[e])}function x(e){return C(t=>t.tokens[e]?.idToken)}function L(e){return C(t=>t.tokens[e]?.refreshToken)}var D,R;function K(){const e=A(w.PUBLIC),{refreshPublicTokens:t}=F(),{config:n}=S(),o=n.profileServiceUrl;return{getPublicProfile:async function(e){const t=`${o}/public/users/${e}/profile?fields=bio,photoURL,displayName,location,handle`;return await I("GET",t)},updatePublicProfile:async function(r){const i=`${o}/me/profile/personal`;await async function(e){const{method:t,url:n,options:o={},token:r}=e;if(!r)throw new Error("No authentication token found");const i={...v,...o.headers,Authorization:`Bearer ${r}`},s={...o,method:t,headers:i},a=await fetch(n,s);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 c=a.headers.get("content-type");if(!c||!c.includes("application/json"))return a;const u=await a.text();if(!u)return null;try{return JSON.parse(u)}catch(e){throw console.error(e),new Error("Invalid JSON response from server")}}({method:"PUT",url:i,options:{body:JSON.stringify(r)},token:e.idToken}),t({refreshTokenApiKey:n.refreshTokenApiKey})}}}!function(e){e.AvatarProfile="avatar-profile",e.AvatarChat="avatar-chat",e.Comments="comments",e.GlobalProfile="global-profile",e.GroupChat="group-chat",e.Polls="polls",e.UniversalSnippet="universal-snippet"}(D||(D={})),function(e){e.AuthenticationCompleted="Authentication Completed",e.AuthenticationStarted="Authentication Started",e.AuthenticationViewed="Authentication Viewed"}(R||(R={}));const M=d()(k((e,t)=>({user:null,publicProfile:null,refreshedTokenLoaded:!1,setUser:t=>{e({user:t})},setPublicProfile:t=>{e({publicProfile:t})},setUserByTokenId:t=>{try{const n=m(t),o={uid:n.user_id,displayName:n.safeDisplayName,email:n.email,photoURL:n.safePhotoURL,handle:n.handle};e({user:o})}catch(e){console.error(e)}},logout:()=>{try{const t=C.getState();t.clearPublicTokens(),t.clearCustomTokens(),e({user:null}),document.dispatchEvent(new Event("arena-comments-logout"))}catch(e){console.error(e)}},refreshPublicTokens:async e=>{try{const n=p.get(_.PUBLIC_REFRESH_TOKEN);if(!n)throw new Error("No refresh token found");const o=`${"https://securetoken.googleapis.com/v1/token?key="}${e.refreshTokenApiKey}`,r=await fetch(o,{method:"POST",body:new URLSearchParams({refresh_token:n,grant_type:"refresh_token"})}),i=await r.json(),{setUserByTokenId:s}=t();s(i.id_token);C.getState().updatePublicTokens(i.id_token,i.refresh_token)}catch(e){console.error(e);const{logout:n}=t();n()}},loadStoredUser:async n=>{const o=p.get(_.PUBLIC_ID_TOKEN),r=p.get(_.PUBLIC_REFRESH_TOKEN),i=localStorage.getItem(_.CUSTOM_ID_TOKEN),s=localStorage.getItem(_.CUSTOM_USER);if(i&&s){const t=JSON.parse(s);e({user:t});C.getState().updateCustomToken(i)}else if(o){const{setUserByTokenId:e}=t();e(o)}else if(r&&n){const{refreshPublicTokens:e}=t();await e(n)}e({refreshedTokenLoaded:!0})},ssoV2Exchange:async(e,n,o)=>{try{const r=g(o??"production"),i=`${r.profileServiceUrl}/sso/sources/${e}/user`,s=await I("POST",i,{body:JSON.stringify({signedUserData:n})});if(s){const e=m(s.token),{setUser:n,setPublicProfile:o}=t();n({uid:e?.sub,email:e?.email,displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle}),o({displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle});C.getState().updateCustomToken(s.token)}return s}catch(e){throw console.error("SSO V2 Exchange failed:",e),e}}})));function B(){return M(e=>e.user)}function G(){return M(e=>e.publicProfile)}function $(){return M(e=>e.refreshedTokenLoaded)}function F(){return{setUser:M(e=>e.setUser),setPublicProfile:M(e=>e.setPublicProfile),logout:M(e=>e.logout),refreshPublicTokens:M(e=>e.refreshPublicTokens),setUserByTokenId:M(e=>e.setUserByTokenId),loadStoredUser:M(e=>e.loadStoredUser),ssoV2Exchange:M(e=>e.ssoV2Exchange)}}function J(){const{updatePublicProfile:e}=K();return{updatePublicProfile:e}}function Y(){return{user:M(e=>e.user),publicProfile:M(e=>e.publicProfile),refreshedTokenLoaded:M(e=>e.refreshedTokenLoaded)}}function j({children:e}){const{config:t}=S(),n=B(),{setPublicProfile:o,loadStoredUser:r}=F(),{getPublicProfile:i}=K(),{mutateAsync:u}=c({mutationFn:i}),l=a(async()=>{if(n?.uid){const e=await u(n.uid);o(e)}},[n?.uid,u,o]);return s(()=>{l()},[l]),s(()=>{r(t)},[t,r]),e}const H="arenaAnonymousId",V="rs_anonymous_id",z="rs_initial_referrer",q="rs_initial_referring_domain";function W(){const e=localStorage.getItem(V);if(e)return e;const t=crypto.randomUUID();return localStorage.setItem(V,t),t}function Z(e){const t={};return["utm_source","utm_medium","utm_campaign","utm_term","utm_content"].forEach(n=>{const o=e.searchParams.get(n);o&&(t[n]=o)}),Object.keys(t).length?t:void 0}function Q(){const e=window,t=document,n=window.screen,o=new URL(e.location.href);!function(){if(!localStorage.getItem(z)){const e=document.referrer||"$direct",t="$direct"!==e?new URL(e).hostname:"";localStorage.setItem(z,e),localStorage.setItem(q,t)}}();const r=localStorage.getItem(z)||"$direct",i=localStorage.getItem(q)||"";return{channel:"web",anonymousId:W(),locale:navigator.language,userAgent:navigator.userAgent,timezone:Intl.DateTimeFormat().resolvedOptions().timeZone,os:{name:navigator.platform,version:void 0},page:{path:o.pathname,referrer:t.referrer||"$direct",referring_domain:t.referrer?new URL(t.referrer).hostname:"",search:o.search,title:t.title,url:o.toString(),initial_referrer:r,initial_referring_domain:i},screen:{density:e.devicePixelRatio||1,height:n.height,width:n.width,innerHeight:e.innerHeight,innerWidth:e.innerWidth},campaign:Z(o)}}function X(e={}){const t={};e.userId&&(t.userId=e.userId);let n=null;try{n=localStorage.getItem(H)}catch(e){console.warn("Failed to access localStorage:",e)}if(e.anonymousId){t.anonymousId=e.anonymousId;try{localStorage.setItem(H,e.anonymousId)}catch(e){console.warn("Failed to save anonymousId to localStorage:",e)}}else if(n)t.anonymousId=n;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(H,e)}catch(e){console.warn("Failed to save new anonymousId to localStorage:",e)}}return t}function ee(){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 te(e,t,n){return{properties:{widget_type:e,url:window.location.href,domain:window.location.hostname,title:window.document.title,canonical_url:ee(),snippet_id:window.__ARENA__?.snippetId||null,...t},context:Q(),timestamp:(new Date).toISOString(),integrations:{All:!0},...X(n)}}function ne(e){return{"Content-Type":"application/json",Authorization:"Basic "+btoa(`${e}:`)}}function oe(e){return a((t,n,o)=>{if(!e)return;const r=(i=e.rsWriteKey,s=e.rsDataPlaneUrl,{page:async(e,t,n)=>{const o=await fetch(`${s}/v1/page`,{method:"POST",headers:ne(i),body:JSON.stringify({type:"page",...te(e,t,n)})});if(o.ok)return await o.text();throw new Error("Failed to send page event to Rudderstack")},track:async(e,t,n,o)=>{const r=await fetch(`${s}/v1/track`,{method:"POST",headers:ne(i),body:JSON.stringify({event:t,type:"track",...te(e,n,o)})});if(r.ok)return await r.text();throw new Error("Failed to send track event to Rudderstack")}});var i,s;const a={site_id:e.siteId,widget_id:e.widgetId,trigger:e.trigger,...o};r.track(e.widgetType,t,a,n?{userId:n}:void 0)},[e])}function re(){const{appName:t,appDescription:n,trackOptions:o,isOpen:r,closeDialog:i,onAuthCompleted:a}=f(),c=t||"Arena AI Chat",u=n||"Arena AI Chat",{setUser:l}=F(),{updatePublicTokens:d}=b(),{config:k}=S(),p=oe(o);let m=`${k.authIframeUrl}/?app-name=${c}&app-description=${u}`;return m+="&language=en",s(()=>{const e=e=>{if("arena-authentication"===e.data?.source)if("canceled"!==e.data?.type)if("authentication-viewed"!==e.data?.type){if("authentication-started"===e.data?.type){const{authType:t}=e.data?.payload||{};return void p(R.AuthenticationStarted,void 0,{authType:t})}if("authentication-completed"===e.data?.type){const{idToken:t,refreshToken:n,user:o,authType:r,isSignup:s}=e.data?.payload||{};return o?(p(R.AuthenticationCompleted,o.uid,{is_signup:s,auth_type:r}),a?.(o),d(t,n),l(o),void i()):void console.error("Authentication completed but user data is missing")}}else p(R.AuthenticationViewed);else i()};return window.addEventListener("message",e),()=>window.removeEventListener("message",e)},[l,d,a,p,i]),r?e("iframe",{src:m,title:"Arena Authentication",style:{position:"fixed",top:0,left:0,width:"100vw",height:"100vh",zIndex:9999999999}}):null}function ie({children:e}){const t=C(e=>e.tokens),n=C(e=>e.updateAnonymousToken),{getAnonymousIdentityToken:o}=function(){const{config:e}=S(),t=e.identityServiceUrl;return{getAnonymousIdentityToken:async function(){const e=`${t}/anonymous-token`;return await I("POST",e)}}}();return s(()=>{t.anonymous.idToken||o().then(e=>{n(e.access_token)})},[t.anonymous.idToken,n,o]),e}function se({children:n,queryClient:o,environment:r}){return o=o||new u,e(l,{client:o,children:e(U,{environment:r,children:e(j,{children:e(h,{children:t(ie,{children:[n,e(re,{})]})})})})})}export{R as AnalyticsEvent,D as AnalyticsWidgetType,_ as AuthCookie,se as AuthProvider,w as TokenType,f as useAuthDialog,G as usePublicProfile,L as useRefreshToken,$ as useRefreshedTokenLoaded,A as useToken,N as useTokenEventListener,C as useTokenStore,x as useTokenValue,b as useTokens,J as useUpdateProfile,B as useUser,F as useUserActions,M as useUserStore,Y as useUserWithProfile};
|
|
2
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.esm.js","sources":["../src/context/auth-dialog-provider.tsx","../src/config/index.ts","../src/context/config-provider.tsx","../src/utils/request.ts","../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","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","TokenType","AuthCookie","TOKEN_UPDATED_EVENT","dispatchTokenUpdatedEvent","type","params","document","dispatchEvent","CustomEvent","detail","defaultTokens","public","idToken","Cookies","get","PUBLIC_ID_TOKEN","refreshToken","PUBLIC_REFRESH_TOKEN","anonymous","ANONYMOUS_ID_TOKEN","guest","GUEST_ID_TOKEN","custom","CUSTOM_ID_TOKEN","useTokenStore","create","subscribeWithSelector","set","updatePublicTokensHelper","source","tokens","state","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","useTokenValue","useRefreshToken","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","getState","Event","URLSearchParams","refresh_token","grant_type","data","id_token","loadStoredUser","publicIdToken","publicRefreshToken","customIdToken","getItem","customUser","parsedUser","ssoV2Exchange","ssoSourceID","jwt","env","signedUserData","decodedUser","sub","useUser","usePublicProfile","useRefreshedTokenLoaded","useUpdateProfile","useUserWithProfile","UserProvider","getPublicProfileService","mutateAsync","useMutation","mutationFn","loadPublicProfile","useCallback","profile","ANONYMOUS_ID_KEY","LS_KEYS","getOrSetAnonymousId","existing","id","crypto","randomUUID","setItem","parseCampaign","u","out","forEach","k","v","searchParams","Object","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","replace","c","r","getCanonicalUrl","canonicalMeta","querySelector","urlObj","removeParamsFromUrl","getEventProperties","widgetType","properties","identity","widget_type","canonical_url","snippet_id","__ARENA__","snippetId","timestamp","Date","toISOString","integrations","All","getEventHeaders","writeKey","btoa","useTrack","analytics","rsWriteKey","dataPlaneUrl","rsDataPlaneUrl","track","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","AuthProvider","queryClient","QueryClient","QueryClientProvider","client","_jsxs"],"mappings":"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"}
|
|
1
|
+
import{jsx as e,jsxs as t}from"react/jsx-runtime";import{createContext as n,useContext as o,useState as r,useRef as i,useEffect as s,useCallback as a}from"react";import{useMutation as u,QueryClient as c,QueryClientProvider as l}from"@tanstack/react-query";import{create as d}from"zustand";import{subscribeWithSelector as k}from"zustand/middleware";import p from"js-cookie";import{jwtDecode as m}from"jwt-decode";const T=n(void 0),h=({children:t})=>{const[n,o]=r(!1),[i,s]=r(void 0),[a,u]=r(void 0),[c,l]=r(void 0),[d,k]=r(void 0),[p,m]=r(void 0);return e(T.Provider,{value:{isOpen:n,appName:i,language:p,appDescription:a,trackOptions:d,onAuthCompleted:c,openDialog:({trackOptions:e,appName:t,language:n,appDescription:r,onAuthCompleted:i})=>{o(!0),k(e),s(t),m(n),u(r),l(i)},closeDialog:()=>o(!1),onOpenChange:e=>o(e)},children:t})},f=()=>{const e=o(T);if(!e)throw new Error("useAuthDialog must be used within an AuthDialogProvider");return e},g=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}},y=n(void 0),U=({children:t,environment:n="development"})=>{const o=g(n);return e(y.Provider,{value:{config:o,environment:n},children:t})},S=()=>{const e=o(y);if(!e)throw new Error("useConfig must be used within a ConfigProvider");return e},v={"Content-Type":"application/json"};async function I(e,t,n={}){const o=await fetch(t,{...n,method:e,headers:{"Content-Type":"application/json",...n.headers}});if(!o.ok)throw new Error(`Error: ${o.statusText}`);return o.json()}var w,_;!function(e){e.ANONYMOUS="anonymous",e.GUEST="guest",e.PUBLIC="public",e.CUSTOM="custom"}(w||(w={})),function(e){e.PUBLIC_ID_TOKEN="arena-auth-public-id-token",e.PUBLIC_REFRESH_TOKEN="arena-auth-public-refresh-token",e.ANONYMOUS_ID_TOKEN="arena-auth-anonymous-id-token",e.GUEST_ID_TOKEN="arena-auth-guest-id-token",e.CUSTOM_ID_TOKEN="arena-auth-custom-id-token",e.CUSTOM_USER="arena-auth-custom-user"}(_||(_={}));const O="arena-auth-token-updated";function P(e,t){document.dispatchEvent(new CustomEvent(O,{detail:{...t,type:e}}))}const E={public:{idToken:p.get(_.PUBLIC_ID_TOKEN)||null,refreshToken:p.get(_.PUBLIC_REFRESH_TOKEN)||null},anonymous:{idToken:p.get(_.ANONYMOUS_ID_TOKEN)||null},guest:{idToken:p.get(_.GUEST_ID_TOKEN)||null},custom:{idToken:p.get(_.CUSTOM_ID_TOKEN)||null}},C=d()(k((e,t)=>{const n=(n,o,r=!0,i)=>{n===t().tokens.public.idToken&&o===t().tokens.public.refreshToken||(e(e=>({tokens:{...e.tokens,public:{idToken:n,refreshToken:o}}})),p.set(_.PUBLIC_ID_TOKEN,n,{expires:1/24}),p.set(_.PUBLIC_REFRESH_TOKEN,o,{expires:30}),r&&P(w.PUBLIC,{idToken:n,refreshToken:o,source:i}))},o=(n,o=!0,r)=>{n!==t().tokens.anonymous.idToken&&(e(e=>({tokens:{...e.tokens,anonymous:{idToken:n}}})),p.set(_.ANONYMOUS_ID_TOKEN,n,{expires:1/24}),o&&P(w.ANONYMOUS,{idToken:n,source:r}))},r=(n,o=!0,r)=>{n!==t().tokens.guest.idToken&&(e(e=>({tokens:{...e.tokens,guest:{idToken:n}}})),p.set(_.GUEST_ID_TOKEN,n,{expires:1/24}),o&&P(w.GUEST,{idToken:n,source:r}))},i=(n,o=!0,r)=>{n!==t().tokens.custom.idToken&&(e(e=>({tokens:{...e.tokens,custom:{idToken:n}}})),p.set(_.CUSTOM_ID_TOKEN,n),o&&P(w.CUSTOM,{idToken:n,source:r}))},s=(t=!0,n)=>{p.remove(_.PUBLIC_ID_TOKEN),p.remove(_.PUBLIC_REFRESH_TOKEN),e(e=>({tokens:{...e.tokens,public:{idToken:null,refreshToken:null}}})),t&&P(w.PUBLIC,{idToken:null,source:n})},a=(t=!0,n)=>{p.remove(_.ANONYMOUS_ID_TOKEN),e(e=>({tokens:{...e.tokens,anonymous:{idToken:null}}})),t&&P(w.ANONYMOUS,{idToken:null,source:n})},u=(t=!0,n)=>{p.remove(_.GUEST_ID_TOKEN),e(e=>({tokens:{...e.tokens,guest:{idToken:null}}})),t&&P(w.GUEST,{idToken:null,source:n})},c=(t=!0,n)=>{p.remove(_.CUSTOM_ID_TOKEN),localStorage.removeItem(_.CUSTOM_ID_TOKEN),localStorage.removeItem(_.CUSTOM_USER),e(e=>({tokens:{...e.tokens,custom:{idToken:null}}})),t&&P(w.CUSTOM,{idToken:null,source:n})};return{tokens:E,getToken:e=>t().tokens[e]?.idToken||null,getMostPrivilegedToken:(e=[w.PUBLIC,w.GUEST,w.ANONYMOUS])=>t().tokens.custom.idToken&&e.includes(w.CUSTOM)?{type:w.CUSTOM,idToken:t().tokens.custom.idToken}:t().tokens.public.idToken&&e.includes(w.PUBLIC)?{type:w.PUBLIC,idToken:t().tokens.public.idToken}:t().tokens.guest.idToken&&e.includes(w.GUEST)?{type:w.GUEST,idToken:t().tokens.guest.idToken}:t().tokens.anonymous.idToken&&e.includes(w.ANONYMOUS)?{type:w.ANONYMOUS,idToken:t().tokens.anonymous.idToken}:null,getRefreshToken:e=>t().tokens[e]?.refreshToken||null,updatePublicTokens:(e,t,o)=>{n(e,t,!0,o)},updateAnonymousToken:(e,t)=>{o(e,!0,t)},updateGuestTokens:(e,t)=>{r(e,!0,t)},updateCustomToken:(e,t)=>{i(e,!0,t)},clearTokens:e=>{s(!0,e),a(!0,e),u(!0,e),c(!0,e)},clearPublicTokens:e=>{s(!0,e)},clearAnonymousTokens:e=>{a(!0,e)},clearGuestTokens:e=>{u(!0,e)},clearCustomTokens:e=>{c(!0,e)},silentUpdatePublicTokens:(e,t)=>{n(e,t,!1)},silentUpdateAnonymousToken:e=>{o(e,!1)},silentUpdateGuestTokens:e=>{r(e,!1)},silentUpdateCustomToken:e=>{i(e,!1)},silentClearPublicTokens:()=>{s(!1)},silentClearAnonymousTokens:()=>{a(!1)},silentClearGuestTokens:()=>{u(!1)},silentClearCustomTokens:()=>{c(!1)}}}));function N(){const e=C(e=>e.silentUpdatePublicTokens),t=C(e=>e.silentUpdateAnonymousToken),n=C(e=>e.silentUpdateGuestTokens),o=C(e=>e.silentUpdateCustomToken),r=C(e=>e.clearTokens),a=C(e=>e.silentClearPublicTokens),u=C(e=>e.silentClearAnonymousTokens),c=C(e=>e.silentClearGuestTokens),l=C(e=>e.silentClearCustomTokens),d=i(`widget-${Math.random().toString(36).substr(2,9)}`);return s(()=>{const r=r=>{const{idToken:i,refreshToken:s,type:k,source:p}=r.detail;if(p!==d.current)switch(k){case w.PUBLIC:if(i){if(!s)throw new Error("Refresh token is required for public tokens");e(i,s)}else a();break;case w.ANONYMOUS:i?t(i):u();break;case w.GUEST:i?n(i):c();break;case w.CUSTOM:i?o(i):l()}};return document.addEventListener(O,r),()=>{document.removeEventListener(O,r)}},[e,t,n,o,r,a,u,c,l]),{eventSource:d.current}}function b(){const e=C(e=>e.getToken),t=C(e=>e.getMostPrivilegedToken),n=C(e=>e.getRefreshToken),o=C(e=>e.updatePublicTokens),r=C(e=>e.updateAnonymousToken),i=C(e=>e.updateGuestTokens),s=C(e=>e.updateCustomToken),a=C(e=>e.clearTokens),u=C(e=>e.clearPublicTokens),c=C(e=>e.clearCustomTokens),{eventSource:l}=N();return{getToken:e,getMostPrivilegedToken:t,getRefreshToken:n,updatePublicTokens:(e,t)=>o(e,t,l),updateAnonymousToken:e=>r(e,l),updateGuestTokens:e=>i(e,l),updateCustomToken:e=>s(e,l),clearTokens:()=>a(l),clearPublicTokens:()=>u(l),clearCustomTokens:()=>c(l)}}function A(e){return C(t=>t.tokens[e])}function x(e){return C(t=>t.tokens[e]?.idToken)}function L(e){return C(t=>t.tokens[e]?.refreshToken)}var D,R;function K(){const e=A(w.PUBLIC),{refreshPublicTokens:t}=F(),{config:n}=S(),o=n.profileServiceUrl;return{getPublicProfile:async function(e){const t=`${o}/public/users/${e}/profile?fields=bio,photoURL,displayName,location,handle`;return await I("GET",t)},updatePublicProfile:async function(r){const i=`${o}/me/profile/personal`;await async function(e){const{method:t,url:n,options:o={},token:r}=e;if(!r)throw new Error("No authentication token found");const i={...v,...o.headers,Authorization:`Bearer ${r}`},s={...o,method:t,headers:i},a=await fetch(n,s);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:i,options:{body:JSON.stringify(r)},token:e.idToken}),t({refreshTokenApiKey:n.refreshTokenApiKey})}}}!function(e){e.AvatarProfile="avatar-profile",e.AvatarChat="avatar-chat",e.Comments="comments",e.GlobalProfile="global-profile",e.GroupChat="group-chat",e.Polls="polls",e.UniversalSnippet="universal-snippet"}(D||(D={})),function(e){e.AuthenticationCompleted="Authentication Completed",e.AuthenticationStarted="Authentication Started",e.AuthenticationViewed="Authentication Viewed"}(R||(R={}));const M=d()(k((e,t)=>({user:null,publicProfile:null,refreshedTokenLoaded:!1,setUser:t=>{e({user:t})},setPublicProfile:t=>{e({publicProfile:t})},setUserByTokenId:t=>{try{const n=m(t),o={uid:n.user_id,displayName:n.safeDisplayName,email:n.email,photoURL:n.safePhotoURL,handle:n.handle};e({user:o})}catch(e){console.error(e)}},logout:()=>{try{const t=C.getState();t.clearPublicTokens(),t.clearCustomTokens(),e({user:null}),document.dispatchEvent(new Event("arena-comments-logout"))}catch(e){console.error(e)}},refreshPublicTokens:async e=>{try{const n=p.get(_.PUBLIC_REFRESH_TOKEN);if(!n)throw new Error("No refresh token found");const o=`${"https://securetoken.googleapis.com/v1/token?key="}${e.refreshTokenApiKey}`,r=await fetch(o,{method:"POST",body:new URLSearchParams({refresh_token:n,grant_type:"refresh_token"})}),i=await r.json(),{setUserByTokenId:s}=t();s(i.id_token);C.getState().updatePublicTokens(i.id_token,i.refresh_token)}catch(e){console.error(e);const{logout:n}=t();n()}},loadStoredUser:async n=>{const o=p.get(_.PUBLIC_ID_TOKEN),r=p.get(_.PUBLIC_REFRESH_TOKEN),i=localStorage.getItem(_.CUSTOM_ID_TOKEN),s=localStorage.getItem(_.CUSTOM_USER);if(i&&s){const t=JSON.parse(s);e({user:t});C.getState().updateCustomToken(i)}else if(o){const{setUserByTokenId:e}=t();e(o)}else if(r&&n){const{refreshPublicTokens:e}=t();await e(n)}e({refreshedTokenLoaded:!0})},ssoV2Exchange:async(e,n,o)=>{try{const r=g(o??"production"),i=`${r.profileServiceUrl}/sso/sources/${e}/user`,s=await I("POST",i,{body:JSON.stringify({signedUserData:n})});if(s){const e=m(s.token),{setUser:n,setPublicProfile:o}=t();n({uid:e?.sub,email:e?.email,displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle}),o({displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle});C.getState().updateCustomToken(s.token)}return s}catch(e){throw console.error("SSO V2 Exchange failed:",e),e}}})));function B(){return M(e=>e.user)}function G(){return M(e=>e.publicProfile)}function $(){return M(e=>e.refreshedTokenLoaded)}function F(){return{setUser:M(e=>e.setUser),setPublicProfile:M(e=>e.setPublicProfile),logout:M(e=>e.logout),refreshPublicTokens:M(e=>e.refreshPublicTokens),setUserByTokenId:M(e=>e.setUserByTokenId),loadStoredUser:M(e=>e.loadStoredUser),ssoV2Exchange:M(e=>e.ssoV2Exchange)}}function J(){const{updatePublicProfile:e}=K();return{updatePublicProfile:e}}function Y(){return{user:M(e=>e.user),publicProfile:M(e=>e.publicProfile),refreshedTokenLoaded:M(e=>e.refreshedTokenLoaded)}}function j({children:e}){const{config:t}=S(),n=B(),{setPublicProfile:o,loadStoredUser:r}=F(),{getPublicProfile:i}=K(),{mutateAsync:c}=u({mutationFn:i}),l=a(async()=>{if(n?.uid){const e=await c(n.uid);o(e)}},[n?.uid,c,o]);return s(()=>{l()},[l]),s(()=>{r(t)},[t,r]),e}const H="arenaAnonymousId",V="rs_anonymous_id",z="rs_initial_referrer",q="rs_initial_referring_domain";function W(){const e=localStorage.getItem(V);if(e)return e;const t=crypto.randomUUID();return localStorage.setItem(V,t),t}function Z(e){const t={};return["utm_source","utm_medium","utm_campaign","utm_term","utm_content"].forEach(n=>{const o=e.searchParams.get(n);o&&(t[n]=o)}),Object.keys(t).length?t:void 0}function Q(){const e=window,t=document,n=window.screen,o=new URL(e.location.href);!function(){if(!localStorage.getItem(z)){const e=document.referrer||"$direct",t="$direct"!==e?new URL(e).hostname:"";localStorage.setItem(z,e),localStorage.setItem(q,t)}}();const r=localStorage.getItem(z)||"$direct",i=localStorage.getItem(q)||"";return{channel:"web",anonymousId:W(),locale:navigator.language,userAgent:navigator.userAgent,timezone:Intl.DateTimeFormat().resolvedOptions().timeZone,os:{name:navigator.platform,version:void 0},page:{path:o.pathname,referrer:t.referrer||"$direct",referring_domain:t.referrer?new URL(t.referrer).hostname:"",search:o.search,title:t.title,url:o.toString(),initial_referrer:r,initial_referring_domain:i},screen:{density:e.devicePixelRatio||1,height:n.height,width:n.width,innerHeight:e.innerHeight,innerWidth:e.innerWidth},campaign:Z(o)}}function X(e={}){const t={};e.userId&&(t.userId=e.userId);let n=null;try{n=localStorage.getItem(H)}catch(e){console.warn("Failed to access localStorage:",e)}if(e.anonymousId){t.anonymousId=e.anonymousId;try{localStorage.setItem(H,e.anonymousId)}catch(e){console.warn("Failed to save anonymousId to localStorage:",e)}}else if(n)t.anonymousId=n;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(H,e)}catch(e){console.warn("Failed to save new anonymousId to localStorage:",e)}}return t}function ee(){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 te(e,t,n){return{properties:{widget_type:e,url:window.location.href,domain:window.location.hostname,title:window.document.title,canonical_url:ee(),snippet_id:window.__ARENA__?.snippetId||null,...t},context:Q(),timestamp:(new Date).toISOString(),integrations:{All:!0},...X(n)}}function ne(e){return{"Content-Type":"application/json",Authorization:"Basic "+btoa(`${e}:`)}}function oe(e){return a((t,n,o)=>{if(!e)return;const r=(i=e.rsWriteKey,s=e.rsDataPlaneUrl,{page:async(e,t,n)=>{const o=await fetch(`${s}/v1/page`,{method:"POST",headers:ne(i),body:JSON.stringify({type:"page",...te(e,t,n)})});if(o.ok)return await o.text();throw new Error("Failed to send page event to Rudderstack")},track:async(e,t,n,o)=>{const r=await fetch(`${s}/v1/track`,{method:"POST",headers:ne(i),body:JSON.stringify({event:t,type:"track",...te(e,n,o)})});if(r.ok)return await r.text();throw new Error("Failed to send track event to Rudderstack")}});var i,s;const a={site_id:e.siteId,widget_id:e.widgetId,trigger:e.trigger,...o};r.track(e.widgetType,t,a,n?{userId:n}:void 0)},[e])}function re(){const{appName:t,appDescription:n,language:o,trackOptions:r,isOpen:i,closeDialog:a,onAuthCompleted:u}=f(),c=t||"Arena AI Chat",l=n||"Arena AI Chat",{setUser:d}=F(),{updatePublicTokens:k}=b(),{config:p}=S(),m=oe(r),T=`${p.authIframeUrl}/?app-name=${c}&app-description=${l}&language=${o??"en"}`;return s(()=>{const e=e=>{if("arena-authentication"===e.data?.source)if("canceled"!==e.data?.type)if("authentication-viewed"!==e.data?.type){if("authentication-started"===e.data?.type){const{authType:t}=e.data?.payload||{};return void m(R.AuthenticationStarted,void 0,{authType:t})}if("authentication-completed"===e.data?.type){const{idToken:t,refreshToken:n,user:o,authType:r,isSignup:i}=e.data?.payload||{};return o?(m(R.AuthenticationCompleted,o.uid,{is_signup:i,auth_type:r}),u?.(o),k(t,n),d(o),void a()):void console.error("Authentication completed but user data is missing")}}else m(R.AuthenticationViewed);else a()};return window.addEventListener("message",e),()=>window.removeEventListener("message",e)},[d,k,u,m,a]),i?e("iframe",{src:T,title:"Arena Authentication",style:{position:"fixed",top:0,left:0,width:"100vw",height:"100vh",zIndex:9999999999}}):null}function ie({children:e}){const t=C(e=>e.tokens),n=C(e=>e.updateAnonymousToken),{getAnonymousIdentityToken:o}=function(){const{config:e}=S(),t=e.identityServiceUrl;return{getAnonymousIdentityToken:async function(){const e=`${t}/anonymous-token`;return await I("POST",e)}}}();return s(()=>{t.anonymous.idToken||o().then(e=>{n(e.access_token)})},[t.anonymous.idToken,n,o]),e}function se({children:n,queryClient:o,environment:r}){return o=o||new c,e(l,{client:o,children:e(U,{environment:r,children:e(j,{children:e(h,{children:t(ie,{children:[n,e(re,{})]})})})})})}export{R as AnalyticsEvent,D as AnalyticsWidgetType,_ as AuthCookie,se as AuthProvider,w as TokenType,f as useAuthDialog,G as usePublicProfile,L as useRefreshToken,$ as useRefreshedTokenLoaded,A as useToken,N as useTokenEventListener,C as useTokenStore,x as useTokenValue,b as useTokens,J as useUpdateProfile,B as useUser,F as useUserActions,M as useUserStore,Y as useUserWithProfile};
|
|
2
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.esm.js","sources":["../src/context/auth-dialog-provider.tsx","../src/config/index.ts","../src/context/config-provider.tsx","../src/utils/request.ts","../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","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","TokenType","AuthCookie","TOKEN_UPDATED_EVENT","dispatchTokenUpdatedEvent","type","params","document","dispatchEvent","CustomEvent","detail","defaultTokens","public","idToken","Cookies","get","PUBLIC_ID_TOKEN","refreshToken","PUBLIC_REFRESH_TOKEN","anonymous","ANONYMOUS_ID_TOKEN","guest","GUEST_ID_TOKEN","custom","CUSTOM_ID_TOKEN","useTokenStore","create","subscribeWithSelector","set","updatePublicTokensHelper","source","tokens","state","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","useTokenValue","useRefreshToken","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","getState","Event","URLSearchParams","refresh_token","grant_type","data","id_token","loadStoredUser","publicIdToken","publicRefreshToken","customIdToken","getItem","customUser","parsedUser","ssoV2Exchange","ssoSourceID","jwt","env","signedUserData","decodedUser","sub","useUser","usePublicProfile","useRefreshedTokenLoaded","useUpdateProfile","useUserWithProfile","UserProvider","getPublicProfileService","mutateAsync","useMutation","mutationFn","loadPublicProfile","useCallback","profile","ANONYMOUS_ID_KEY","LS_KEYS","getOrSetAnonymousId","existing","id","crypto","randomUUID","setItem","parseCampaign","u","out","forEach","k","v","searchParams","Object","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","replace","c","r","getCanonicalUrl","canonicalMeta","querySelector","urlObj","removeParamsFromUrl","getEventProperties","widgetType","properties","identity","widget_type","canonical_url","snippet_id","__ARENA__","snippetId","timestamp","Date","toISOString","integrations","All","getEventHeaders","writeKey","btoa","useTrack","analytics","rsWriteKey","dataPlaneUrl","rsDataPlaneUrl","track","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","AuthProvider","queryClient","QueryClient","QueryClientProvider","client","_jsxs"],"mappings":"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"}
|