Merge remote-tracking branch 'origin/main' into samuel/alf-login
This commit is contained in:
		
						commit
						d24ffba01d
					
				
					 62 changed files with 30007 additions and 10775 deletions
				
			
		|  | @ -6,6 +6,7 @@ import {useSessionApi, SessionAccount} from '#/state/session' | |||
| import * as Toast from '#/view/com/util/Toast' | ||||
| import {useCloseAllActiveElements} from '#/state/util' | ||||
| import {useLoggedOutViewControls} from '#/state/shell/logged-out' | ||||
| import {LogEvents} from '../statsig/statsig' | ||||
| 
 | ||||
| export function useAccountSwitcher() { | ||||
|   const {track} = useAnalytics() | ||||
|  | @ -14,7 +15,10 @@ export function useAccountSwitcher() { | |||
|   const {requestSwitchToAccount} = useLoggedOutViewControls() | ||||
| 
 | ||||
|   const onPressSwitchAccount = useCallback( | ||||
|     async (account: SessionAccount) => { | ||||
|     async ( | ||||
|       account: SessionAccount, | ||||
|       logContext: LogEvents['account:loggedIn']['logContext'], | ||||
|     ) => { | ||||
|       track('Settings:SwitchAccountButtonClicked') | ||||
| 
 | ||||
|       try { | ||||
|  | @ -28,7 +32,7 @@ export function useAccountSwitcher() { | |||
|             // So we change the URL ourselves. The navigator will pick it up on remount.
 | ||||
|             history.pushState(null, '', '/') | ||||
|           } | ||||
|           await selectAccount(account) | ||||
|           await selectAccount(account, logContext) | ||||
|           setTimeout(() => { | ||||
|             Toast.show(`Signed in as @${account.handle}`) | ||||
|           }, 100) | ||||
|  |  | |||
|  | @ -6,6 +6,7 @@ let refCount = 0 | |||
| function incrementRefCount() { | ||||
|   if (refCount === 0) { | ||||
|     document.body.style.overflow = 'hidden' | ||||
|     document.documentElement.style.scrollbarGutter = 'auto' | ||||
|   } | ||||
|   refCount++ | ||||
| } | ||||
|  | @ -14,6 +15,7 @@ function decrementRefCount() { | |||
|   refCount-- | ||||
|   if (refCount === 0) { | ||||
|     document.body.style.overflow = '' | ||||
|     document.documentElement.style.scrollbarGutter = '' | ||||
|   } | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -3,7 +3,6 @@ import RNFS from 'react-native-fs' | |||
| import {CropperOptions} from './types' | ||||
| import {compressIfNeeded} from './manip' | ||||
| 
 | ||||
| let _imageCounter = 0 | ||||
| async function getFile() { | ||||
|   let files = await RNFS.readDir( | ||||
|     RNFS.LibraryDirectoryPath.split('/') | ||||
|  | @ -12,7 +11,7 @@ async function getFile() { | |||
|       .join('/'), | ||||
|   ) | ||||
|   files = files.filter(file => file.path.endsWith('.JPG')) | ||||
|   const file = files[_imageCounter++ % files.length] | ||||
|   const file = files[0] | ||||
|   return await compressIfNeeded({ | ||||
|     path: file.path, | ||||
|     mime: 'image/jpeg', | ||||
|  |  | |||
|  | @ -118,11 +118,15 @@ export function useModerationCauseDescription( | |||
|         (labeler?.creator.handle ? '@' + labeler?.creator.handle : undefined) | ||||
|       if (!source) { | ||||
|         if (cause.label.src === BSKY_LABELER_DID) { | ||||
|           source = 'Bluesky Moderation' | ||||
|           source = 'Bluesky Moderation Service' | ||||
|         } else { | ||||
|           source = cause.label.src | ||||
|         } | ||||
|       } | ||||
|       if (def.identifier === 'porn' || def.identifier === 'sexual') { | ||||
|         strings.name = 'Adult Content' | ||||
|       } | ||||
| 
 | ||||
|       return { | ||||
|         icon: | ||||
|           def.identifier === '!no-unauthenticated' | ||||
|  |  | |||
|  | @ -7,6 +7,7 @@ import {logger} from '#/logger' | |||
| import {RQKEY as RQKEY_NOTIFS} from '#/state/queries/notifications/feed' | ||||
| import {truncateAndInvalidate} from '#/state/queries/util' | ||||
| import {SessionAccount, getAgent} from '#/state/session' | ||||
| import {logEvent} from '../statsig/statsig' | ||||
| 
 | ||||
| const SERVICE_DID = (serviceUrl?: string) => | ||||
|   serviceUrl?.includes('staging') | ||||
|  | @ -123,6 +124,7 @@ export function init(queryClient: QueryClient) { | |||
|         logger.DebugContext.notifications, | ||||
|       ) | ||||
|       track('Notificatons:OpenApp') | ||||
|       logEvent('notifications:openApp', {}) | ||||
|       truncateAndInvalidate(queryClient, RQKEY_NOTIFS()) | ||||
|       resetToTab('NotificationsTab') // open notifications tab
 | ||||
|     } | ||||
|  |  | |||
|  | @ -2,10 +2,26 @@ export type LogEvents = { | |||
|   init: { | ||||
|     initMs: number | ||||
|   } | ||||
|   'account:loggedIn': { | ||||
|     logContext: 'LoginForm' | 'SwitchAccount' | 'ChooseAccountForm' | 'Settings' | ||||
|     withPassword: boolean | ||||
|   } | ||||
|   'account:loggedOut': { | ||||
|     logContext: 'SwitchAccount' | 'Settings' | 'Deactivated' | ||||
|   } | ||||
|   'notifications:openApp': {} | ||||
|   'state:background': { | ||||
|     secondsActive: number | ||||
|   } | ||||
|   'state:foreground': {} | ||||
|   'feed:endReached': { | ||||
|     feedType: string | ||||
|     itemCount: number | ||||
|   } | ||||
|   'feed:refresh': { | ||||
|     feedType: string | ||||
|     reason: 'pull-to-refresh' | 'soft-reset' | 'load-latest' | ||||
|   } | ||||
|   'post:create': { | ||||
|     imageCount: number | ||||
|     isReply: boolean | ||||
|  |  | |||
|  | @ -1,9 +1,11 @@ | |||
| import React from 'react' | ||||
| import {Platform} from 'react-native' | ||||
| import { | ||||
|   Statsig, | ||||
|   StatsigProvider, | ||||
|   useGate as useStatsigGate, | ||||
| } from 'statsig-react-native-expo' | ||||
| import {AppState, AppStateStatus} from 'react-native' | ||||
| import {useSession} from '../../state/session' | ||||
| import {sha256} from 'js-sha256' | ||||
| import {LogEvents} from './events' | ||||
|  | @ -58,9 +60,34 @@ function toStatsigUser(did: string | undefined) { | |||
|   if (did) { | ||||
|     userID = sha256(did) | ||||
|   } | ||||
|   return {userID} | ||||
|   return { | ||||
|     userID, | ||||
|     platform: Platform.OS, | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| let lastState: AppStateStatus = AppState.currentState | ||||
| let lastActive = lastState === 'active' ? performance.now() : null | ||||
| AppState.addEventListener('change', (state: AppStateStatus) => { | ||||
|   if (state === lastState) { | ||||
|     return | ||||
|   } | ||||
|   lastState = state | ||||
|   if (state === 'active') { | ||||
|     lastActive = performance.now() | ||||
|     logEvent('state:foreground', {}) | ||||
|   } else { | ||||
|     let secondsActive = 0 | ||||
|     if (lastActive != null) { | ||||
|       secondsActive = Math.round((performance.now() - lastActive) / 1e3) | ||||
|     } | ||||
|     lastActive = null | ||||
|     logEvent('state:background', { | ||||
|       secondsActive, | ||||
|     }) | ||||
|   } | ||||
| }) | ||||
| 
 | ||||
| export function Provider({children}: {children: React.ReactNode}) { | ||||
|   const {currentAccount} = useSession() | ||||
|   const currentStatsigUser = React.useMemo( | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue