create Alert.tsx and Alert.web.tsx and replace uses (#513)
This commit is contained in:
		
							parent
							
								
									b00365c196
								
							
						
					
					
						commit
						01410ad4bf
					
				
					 4 changed files with 44 additions and 26 deletions
				
			
		|  | @ -1,8 +1,8 @@ | ||||||
| import {Alert} from 'react-native' |  | ||||||
| import {Camera} from 'expo-camera' | import {Camera} from 'expo-camera' | ||||||
| import * as MediaLibrary from 'expo-media-library' | import * as MediaLibrary from 'expo-media-library' | ||||||
| import {Linking} from 'react-native' | import {Linking} from 'react-native' | ||||||
| import {isWeb} from 'platform/detection' | import {isWeb} from 'platform/detection' | ||||||
|  | import {Alert} from 'view/com/util/Alert' | ||||||
| 
 | 
 | ||||||
| const openSettings = () => { | const openSettings = () => { | ||||||
|   Linking.openURL('app-settings:') |   Linking.openURL('app-settings:') | ||||||
|  |  | ||||||
							
								
								
									
										1
									
								
								src/view/com/util/Alert.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								src/view/com/util/Alert.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | ||||||
|  | export {Alert} from 'react-native' | ||||||
							
								
								
									
										23
									
								
								src/view/com/util/Alert.web.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								src/view/com/util/Alert.web.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,23 @@ | ||||||
|  | import {AlertButton, AlertStatic} from 'react-native' | ||||||
|  | 
 | ||||||
|  | class WebAlert implements Pick<AlertStatic, 'alert'> { | ||||||
|  |   public alert(title: string, message?: string, buttons?: AlertButton[]): void { | ||||||
|  |     if (buttons === undefined || buttons.length === 0) { | ||||||
|  |       window.alert([title, message].filter(Boolean).join('\n')) | ||||||
|  |       return | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     const result = window.confirm([title, message].filter(Boolean).join('\n')) | ||||||
|  | 
 | ||||||
|  |     if (result === true) { | ||||||
|  |       const confirm = buttons.find(({style}) => style !== 'cancel') | ||||||
|  |       confirm?.onPress?.() | ||||||
|  |       return | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     const cancel = buttons.find(({style}) => style === 'cancel') | ||||||
|  |     cancel?.onPress?.() | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export const Alert = new WebAlert() | ||||||
|  | @ -1,5 +1,6 @@ | ||||||
| import React from 'react' | import React from 'react' | ||||||
| import {Alert, StyleSheet, TouchableOpacity, View} from 'react-native' | import {StyleSheet, TouchableOpacity, View} from 'react-native' | ||||||
|  | import {Alert} from 'view/com/util/Alert' | ||||||
| import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' | import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' | ||||||
| import {ScrollView} from 'react-native-gesture-handler' | import {ScrollView} from 'react-native-gesture-handler' | ||||||
| import {Text} from '../com/util/text/Text' | import {Text} from '../com/util/text/Text' | ||||||
|  | @ -159,12 +160,6 @@ function AppPassword({ | ||||||
|   const store = useStores() |   const store = useStores() | ||||||
| 
 | 
 | ||||||
|   const onDelete = React.useCallback(async () => { |   const onDelete = React.useCallback(async () => { | ||||||
|     if (isDesktopWeb) { |  | ||||||
|       if (confirm('Delete app password?')) { |  | ||||||
|         await store.me.deleteAppPassword(name) |  | ||||||
|         Toast.show('App password deleted') |  | ||||||
|       } |  | ||||||
|     } else { |  | ||||||
|     Alert.alert( |     Alert.alert( | ||||||
|       'Delete App Password', |       'Delete App Password', | ||||||
|       `Are you sure you want to delete the app password "${name}"?`, |       `Are you sure you want to delete the app password "${name}"?`, | ||||||
|  | @ -183,7 +178,6 @@ function AppPassword({ | ||||||
|         }, |         }, | ||||||
|       ], |       ], | ||||||
|     ) |     ) | ||||||
|     } |  | ||||||
|   }, [store, name]) |   }, [store, name]) | ||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue