For any `Screen` that shows on desktop, `title` is "(1) ... - Bluesky" where "(1)" is the unread notification count. The titles are unlocalized and the string "Bluesky" is hardcoded, following the pattern of the rest of the app. Display names and post content are loaded into the title as effects. Tested: * all screens * screen changes / component mounts/unmounts * long posts with links and images * display name set/unset * spamming myself with notifications, clearing notifications * /profile/did:... links * lint (only my changed files), jest, e2e. New utilities: `useUnreadCountLabel`, `bskyTitle`, `combinedDisplayName`, `useSetTitle`. resolves: #626 #599
This commit is contained in:
		
							parent
							
								
									a5838694bd
								
							
						
					
					
						commit
						50c1841a06
					
				
					 8 changed files with 180 additions and 21 deletions
				
			
		|  | @ -25,6 +25,8 @@ import {FAB} from '../com/util/fab/FAB' | |||
| import {s, colors} from 'lib/styles' | ||||
| import {useAnalytics} from 'lib/analytics' | ||||
| import {ComposeIcon2} from 'lib/icons' | ||||
| import {useSetTitle} from 'lib/hooks/useSetTitle' | ||||
| import {combinedDisplayName} from 'lib/strings/display-names' | ||||
| 
 | ||||
| type Props = NativeStackScreenProps<CommonNavigatorParams, 'Profile'> | ||||
| export const ProfileScreen = withAuthRequired( | ||||
|  | @ -41,6 +43,7 @@ export const ProfileScreen = withAuthRequired( | |||
|       () => new ProfileUiModel(store, {user: route.params.name}), | ||||
|       [route.params.name, store], | ||||
|     ) | ||||
|     useSetTitle(combinedDisplayName(uiState.profile)) | ||||
| 
 | ||||
|     useFocusEffect( | ||||
|       React.useCallback(() => { | ||||
|  |  | |||
|  | @ -14,6 +14,7 @@ import * as Toast from 'view/com/util/Toast' | |||
| import {ListModel} from 'state/models/content/list' | ||||
| import {useStores} from 'state/index' | ||||
| import {usePalette} from 'lib/hooks/usePalette' | ||||
| import {useSetTitle} from 'lib/hooks/useSetTitle' | ||||
| import {NavigationProp} from 'lib/routes/types' | ||||
| import {isDesktopWeb} from 'platform/detection' | ||||
| 
 | ||||
|  | @ -32,6 +33,7 @@ export const ProfileListScreen = withAuthRequired( | |||
|       ) | ||||
|       return model | ||||
|     }, [store, name, rkey]) | ||||
|     useSetTitle(list.list?.name) | ||||
| 
 | ||||
|     useFocusEffect( | ||||
|       React.useCallback(() => { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue