diff options
author | Eric Bailey <git@esb.lol> | 2025-04-18 21:15:32 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-04-18 19:15:32 -0700 |
commit | 0ac15920a477a5c8090fd2b929b36ac0b6e02c34 (patch) | |
tree | debd067ccc0f3f5f814d8ec10082e41034d47c7c /src/components/AccountList.tsx | |
parent | f1e44ee12e0ccde71e616121708e70462351f068 (diff) | |
download | voidsky-0ac15920a477a5c8090fd2b929b36ac0b6e02c34.tar.zst |
Verification (#8226)
* WIP * Alignment with icon * Add create/remove prompts * Fill out check dialog a bit * Reorg * Handle was verified state * Add warning to edit profile * Add warning to handle dialog * Decent alignment in posts on all platforms * Refactor alignment for posts, chatlist, hover card * Disable on profile * Convo header * Compute simple verification state * Add other icon, rename, integrate * Swap in simple state for profile edits * Clean up utility hooks * Add verifications UI to dialog * Add edu nux * Revert change * Fix wrapping of check on profile * Rename * Fix gap under PostMeta * Update check dialogs * Handle takendown verifiers in check dialog * alf composer reply to * Refactor verification state * Add create/remove mutations, non-functional for now * Fix up post-rebase * Add check to first author noty * Do cache updates after mutations * DRY up hook, add to profile updates too * Add to drawer * Update account list * Adapt to new types * Hook up mutations * Use profile shadow in feeds * Add to settings * Shadow currentAccountProfile * Add invalid state to verifications * Fix alignment and overflow in Settings and Drawer * Re-integrate post rebase * Remove debug code * Update copy * Add unverified notification support * Remove link * Make sure dialog closes * Update URL * Add settings screen * Integrate new setting into verification states * Add metrics, bump package, fix bad import * NUX fixes * Update copy * Fixes * Update types * fix search autocomplete * fix lint * add display name warning to new dialog * update default prefs * Add parsing support for notifications * Bump pkg * Tweak noty styles * Adjust check alignment * Tweak check alignment * Fix badge for verifier * Modify copy --------- Co-authored-by: Samuel Newman <mozzius@protonmail.com> Co-authored-by: Paul Frazee <pfrazee@gmail.com>
Diffstat (limited to 'src/components/AccountList.tsx')
-rw-r--r-- | src/components/AccountList.tsx | 67 |
1 files changed, 42 insertions, 25 deletions
diff --git a/src/components/AccountList.tsx b/src/components/AccountList.tsx index 52d149eb5..f2e781ccf 100644 --- a/src/components/AccountList.tsx +++ b/src/components/AccountList.tsx @@ -1,6 +1,6 @@ import React, {useCallback} from 'react' import {View} from 'react-native' -import {AppBskyActorDefs} from '@atproto/api' +import {type AppBskyActorDefs} from '@atproto/api' import {msg, Trans} from '@lingui/macro' import {useLingui} from '@lingui/react' @@ -12,6 +12,8 @@ import {UserAvatar} from '#/view/com/util/UserAvatar' import {atoms as a, useTheme} from '#/alf' import {Check_Stroke2_Corner0_Rounded as Check} from '#/components/icons/Check' import {ChevronRight_Stroke2_Corner0_Rounded as Chevron} from '#/components/icons/Chevron' +import {useSimpleVerificationState} from '#/components/verification' +import {VerificationCheck} from '#/components/verification/VerificationCheck' import {Button} from './Button' import {Text} from './Typography' @@ -74,11 +76,13 @@ export function AccountList({ ]}> <Text style={[ - a.align_baseline, + a.font_bold, a.flex_1, a.flex_row, a.py_sm, - {paddingLeft: 48}, + a.leading_tight, + t.atoms.text_contrast_medium, + {paddingLeft: 56}, ]}> {otherLabel ?? <Trans>Other account</Trans>} </Text> @@ -105,6 +109,7 @@ function AccountItem({ }) { const t = useTheme() const {_} = useLingui() + const verification = useSimpleVerificationState({profile}) const onPress = useCallback(() => { onSelect(account) @@ -114,7 +119,7 @@ function AccountItem({ <Button testID={`chooseAccountBtn-${account.handle}`} key={account.did} - style={[a.flex_1]} + style={[a.w_full]} onPress={onPress} label={ isCurrentAccount @@ -127,33 +132,45 @@ function AccountItem({ a.flex_1, a.flex_row, a.align_center, - {height: 48}, + a.px_md, + a.gap_sm, + {height: 56}, (hovered || pressed || isPendingAccount) && t.atoms.bg_contrast_25, ]}> - <View style={a.p_md}> - <UserAvatar - avatar={profile?.avatar} - size={24} - type={profile?.associated?.labeler ? 'labeler' : 'user'} - /> - </View> - <Text style={[a.align_baseline, a.flex_1, a.flex_row, a.py_sm]}> - <Text emoji style={[a.font_bold]}> - {sanitizeDisplayName( - profile?.displayName || profile?.handle || account.handle, + <UserAvatar + avatar={profile?.avatar} + size={36} + type={profile?.associated?.labeler ? 'labeler' : 'user'} + /> + + <View style={[a.flex_1, a.gap_2xs, a.pr_2xl]}> + <View style={[a.flex_row, a.align_center, a.gap_xs]}> + <Text + emoji + style={[a.font_bold, a.leading_tight]} + numberOfLines={1}> + {sanitizeDisplayName( + profile?.displayName || profile?.handle || account.handle, + )} + </Text> + {verification.showBadge && ( + <View> + <VerificationCheck + width={12} + verifier={verification.role === 'verifier'} + /> + </View> )} - </Text>{' '} - <Text emoji style={[t.atoms.text_contrast_medium]}> - {sanitizeHandle(account.handle)} + </View> + <Text style={[a.leading_tight, t.atoms.text_contrast_medium]}> + {sanitizeHandle(account.handle, '@')} </Text> - </Text> + </View> + {isCurrentAccount ? ( - <Check - size="sm" - style={[{color: t.palette.positive_600}, a.mr_md]} - /> + <Check size="sm" style={[{color: t.palette.positive_600}]} /> ) : ( - <Chevron size="sm" style={[t.atoms.text, a.mr_md]} /> + <Chevron size="sm" style={[t.atoms.text]} /> )} </View> )} |