86 lines
2.3 KiB
TypeScript
86 lines
2.3 KiB
TypeScript
import React from 'react'
|
|
import {StyleProp, View, ViewStyle} from 'react-native'
|
|
import {AppBskyFeedDefs, ComAtprotoLabelDefs} from '@atproto/api'
|
|
import {msg, Plural} from '@lingui/macro'
|
|
import {useLingui} from '@lingui/react'
|
|
|
|
import {useSession} from '#/state/session'
|
|
import {atoms as a} from '#/alf'
|
|
import {Button, ButtonIcon, ButtonSize, ButtonText} from '#/components/Button'
|
|
import {CircleInfo_Stroke2_Corner0_Rounded as CircleInfo} from '#/components/icons/CircleInfo'
|
|
import {
|
|
LabelsOnMeDialog,
|
|
useLabelsOnMeDialogControl,
|
|
} from '#/components/moderation/LabelsOnMeDialog'
|
|
|
|
export function LabelsOnMe({
|
|
type,
|
|
labels,
|
|
size,
|
|
style,
|
|
}: {
|
|
type: 'account' | 'content'
|
|
labels: ComAtprotoLabelDefs.Label[] | undefined
|
|
size?: ButtonSize
|
|
style?: StyleProp<ViewStyle>
|
|
}) {
|
|
const {_} = useLingui()
|
|
const {currentAccount} = useSession()
|
|
const control = useLabelsOnMeDialogControl()
|
|
|
|
if (!labels || !currentAccount) {
|
|
return null
|
|
}
|
|
labels = labels.filter(l => !l.val.startsWith('!'))
|
|
if (!labels.length) {
|
|
return null
|
|
}
|
|
|
|
return (
|
|
<View style={[a.flex_row, style]}>
|
|
<LabelsOnMeDialog control={control} labels={labels} type={type} />
|
|
|
|
<Button
|
|
variant="solid"
|
|
color="secondary"
|
|
size={size || 'small'}
|
|
label={_(msg`View information about these labels`)}
|
|
onPress={() => {
|
|
control.open()
|
|
}}>
|
|
<ButtonIcon position="left" icon={CircleInfo} />
|
|
<ButtonText style={[a.leading_snug]}>
|
|
{type === 'account' ? (
|
|
<Plural
|
|
value={labels.length}
|
|
one="# label has been placed on this account"
|
|
other="# labels have been placed on this account"
|
|
/>
|
|
) : (
|
|
<Plural
|
|
value={labels.length}
|
|
one="# label has been placed on this content"
|
|
other="# labels have been placed on this content"
|
|
/>
|
|
)}
|
|
</ButtonText>
|
|
</Button>
|
|
</View>
|
|
)
|
|
}
|
|
|
|
export function LabelsOnMyPost({
|
|
post,
|
|
style,
|
|
}: {
|
|
post: AppBskyFeedDefs.PostView
|
|
style?: StyleProp<ViewStyle>
|
|
}) {
|
|
const {currentAccount} = useSession()
|
|
if (post.author.did !== currentAccount?.did) {
|
|
return null
|
|
}
|
|
return (
|
|
<LabelsOnMe type="content" labels={post.labels} size="tiny" style={style} />
|
|
)
|
|
}
|