diff --git a/packages/ui/src/Button/index.tsx b/packages/ui/src/Button/index.tsx index e7e0251de..434ec9402 100644 --- a/packages/ui/src/Button/index.tsx +++ b/packages/ui/src/Button/index.tsx @@ -102,13 +102,15 @@ export const Button = forwardRef( actionType = 'default', type = 'button', priority = 'primary', + density: densityProp, ...attrs // needed for the Radix's `asChild` prop to work correctly // https://www.radix-ui.com/primitives/docs/guides/composition#composing-with-your-own-react-components }, ref, ) => { - const density = useDensity(); + const densityContext = useDensity(); + const density = densityProp ?? densityContext; const styleAttrs = { actionType, iconOnly, density, priority }; return ( @@ -133,7 +135,7 @@ export const Button = forwardRef( 'relative', 'text-neutral-contrast', - 'flex items-center justify-center', + 'inline-flex items-center justify-center', density === 'sparse' ? 'gap-2' : 'gap-1', )} > diff --git a/packages/ui/src/Table/index.tsx b/packages/ui/src/Table/index.tsx index f4c23a75d..e6e9d399d 100644 --- a/packages/ui/src/Table/index.tsx +++ b/packages/ui/src/Table/index.tsx @@ -3,6 +3,7 @@ import cn from 'clsx'; import { tableHeading, tableItem } from '../utils/typography'; import { Density, useDensity } from '../utils/density'; import { ConditionalWrap } from '../ConditionalWrap'; +import { getThemeColorClass, ThemeColor } from '../utils/color'; export interface TableProps { /** Content that will appear above the table. */ @@ -10,6 +11,8 @@ export interface TableProps { children: ReactNode; /** Which CSS `table-layout` property to use. */ tableLayout?: 'fixed' | 'auto'; + /** The background color of the table. */ + bgColor?: ThemeColor; } /** @@ -53,7 +56,12 @@ export interface TableProps { * * ``` */ -export const Table = ({ title, children, tableLayout }: TableProps) => ( +export const Table = ({ + title, + children, + tableLayout, + bgColor = 'other.tonalFill5', +}: TableProps) => ( ( @@ -67,7 +75,8 @@ export const Table = ({ title, children, tableLayout }: TableProps) => ( cellSpacing={0} cellPadding={0} className={cn( - 'w-full bg-other-tonalFill5 pl-3 pr-3 rounded-sm', + getThemeColorClass(bgColor).bg, + 'w-full pl-3 pr-3 rounded-sm', tableLayout === 'fixed' ? 'table-fixed' : 'table-auto', )} > @@ -82,16 +91,22 @@ Table.Thead = Thead; const Tbody = ({ children }: PropsWithChildren) => {children}; Table.Tbody = Tbody; -const Tr = ({ children }: PropsWithChildren) => ( - {children} -); +const Tr = ({ children }: PropsWithChildren) => {children}; Table.Tr = Tr; type HAlign = 'left' | 'center' | 'right'; type VAlign = 'top' | 'middle' | 'bottom'; -const getCell = (density: Density) => - cn('box-border', 'pl-3 pr-3', density === 'sparse' ? 'pt-4 pb-4' : 'pt-3 pb-3'); +const densityPaddingMapping = { + slim: 'px-3 py-2', + compact: 'px-3 py-3', + sparse: 'px-3 py-4', +}; + +const getCell = (density: Density) => { + const padding = densityPaddingMapping[density]; + return cn('box-border', padding); +}; const Th = ({ children, @@ -99,6 +114,7 @@ const Th = ({ hAlign, vAlign, width, + density: densityProp, }: PropsWithChildren<{ colSpan?: number; /** A CSS `width` value to use for this cell. */ @@ -107,8 +123,10 @@ const Th = ({ hAlign?: HAlign; /** Controls the CSS `vertical-align` property for this cell. */ vAlign?: VAlign; + density?: Density; }>) => { - const density = useDensity(); + const densityContext = useDensity(); + const density = densityProp ?? densityContext; return ( ) => { - const density = useDensity(); + const densityContext = useDensity(); + const density = densityProp ?? densityContext; return ( & Partial, never>>; diff --git a/packages/ui/src/ValueView/index.tsx b/packages/ui/src/ValueView/index.tsx index ff08836bc..510a99649 100644 --- a/packages/ui/src/ValueView/index.tsx +++ b/packages/ui/src/ValueView/index.tsx @@ -18,6 +18,10 @@ const ValueText = ({ children, density }: { children: ReactNode; density: Densit return {children}; } + if (density === 'slim') { + return {children}; + } + return {children}; }; @@ -35,6 +39,10 @@ export interface ValueViewComponentProps { * numeraire. */ priority?: PillProps['priority']; + /** + * If true, the asset icon will be visible. + */ + showIcon?: boolean; /** * If true, the asset symbol will be visible. */ @@ -51,6 +59,11 @@ export interface ValueViewComponentProps { * If true, the amount will have trailing zeros. */ trailingZeros?: boolean; + /** + * The density to use for the component. If not provided, the density will be + * determined by the `Density` context. + */ + density?: Density; } /** @@ -64,12 +77,15 @@ export const ValueViewComponent = ( valueView, context, priority = 'primary', + showIcon = true, showSymbol = true, abbreviate = false, showValue = true, trailingZeros = false, + density: densityProps, }: ValueViewComponentProps) => { - const density = useDensity(); + const densityContext = useDensity(); + const density = densityProps ?? densityContext; if (!valueView) { return null; @@ -102,9 +118,11 @@ export const ValueViewComponent = ( )} > -
- -
+ {showIcon && ( +
+ +
+ )}