ALF confirmation dialogs (Dialogs Pt. 3) (#3143)
* Improve a11y on ios * Format * Remove android * Fix android * ALF confirmation dialog * Use ALF for Delete Post confirmation organize diff fix text minimize change copy alternative confirm prompt revert type changes add ButtonColor param * small adjustment to buttons in prompt * full width below gtmobile * update hide post dialog * space out dialogs * update dialogs for lists * add example * add to app passwords * Revert some changes * use sharedvalue for `importantForAccessibility` * add back `isOpen` * fix some more types * small adjustment to buttons in prompt * full width below gtmobile * update the rest of the prompts rm old confirm modal rm update prompt feed error prompt feed source card and profile block/unblock composer discard * Update src/view/screens/AppPasswords.tsx Co-authored-by: surfdude29 <149612116+surfdude29@users.noreply.github.com> * lint * How about a default * Reverse reverse * Port over confirm dialogs * Add some comments * Remove unused file * complete merge * add testID where needed --------- Co-authored-by: Eric Bailey <git@esb.lol> Co-authored-by: surfdude29 <149612116+surfdude29@users.noreply.github.com>
This commit is contained in:
		
							parent
							
								
									090b35e52e
								
							
						
					
					
						commit
						9f2f7f221c
					
				
					 19 changed files with 540 additions and 605 deletions
				
			
		|  | @ -2,25 +2,9 @@ import * as Updates from 'expo-updates' | |||
| import {useCallback, useEffect} from 'react' | ||||
| import {AppState} from 'react-native' | ||||
| import {logger} from '#/logger' | ||||
| import {useModalControls} from '#/state/modals' | ||||
| import {t} from '@lingui/macro' | ||||
| 
 | ||||
| export function useOTAUpdate() { | ||||
|   const {openModal} = useModalControls() | ||||
| 
 | ||||
|   // HELPER FUNCTIONS
 | ||||
|   const showUpdatePopup = useCallback(() => { | ||||
|     openModal({ | ||||
|       name: 'confirm', | ||||
|       title: t`Update Available`, | ||||
|       message: t`A new version of the app is available. Please update to continue using the app.`, | ||||
|       onPressConfirm: async () => { | ||||
|         Updates.reloadAsync().catch(err => { | ||||
|           throw err | ||||
|         }) | ||||
|       }, | ||||
|     }) | ||||
|   }, [openModal]) | ||||
|   const checkForUpdate = useCallback(async () => { | ||||
|     logger.debug('useOTAUpdate: Checking for update...') | ||||
|     try { | ||||
|  | @ -32,32 +16,26 @@ export function useOTAUpdate() { | |||
|       } | ||||
|       // Otherwise fetch the update in the background, so even if the user rejects switching to latest version it will be done automatically on next relaunch.
 | ||||
|       await Updates.fetchUpdateAsync() | ||||
|       // show a popup modal
 | ||||
|       showUpdatePopup() | ||||
|     } catch (e) { | ||||
|       logger.error('useOTAUpdate: Error while checking for update', { | ||||
|         message: e, | ||||
|       }) | ||||
|     } | ||||
|   }, [showUpdatePopup]) | ||||
|   const updateEventListener = useCallback( | ||||
|     (event: Updates.UpdateEvent) => { | ||||
|       logger.debug('useOTAUpdate: Listening for update...') | ||||
|       if (event.type === Updates.UpdateEventType.ERROR) { | ||||
|         logger.error('useOTAUpdate: Error while listening for update', { | ||||
|           message: event.message, | ||||
|         }) | ||||
|       } else if (event.type === Updates.UpdateEventType.NO_UPDATE_AVAILABLE) { | ||||
|         // Handle no update available
 | ||||
|         // do nothing
 | ||||
|       } else if (event.type === Updates.UpdateEventType.UPDATE_AVAILABLE) { | ||||
|         // Handle update available
 | ||||
|         // open modal, ask for user confirmation, and reload the app
 | ||||
|         showUpdatePopup() | ||||
|       } | ||||
|     }, | ||||
|     [showUpdatePopup], | ||||
|   ) | ||||
|   }, []) | ||||
|   const updateEventListener = useCallback((event: Updates.UpdateEvent) => { | ||||
|     logger.debug('useOTAUpdate: Listening for update...') | ||||
|     if (event.type === Updates.UpdateEventType.ERROR) { | ||||
|       logger.error('useOTAUpdate: Error while listening for update', { | ||||
|         message: event.message, | ||||
|       }) | ||||
|     } else if (event.type === Updates.UpdateEventType.NO_UPDATE_AVAILABLE) { | ||||
|       // Handle no update available
 | ||||
|       // do nothing
 | ||||
|     } else if (event.type === Updates.UpdateEventType.UPDATE_AVAILABLE) { | ||||
|       // Handle update available
 | ||||
|       // open modal, ask for user confirmation, and reload the app
 | ||||
|     } | ||||
|   }, []) | ||||
| 
 | ||||
|   useEffect(() => { | ||||
|     // ADD EVENT LISTENERS
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue