diff --git a/.changeset/quiet-cars-add.md b/.changeset/quiet-cars-add.md new file mode 100644 index 0000000000..6b4f5924fa --- /dev/null +++ b/.changeset/quiet-cars-add.md @@ -0,0 +1,5 @@ +--- +'@penumbra-zone/ui': patch +--- + +Fix and improve UI components to prepare them for sub-account selector diff --git a/packages/ui/src/AddressViewComponent/index.tsx b/packages/ui/src/AddressViewComponent/index.tsx index 687efe1391..fdaac2654d 100644 --- a/packages/ui/src/AddressViewComponent/index.tsx +++ b/packages/ui/src/AddressViewComponent/index.tsx @@ -16,11 +16,16 @@ const Root = styled.div` export interface AddressViewProps { addressView: AddressView | undefined; copyable?: boolean; + hideIcon?: boolean; } // Renders an address or an address view. // If the view is given and is "visible", the account information will be displayed instead. -export const AddressViewComponent = ({ addressView, copyable = true }: AddressViewProps) => { +export const AddressViewComponent = ({ + addressView, + copyable = true, + hideIcon, +}: AddressViewProps) => { if (!addressView?.addressView.value?.address) { return null; } @@ -34,14 +39,16 @@ export const AddressViewComponent = ({ addressView, copyable = true }: AddressVi return ( - - - + {!hideIcon && ( + + + + )} {addressIndex ? ( {isRandomized && 'IBC Deposit Address for '} - {`Account #${addressIndex.account}`} + {`Sub-Account #${addressIndex.account}`} ) : ( diff --git a/packages/ui/src/Button/index.tsx b/packages/ui/src/Button/index.tsx index 7839fa9b88..70a7626307 100644 --- a/packages/ui/src/Button/index.tsx +++ b/packages/ui/src/Button/index.tsx @@ -19,10 +19,11 @@ const iconOnlyAdornment = css` const sparse = css` border-radius: ${props => props.theme.borderRadius.sm}; - padding-left: ${props => props.theme.spacing(4)}; - padding-right: ${props => props.theme.spacing(4)}; + padding-left: ${props => (props.$iconOnly ? 'none' : props.theme.spacing(4))}; + padding-right: ${props => (props.$iconOnly ? 'none' : props.theme.spacing(4))}; height: 48px; width: ${props => (props.$iconOnly ? '48px' : '100%')}; + ${props => props.$iconOnly && 'min-width: 48px;'} `; const compact = css` diff --git a/packages/ui/src/DropdownMenu/Item.tsx b/packages/ui/src/DropdownMenu/Item.tsx index c11385b1fa..78aeec15a9 100644 --- a/packages/ui/src/DropdownMenu/Item.tsx +++ b/packages/ui/src/DropdownMenu/Item.tsx @@ -1,4 +1,4 @@ -import type { ReactNode } from 'react'; +import { ReactNode } from 'react'; import { Item as RadixDropdownMenuItem } from '@radix-ui/react-dropdown-menu'; import { asTransientProps } from '../utils/asTransientProps.ts'; import { Text } from '../Text'; @@ -7,17 +7,20 @@ import { DropdownMenuItemBase, MenuItem } from '../utils/menuItem.ts'; export interface DropdownMenuItemProps extends DropdownMenuItemBase { children?: ReactNode; onSelect?: (event: Event) => void; + icon?: ReactNode; } export const Item = ({ children, + icon, actionType = 'default', disabled, onSelect, }: DropdownMenuItemProps) => { return ( - + + {icon} {children} diff --git a/packages/ui/src/utils/menuItem.ts b/packages/ui/src/utils/menuItem.ts index 26458713bf..349802ae58 100644 --- a/packages/ui/src/utils/menuItem.ts +++ b/packages/ui/src/utils/menuItem.ts @@ -38,7 +38,7 @@ export const MenuItem = styled.div` } &[aria-checked='false'], - &[role='menuitem'] { + &[role='menuitem'][data-icon='false'] { padding-left: ${props => props.theme.spacing(9)}; }