Readd the FAB for composing new posts
parent
f7d7c78611
commit
00b7189d5d
|
@ -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: {},
|
||||||
|
})
|
|
@ -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}
|
||||||
|
|
|
@ -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>
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
|
|
|
@ -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>
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in New Issue