diff --git a/src/view/com/util/FAB.tsx b/src/view/com/util/FAB.tsx
new file mode 100644
index 00000000..ae110c7f
--- /dev/null
+++ b/src/view/com/util/FAB.tsx
@@ -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 (
+
+
+
+
+
+
+
+ )
+ },
+)
+
+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: {},
+})
diff --git a/src/view/com/util/ViewHeader.tsx b/src/view/com/util/ViewHeader.tsx
index 2e584b76..e4627071 100644
--- a/src/view/com/util/ViewHeader.tsx
+++ b/src/view/com/util/ViewHeader.tsx
@@ -21,12 +21,10 @@ export const ViewHeader = observer(function ViewHeader({
title,
subtitle,
canGoBack,
- onPost,
}: {
title: string
subtitle?: string
canGoBack?: boolean
- onPost?: () => void
}) {
const theme = useTheme()
const pal = usePalette('default')
@@ -37,9 +35,6 @@ export const ViewHeader = observer(function ViewHeader({
const onPressMenu = () => {
store.shell.setMainMenuOpen(true)
}
- const onPressCompose = () => {
- store.shell.openComposer({onPost})
- }
const onPressSearch = () => {
store.nav.navigate(`/search`)
}
@@ -85,12 +80,6 @@ export const ViewHeader = observer(function ViewHeader({
) : undefined}
-
-
-
Load new posts
) : undefined}
+
)
})
diff --git a/src/view/screens/Profile.tsx b/src/view/screens/Profile.tsx
index 0fb30162..c89c2ad1 100644
--- a/src/view/screens/Profile.tsx
+++ b/src/view/screens/Profile.tsx
@@ -18,6 +18,7 @@ import {EmptyState} from '../com/util/EmptyState'
import {Text} from '../com/util/text/Text'
import {ViewHeader} from '../com/util/ViewHeader'
import * as Toast from '../com/util/Toast'
+import {FAB} from '../com/util/FAB'
import {s, colors} from '../lib/styles'
import {useOnMainScroll} from '../lib/hooks/useOnMainScroll'
@@ -89,6 +90,10 @@ export const Profile = observer(({navIdx, visible, params}: ScreenParams) => {
)
}
+ const onPressCompose = () => {
+ store.shell.openComposer({})
+ }
+
// rendering
// =
@@ -263,6 +268,7 @@ export const Profile = observer(({navIdx, visible, params}: ScreenParams) => {
) : (
renderHeader()
)}
+
)
})