import menuAccount from '@components/contextMenu/account' import menuShare from '@components/contextMenu/share' import menuStatus from '@components/contextMenu/status' import Icon from '@components/Icon' import { StyleConstants } from '@utils/styles/constants' import { useTheme } from '@utils/styles/ThemeManager' import React, { Fragment, useContext, useState } from 'react' import { Platform, View } from 'react-native' import * as DropdownMenu from 'zeego/dropdown-menu' import StatusContext from './Context' const TimelineHeaderAndroid: React.FC = () => { const { queryKey, status, disableDetails, disableOnPress, rawContent } = useContext(StatusContext) if (Platform.OS !== 'android' || !status || disableDetails || disableOnPress) return null const { colors } = useTheme() const [openChange, setOpenChange] = useState(false) const mShare = menuShare({ visibility: status.visibility, type: 'status', url: status.url || status.uri, rawContent }) const mAccount = menuAccount({ type: 'status', openChange, account: status.account, ...(status && { status }) }) const mStatus = menuStatus({ status, queryKey }) return ( {queryKey ? ( {[mShare, mAccount, mStatus].map((menu, i) => ( {menu.map((group, index) => ( {group.map(item => { switch (item.type) { case 'item': return ( {item.icon ? ( ) : null} ) case 'sub': return ( {item.items.map(sub => ( {sub.icon ? ( ) : null} ))} ) } })} ))} ))} ) : null} ) } export default TimelineHeaderAndroid