Readd the FAB for composing new posts

zio/stable
Paul Frazee 2023-01-16 17:07:33 -06:00
parent f7d7c78611
commit 00b7189d5d
4 changed files with 76 additions and 11 deletions

View File

@ -0,0 +1,68 @@
import React from 'react'
import {observer} from 'mobx-react-lite'
import {
GestureResponderEvent,
StyleSheet,
TouchableWithoutFeedback,
View,
} from 'react-native'
import LinearGradient from 'react-native-linear-gradient'
import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome'
import {IconProp} from '@fortawesome/fontawesome-svg-core'
import {colors, gradients} from '../../lib/styles'
import {useStores} from '../../../state'
type OnPress = ((event: GestureResponderEvent) => void) | undefined
export const FAB = observer(
({icon, onPress}: {icon: IconProp; onPress: OnPress}) => {
const store = useStores()
return (
<TouchableWithoutFeedback onPress={onPress}>
<View
style={[
styles.outer,
store.shell.minimalShellMode ? styles.lower : undefined,
]}>
<LinearGradient
colors={[gradients.purple.start, gradients.purple.end]}
start={{x: 0, y: 0}}
end={{x: 1, y: 1}}
style={styles.inner}>
<FontAwesomeIcon
size={24}
icon={icon}
color={colors.white}
style={styles.icon}
/>
</LinearGradient>
</View>
</TouchableWithoutFeedback>
)
},
)
const styles = StyleSheet.create({
outer: {
position: 'absolute',
zIndex: 1,
right: 22,
bottom: 84,
width: 60,
height: 60,
borderRadius: 30,
shadowColor: '#000',
shadowOpacity: 0.3,
shadowOffset: {width: 0, height: 1},
},
lower: {
bottom: 34,
},
inner: {
width: 60,
height: 60,
borderRadius: 30,
justifyContent: 'center',
alignItems: 'center',
},
icon: {},
})

View File

@ -21,12 +21,10 @@ export const ViewHeader = observer(function ViewHeader({
title, title,
subtitle, subtitle,
canGoBack, canGoBack,
onPost,
}: { }: {
title: string title: string
subtitle?: string subtitle?: string
canGoBack?: boolean canGoBack?: boolean
onPost?: () => void
}) { }) {
const theme = useTheme() const theme = useTheme()
const pal = usePalette('default') const pal = usePalette('default')
@ -37,9 +35,6 @@ export const ViewHeader = observer(function ViewHeader({
const onPressMenu = () => { const onPressMenu = () => {
store.shell.setMainMenuOpen(true) store.shell.setMainMenuOpen(true)
} }
const onPressCompose = () => {
store.shell.openComposer({onPost})
}
const onPressSearch = () => { const onPressSearch = () => {
store.nav.navigate(`/search`) store.nav.navigate(`/search`)
} }
@ -85,12 +80,6 @@ export const ViewHeader = observer(function ViewHeader({
</Text> </Text>
) : undefined} ) : undefined}
</View> </View>
<TouchableOpacity
onPress={onPressCompose}
hitSlop={HITSLOP}
style={[styles.btn, {backgroundColor: pal.colors.backgroundLight}]}>
<FontAwesomeIcon size={18} icon="plus" style={pal.text} />
</TouchableOpacity>
<TouchableOpacity <TouchableOpacity
onPress={onPressSearch} onPress={onPressSearch}
hitSlop={HITSLOP} hitSlop={HITSLOP}

View File

@ -7,6 +7,7 @@ import {useSafeAreaInsets} from 'react-native-safe-area-context'
import {ViewHeader} from '../com/util/ViewHeader' import {ViewHeader} from '../com/util/ViewHeader'
import {Feed} from '../com/posts/Feed' import {Feed} from '../com/posts/Feed'
import {Text} from '../com/util/text/Text' import {Text} from '../com/util/text/Text'
import {FAB} from '../com/util/FAB'
import {useStores} from '../../state' import {useStores} from '../../state'
import {ScreenParams} from '../routes' import {ScreenParams} from '../routes'
import {s, colors} from '../lib/styles' import {s, colors} from '../lib/styles'
@ -103,6 +104,7 @@ export const Home = observer(function Home({
<Text style={styles.loadLatestText}>Load new posts</Text> <Text style={styles.loadLatestText}>Load new posts</Text>
</TouchableOpacity> </TouchableOpacity>
) : undefined} ) : undefined}
<FAB icon="pen-nib" onPress={onPressCompose} />
</View> </View>
) )
}) })

View File

@ -18,6 +18,7 @@ import {EmptyState} from '../com/util/EmptyState'
import {Text} from '../com/util/text/Text' import {Text} from '../com/util/text/Text'
import {ViewHeader} from '../com/util/ViewHeader' import {ViewHeader} from '../com/util/ViewHeader'
import * as Toast from '../com/util/Toast' import * as Toast from '../com/util/Toast'
import {FAB} from '../com/util/FAB'
import {s, colors} from '../lib/styles' import {s, colors} from '../lib/styles'
import {useOnMainScroll} from '../lib/hooks/useOnMainScroll' import {useOnMainScroll} from '../lib/hooks/useOnMainScroll'
@ -89,6 +90,10 @@ export const Profile = observer(({navIdx, visible, params}: ScreenParams) => {
) )
} }
const onPressCompose = () => {
store.shell.openComposer({})
}
// rendering // rendering
// = // =
@ -263,6 +268,7 @@ export const Profile = observer(({navIdx, visible, params}: ScreenParams) => {
) : ( ) : (
renderHeader() renderHeader()
)} )}
<FAB icon="pen-nib" onPress={onPressCompose} />
</View> </View>
) )
}) })