Unfork Statsig for web (#3192)
This commit is contained in:
		
							parent
							
								
									202adb6d7b
								
							
						
					
					
						commit
						7af338ed21
					
				
					 3 changed files with 0 additions and 96 deletions
				
			
		|  | @ -1,75 +0,0 @@ | |||
| import React from 'react' | ||||
| import { | ||||
|   Statsig, | ||||
|   StatsigProvider, | ||||
|   useGate as useStatsigGate, | ||||
| } from 'statsig-react' | ||||
| import {useSession} from '../../state/session' | ||||
| import {sha256} from 'js-sha256' | ||||
| 
 | ||||
| const statsigOptions = { | ||||
|   environment: { | ||||
|     tier: process.env.NODE_ENV === 'development' ? 'development' : 'production', | ||||
|   }, | ||||
|   // Don't block on waiting for network. The fetched config will kick in on next load.
 | ||||
|   // This ensures the UI is always consistent and doesn't update mid-session.
 | ||||
|   // Note this makes cold load (no local storage) and private mode return `false` for all gates.
 | ||||
|   initTimeoutMs: 1, | ||||
| } | ||||
| 
 | ||||
| export function logEvent( | ||||
|   eventName: string, | ||||
|   value?: string | number | null, | ||||
|   metadata?: Record<string, string> | null, | ||||
| ) { | ||||
|   Statsig.logEvent(eventName, value, metadata) | ||||
| } | ||||
| 
 | ||||
| export function useGate(gateName: string) { | ||||
|   const {isLoading, value} = useStatsigGate(gateName) | ||||
|   if (isLoading) { | ||||
|     // This should not happen because of waitForInitialization={true}.
 | ||||
|     console.error('Did not expected isLoading to ever be true.') | ||||
|   } | ||||
|   return value | ||||
| } | ||||
| 
 | ||||
| function toStatsigUser(did: string | undefined) { | ||||
|   let userID: string | undefined | ||||
|   if (did) { | ||||
|     userID = sha256(did) | ||||
|   } | ||||
|   return {userID} | ||||
| } | ||||
| 
 | ||||
| export function Provider({children}: {children: React.ReactNode}) { | ||||
|   const {currentAccount} = useSession() | ||||
|   const currentStatsigUser = React.useMemo( | ||||
|     () => toStatsigUser(currentAccount?.did), | ||||
|     [currentAccount?.did], | ||||
|   ) | ||||
| 
 | ||||
|   React.useEffect(() => { | ||||
|     function refresh() { | ||||
|       // Intentionally refetching the config using the JS SDK rather than React SDK
 | ||||
|       // so that the new config is stored in cache but isn't used during this session.
 | ||||
|       // It will kick in for the next reload.
 | ||||
|       Statsig.updateUser(currentStatsigUser) | ||||
|     } | ||||
|     const id = setInterval(refresh, 3 * 60e3 /* 3 min */) | ||||
|     return () => clearInterval(id) | ||||
|   }, [currentStatsigUser]) | ||||
| 
 | ||||
|   return ( | ||||
|     <StatsigProvider | ||||
|       sdkKey="client-SXJakO39w9vIhl3D44u8UupyzFl4oZ2qPIkjwcvuPsV" | ||||
|       mountKey={currentStatsigUser.userID} | ||||
|       user={currentStatsigUser} | ||||
|       // This isn't really blocking due to short initTimeoutMs above.
 | ||||
|       // However, it ensures `isLoading` is always `false`.
 | ||||
|       waitForInitialization={true} | ||||
|       options={statsigOptions}> | ||||
|       {children} | ||||
|     </StatsigProvider> | ||||
|   ) | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue