about summary refs log tree commit diff
path: root/src/view/com/util/AccountDropdownBtn.tsx
blob: 034fbfc653a48e6eef7aa6dcee58091ed9202ee4 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
import React from 'react'
import {msg, Trans} from '@lingui/macro'
import {useLingui} from '@lingui/react'

import {SessionAccount, useSessionApi} from '#/state/session'
import {HITSLOP_10} from 'lib/constants'
import {Button, ButtonIcon} from '#/components/Button'
import {useDialogControl} from '#/components/Dialog'
import {DotGrid_Stroke2_Corner0_Rounded as Ellipsis} from '#/components/icons/DotGrid'
import {Trash_Stroke2_Corner0_Rounded as Trash} from '#/components/icons/Trash'
import * as Menu from '#/components/Menu'
import * as Prompt from '#/components/Prompt'
import * as Toast from '../../com/util/Toast'

export function AccountDropdownBtn({account}: {account: SessionAccount}) {
  const {_} = useLingui()
  const {removeAccount} = useSessionApi()
  const removePromptControl = useDialogControl()

  return (
    <>
      <Menu.Root>
        <Menu.Trigger label={_(`Account options`)}>
          {({props}) => {
            return (
              <Button
                {...props}
                testID="accountSettingsDropdownBtn"
                label={_(`Account options`)}
                hitSlop={HITSLOP_10}
                size="xsmall"
                shape="round"
                color="secondary"
                variant="ghost">
                <ButtonIcon icon={Ellipsis} size="sm" />
              </Button>
            )
          }}
        </Menu.Trigger>

        <Menu.Outer style={{minWidth: 170}}>
          <Menu.Group>
            <Menu.Item
              label={_(msg`Remove account`)}
              onPress={() => {
                removePromptControl.open()
              }}>
              <Menu.ItemText>
                <Trans>Remove account</Trans>
              </Menu.ItemText>
              <Menu.ItemIcon icon={Trash} />
            </Menu.Item>
          </Menu.Group>
        </Menu.Outer>
      </Menu.Root>

      <Prompt.Basic
        control={removePromptControl}
        title={_(msg`Remove from quick access?`)}
        description={_(
          msg`This will remove @${account.handle} from the quick access list.`,
        )}
        onConfirm={() => {
          removeAccount(account)
          Toast.show(_(msg`Account removed from quick access`))
        }}
        confirmButtonCta={_(msg`Remove`)}
        confirmButtonColor="negative"
      />
    </>
  )
}