Implement web toast
This commit is contained in:
		
							parent
							
								
									20eaac6acd
								
							
						
					
					
						commit
						24559599f3
					
				
					 3 changed files with 77 additions and 21 deletions
				
			
		
							
								
								
									
										75
									
								
								src/view/com/util/Toast.web.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								src/view/com/util/Toast.web.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,75 @@ | |||
| /* | ||||
|  * Note: the dataSet properties are used to leverage custom CSS in public/index.html | ||||
|  */ | ||||
| 
 | ||||
| import React, {useState, useEffect} from 'react' | ||||
| import {StyleSheet, Text, View} from 'react-native' | ||||
| import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' | ||||
| 
 | ||||
| const DURATION = 3500 | ||||
| 
 | ||||
| interface ActiveToast { | ||||
|   text: string | ||||
| } | ||||
| type GlobalSetActiveToast = (_activeToast: ActiveToast | undefined) => void | ||||
| 
 | ||||
| // globals
 | ||||
| // =
 | ||||
| let globalSetActiveToast: GlobalSetActiveToast | undefined | ||||
| let toastTimeout: NodeJS.Timeout | undefined | ||||
| 
 | ||||
| // components
 | ||||
| // =
 | ||||
| type ToastContainerProps = {} | ||||
| export const ToastContainer: React.FC<ToastContainerProps> = ({}) => { | ||||
|   const [activeToast, setActiveToast] = useState<ActiveToast | undefined>() | ||||
|   useEffect(() => { | ||||
|     globalSetActiveToast = (t: ActiveToast | undefined) => { | ||||
|       setActiveToast(t) | ||||
|     } | ||||
|   }) | ||||
|   return ( | ||||
|     <> | ||||
|       {activeToast && ( | ||||
|         <View style={styles.container}> | ||||
|           <FontAwesomeIcon icon="check" size={24} style={styles.icon} /> | ||||
|           <Text style={styles.text}>{activeToast.text}</Text> | ||||
|         </View> | ||||
|       )} | ||||
|     </> | ||||
|   ) | ||||
| } | ||||
| 
 | ||||
| // methods
 | ||||
| // =
 | ||||
| export function show(text: string) { | ||||
|   if (toastTimeout) { | ||||
|     clearTimeout(toastTimeout) | ||||
|   } | ||||
|   globalSetActiveToast?.({text}) | ||||
|   toastTimeout = setTimeout(() => { | ||||
|     globalSetActiveToast?.(undefined) | ||||
|   }, DURATION) | ||||
| } | ||||
| 
 | ||||
| const styles = StyleSheet.create({ | ||||
|   container: { | ||||
|     position: 'absolute', | ||||
|     right: 20, | ||||
|     bottom: 20, | ||||
|     width: 350, | ||||
|     padding: 20, | ||||
|     flexDirection: 'row', | ||||
|     alignItems: 'center', | ||||
|     backgroundColor: '#000c', | ||||
|     borderRadius: 10, | ||||
|   }, | ||||
|   icon: { | ||||
|     color: '#fff', | ||||
|   }, | ||||
|   text: { | ||||
|     color: '#fff', | ||||
|     fontSize: 18, | ||||
|     marginLeft: 10, | ||||
|   }, | ||||
| }) | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue