import React from 'react'
import {observer} from 'mobx-react-lite'
import {Pressable, StyleSheet, TouchableOpacity, View} from 'react-native'
import {Text} from 'view/com/util/text/Text'
import {UserAvatar} from 'view/com/util/UserAvatar'
import {usePalette} from 'lib/hooks/usePalette'
import {useColorSchemeStyle} from 'lib/hooks/useColorSchemeStyle'
import {useStores} from 'state/index'
import {colors} from 'lib/styles'
import {
ComposeIcon,
HomeIcon,
HomeIconSolid,
BellIcon,
BellIconSolid,
MagnifyingGlassIcon,
CogIcon,
} from 'lib/icons'
import {DesktopSearch} from './DesktopSearch'
interface NavItemProps {
count?: number
href: string
icon: JSX.Element
iconFilled: JSX.Element
isProfile?: boolean
}
export const NavItem = observer(
({count, href, icon, iconFilled}: NavItemProps) => {
const store = useStores()
const hoverBg = useColorSchemeStyle(
styles.navItemHoverBgLight,
styles.navItemHoverBgDark,
)
const isCurrent = store.nav.tab.current.url === href
const onPress = () => store.nav.navigate(href)
return (
[
styles.navItem,
// @ts-ignore Pressable state differs for RNW -prf
(state.hovered || isCurrent) && hoverBg,
]}
onPress={onPress}>
{isCurrent ? iconFilled : icon}
{typeof count === 'number' && count > 0 && (
{count}
)}
)
},
)
export const ProfileItem = observer(() => {
const store = useStores()
const hoverBg = useColorSchemeStyle(
styles.navItemHoverBgLight,
styles.navItemHoverBgDark,
)
const href = `/profile/${store.me.handle}`
const isCurrent = store.nav.tab.current.url === href
const onPress = () => store.nav.navigate(href)
return (
[
styles.navItem,
// @ts-ignore Pressable state differs for RNW -prf
(state.hovered || isCurrent) && hoverBg,
]}
onPress={onPress}>
)
})
export const DesktopHeader = observer(function DesktopHeader({}: {
canGoBack?: boolean
}) {
const store = useStores()
const pal = usePalette('default')
const onPressCompose = () => store.shell.openComposer({})
return (
Bluesky
}
iconFilled={}
/>
}
iconFilled={}
/>
}
iconFilled={}
/>
New Post
}
iconFilled={}
/>
)
})
const styles = StyleSheet.create({
header: {
flexDirection: 'row',
alignItems: 'center',
// paddingTop: 18,
// paddingBottom: 18,
paddingLeft: 30,
paddingRight: 40,
borderBottomWidth: 1,
zIndex: 1,
},
spaceFlex: {
flex: 1,
},
space15: {
width: 15,
},
space20: {
width: 20,
},
space30: {
width: 30,
},
title: {},
navItem: {
paddingTop: 14,
paddingBottom: 10,
paddingHorizontal: 10,
alignItems: 'center',
borderBottomWidth: 2,
borderBottomColor: 'transparent',
},
navItemHoverBgLight: {
borderBottomWidth: 2,
borderBottomColor: colors.blue3,
},
navItemHoverBgDark: {
borderBottomWidth: 2,
backgroundColor: colors.blue3,
},
navItemIconWrapper: {
alignItems: 'center',
justifyContent: 'center',
width: 28,
height: 28,
marginBottom: 2,
},
navItemCount: {
position: 'absolute',
top: 0,
left: 15,
backgroundColor: colors.red3,
color: colors.white,
fontSize: 12,
fontWeight: 'bold',
paddingHorizontal: 4,
borderRadius: 6,
},
newPostBtn: {
flexDirection: 'row',
alignItems: 'center',
justifyContent: 'center',
borderRadius: 24,
paddingTop: 8,
paddingBottom: 8,
paddingHorizontal: 18,
backgroundColor: colors.blue3,
},
newPostBtnIconWrapper: {
marginRight: 8,
},
newPostBtnLabel: {
color: colors.white,
},
})