Mobile Web (#427)
* WIP * WIP * Fix header offset on web * Remove debug * Fix web mobile feed and FAB layout * Fix modals on mobile web * Remove dead code * Remove ios config that shouldnt be committed now * Move bottom bar into its own folder * Fix web drawer navigation and state behaviors * Remove dark mode toggle from web drawer for now * Fix search on mobile web * Fix the logged out splash screen on mobile web * Fixes to detox simulator --------- Co-authored-by: Paul Frazee <pfrazee@gmail.com>
This commit is contained in:
		
							parent
							
								
									2fed6c4021
								
							
						
					
					
						commit
						f6769b283f
					
				
					 30 changed files with 4343 additions and 319 deletions
				
			
		|  | @ -1,71 +0,0 @@ | |||
| import React from 'react' | ||||
| import {observer} from 'mobx-react-lite' | ||||
| import { | ||||
|   Animated, | ||||
|   GestureResponderEvent, | ||||
|   StyleSheet, | ||||
|   TouchableWithoutFeedback, | ||||
| } from 'react-native' | ||||
| import LinearGradient from 'react-native-linear-gradient' | ||||
| import {gradients} from 'lib/styles' | ||||
| import {useAnimatedValue} from 'lib/hooks/useAnimatedValue' | ||||
| import {useStores} from 'state/index' | ||||
| 
 | ||||
| type OnPress = ((event: GestureResponderEvent) => void) | undefined | ||||
| export const FAB = observer( | ||||
|   ({ | ||||
|     testID, | ||||
|     icon, | ||||
|     onPress, | ||||
|   }: { | ||||
|     testID?: string | ||||
|     icon: JSX.Element | ||||
|     onPress: OnPress | ||||
|   }) => { | ||||
|     const store = useStores() | ||||
|     const interp = useAnimatedValue(0) | ||||
|     React.useEffect(() => { | ||||
|       Animated.timing(interp, { | ||||
|         toValue: store.shell.minimalShellMode ? 1 : 0, | ||||
|         duration: 100, | ||||
|         useNativeDriver: true, | ||||
|         isInteraction: false, | ||||
|       }).start() | ||||
|     }, [interp, store.shell.minimalShellMode]) | ||||
|     const transform = { | ||||
|       transform: [{translateY: Animated.multiply(interp, 60)}], | ||||
|     } | ||||
|     return ( | ||||
|       <TouchableWithoutFeedback testID={testID} onPress={onPress}> | ||||
|         <Animated.View style={[styles.outer, transform]}> | ||||
|           <LinearGradient | ||||
|             colors={[gradients.blueLight.start, gradients.blueLight.end]} | ||||
|             start={{x: 0, y: 0}} | ||||
|             end={{x: 1, y: 1}} | ||||
|             style={styles.inner}> | ||||
|             {icon} | ||||
|           </LinearGradient> | ||||
|         </Animated.View> | ||||
|       </TouchableWithoutFeedback> | ||||
|     ) | ||||
|   }, | ||||
| ) | ||||
| 
 | ||||
| const styles = StyleSheet.create({ | ||||
|   outer: { | ||||
|     position: 'absolute', | ||||
|     zIndex: 1, | ||||
|     right: 28, | ||||
|     bottom: 94, | ||||
|     width: 60, | ||||
|     height: 60, | ||||
|     borderRadius: 30, | ||||
|   }, | ||||
|   inner: { | ||||
|     width: 60, | ||||
|     height: 60, | ||||
|     borderRadius: 30, | ||||
|     justifyContent: 'center', | ||||
|     alignItems: 'center', | ||||
|   }, | ||||
| }) | ||||
|  | @ -1,8 +0,0 @@ | |||
| import React from 'react' | ||||
| import {GestureResponderEvent, View} from 'react-native' | ||||
| import {IconProp} from '@fortawesome/fontawesome-svg-core' | ||||
| 
 | ||||
| type OnPress = ((event: GestureResponderEvent) => void) | undefined | ||||
| export const FAB = (_opts: {icon: IconProp; onPress: OnPress}) => { | ||||
|   return <View /> | ||||
| } | ||||
|  | @ -55,9 +55,10 @@ export function show(text: string) { | |||
| const styles = StyleSheet.create({ | ||||
|   container: { | ||||
|     position: 'absolute', | ||||
|     right: 20, | ||||
|     left: 20, | ||||
|     bottom: 20, | ||||
|     width: 350, | ||||
|     width: 'calc(100% - 40px)', | ||||
|     maxWidth: 350, | ||||
|     padding: 20, | ||||
|     flexDirection: 'row', | ||||
|     alignItems: 'center', | ||||
|  |  | |||
							
								
								
									
										1
									
								
								src/view/com/util/fab/FAB.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								src/view/com/util/fab/FAB.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| export {FABInner as FAB} from './FABInner' | ||||
							
								
								
									
										14
									
								
								src/view/com/util/fab/FAB.web.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								src/view/com/util/fab/FAB.web.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,14 @@ | |||
| import React from 'react' | ||||
| import {View} from 'react-native' | ||||
| import {FABInner, FABProps} from './FABInner' | ||||
| import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries' | ||||
| 
 | ||||
| export const FAB = (_opts: FABProps) => { | ||||
|   const {isDesktop} = useWebMediaQueries() | ||||
| 
 | ||||
|   if (!isDesktop) { | ||||
|     return <FABInner {..._opts} /> | ||||
|   } | ||||
| 
 | ||||
|   return <View /> | ||||
| } | ||||
							
								
								
									
										72
									
								
								src/view/com/util/fab/FABInner.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								src/view/com/util/fab/FABInner.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,72 @@ | |||
| import React from 'react' | ||||
| import {observer} from 'mobx-react-lite' | ||||
| import { | ||||
|   Animated, | ||||
|   GestureResponderEvent, | ||||
|   StyleSheet, | ||||
|   TouchableWithoutFeedback, | ||||
| } from 'react-native' | ||||
| import LinearGradient from 'react-native-linear-gradient' | ||||
| import {gradients} from 'lib/styles' | ||||
| import {useAnimatedValue} from 'lib/hooks/useAnimatedValue' | ||||
| import {useStores} from 'state/index' | ||||
| import {isMobileWeb} from 'platform/detection' | ||||
| 
 | ||||
| type OnPress = ((event: GestureResponderEvent) => void) | undefined | ||||
| export interface FABProps { | ||||
|   testID?: string | ||||
|   icon: JSX.Element | ||||
|   onPress: OnPress | ||||
| } | ||||
| 
 | ||||
| export const FABInner = observer(({testID, icon, onPress}: FABProps) => { | ||||
|   const store = useStores() | ||||
|   const interp = useAnimatedValue(0) | ||||
|   React.useEffect(() => { | ||||
|     Animated.timing(interp, { | ||||
|       toValue: store.shell.minimalShellMode ? 1 : 0, | ||||
|       duration: 100, | ||||
|       useNativeDriver: true, | ||||
|       isInteraction: false, | ||||
|     }).start() | ||||
|   }, [interp, store.shell.minimalShellMode]) | ||||
|   const transform = { | ||||
|     transform: [{translateY: Animated.multiply(interp, 60)}], | ||||
|   } | ||||
|   return ( | ||||
|     <TouchableWithoutFeedback testID={testID} onPress={onPress}> | ||||
|       <Animated.View | ||||
|         style={[styles.outer, isMobileWeb && styles.mobileWebOuter, transform]}> | ||||
|         <LinearGradient | ||||
|           colors={[gradients.blueLight.start, gradients.blueLight.end]} | ||||
|           start={{x: 0, y: 0}} | ||||
|           end={{x: 1, y: 1}} | ||||
|           style={styles.inner}> | ||||
|           {icon} | ||||
|         </LinearGradient> | ||||
|       </Animated.View> | ||||
|     </TouchableWithoutFeedback> | ||||
|   ) | ||||
| }) | ||||
| 
 | ||||
| const styles = StyleSheet.create({ | ||||
|   outer: { | ||||
|     position: 'absolute', | ||||
|     zIndex: 1, | ||||
|     right: 28, | ||||
|     bottom: 94, | ||||
|     width: 60, | ||||
|     height: 60, | ||||
|     borderRadius: 30, | ||||
|   }, | ||||
|   mobileWebOuter: { | ||||
|     bottom: 114, | ||||
|   }, | ||||
|   inner: { | ||||
|     width: 60, | ||||
|     height: 60, | ||||
|     borderRadius: 30, | ||||
|     justifyContent: 'center', | ||||
|     alignItems: 'center', | ||||
|   }, | ||||
| }) | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue