import {View} from 'react-native'
import {msg} from '@lingui/core/macro'
import {useLingui} from '@lingui/react'
import {Trans} from '@lingui/react/macro'
import {useEnableSquareButtons} from '#/state/preferences/enable-square-buttons'
import {
useTrendingSettings,
useTrendingSettingsApi,
} from '#/state/preferences/trending'
import {useTrendingTopics} from '#/state/queries/trending/useTrendingTopics'
import {useTrendingConfig} from '#/state/service-config'
import {atoms as a, useTheme} from '#/alf'
import {Button, ButtonIcon} from '#/components/Button'
import {DotGrid3x1_Stroke2_Corner0_Rounded as Ellipsis} from '#/components/icons/DotGrid'
import {Trending3_Stroke2_Corner1_Rounded as TrendingIcon} from '#/components/icons/Trending'
import * as Prompt from '#/components/Prompt'
import {TrendingTopicLink} from '#/components/TrendingTopics'
import {Text} from '#/components/Typography'
import {useAnalytics} from '#/analytics'
const TRENDING_LIMIT = 5
export function SidebarTrendingTopics() {
const {enabled} = useTrendingConfig()
const {trendingDisabled} = useTrendingSettings()
return !enabled ? null : trendingDisabled ? null :
}
function Inner() {
const t = useTheme()
const {_} = useLingui()
const ax = useAnalytics()
const trendingPrompt = Prompt.usePromptControl()
const {setTrendingDisabled} = useTrendingSettingsApi()
const {data: trending, error, isLoading} = useTrendingTopics()
const noTopics = !isLoading && !error && !trending?.topics?.length
const enableSquareButtons = useEnableSquareButtons()
const onConfirmHide = () => {
ax.metric('trendingTopics:hide', {context: 'sidebar'})
setTrendingDisabled(true)
}
return error || noTopics ? null : (
<>
Trending
{isLoading ? (
Array(TRENDING_LIMIT)
.fill(0)
.map((_n, i) => (
{i + 1}.
))
) : !trending?.topics ? null : (
<>
{trending.topics.slice(0, TRENDING_LIMIT).map((topic, i) => (
{
ax.metric('trendingTopic:click', {context: 'sidebar'})
}}>
{({hovered}) => (
{i + 1}.
{topic.displayName ?? topic.topic}
)}
))}
>
)}
>
)
}