From e845334c36f04bc7ec92518d06612db21dd34498 Mon Sep 17 00:00:00 2001 From: Brandon Dow Date: Tue, 4 Jun 2024 09:26:34 -0400 Subject: [PATCH] feat: Support icon in Chip component --- src/components/Chip.stories.tsx | 9 +++++++++ src/components/Chip.tsx | 7 +++++-- src/components/Icon.tsx | 2 +- 3 files changed, 15 insertions(+), 3 deletions(-) diff --git a/src/components/Chip.stories.tsx b/src/components/Chip.stories.tsx index 6a97be728..2820b15d3 100644 --- a/src/components/Chip.stories.tsx +++ b/src/components/Chip.stories.tsx @@ -49,3 +49,12 @@ export function ChipWithCustomTitle() { export function ChipWithCustomColor() { return ; } + +export function WithIcon() { + return ( +
+ + +
+ ); +} diff --git a/src/components/Chip.tsx b/src/components/Chip.tsx index 663d8d7be..06468ea29 100644 --- a/src/components/Chip.tsx +++ b/src/components/Chip.tsx @@ -3,6 +3,7 @@ import { usePresentationContext } from "src/components/PresentationContext"; import { maybeTooltip } from "src/components/Tooltip"; import { Css, Margin, Only, Properties, Xss } from "src/Css"; import { useTestIds } from "src/utils/useTestIds"; +import { Icon, IconKey } from "src/components/Icon"; export type ChipType = "caution" | "warning" | "success" | "light" | "dark" | "neutral" | "darkMode" | "info"; @@ -24,6 +25,7 @@ export interface ChipProps { xss?: X; type?: ChipType; compact?: boolean; + icon?: IconKey; } /** Kinda like a chip, but read-only, so no `onClick` or `hover`. */ @@ -32,7 +34,7 @@ export function Chip, X ...props }: ChipProps) { const { fieldProps } = usePresentationContext(); - const { text, title, xss = {}, compact = fieldProps?.compact } = props; + const { text, title, xss = {}, compact = fieldProps?.compact, icon } = props; const tid = useTestIds(props, "chip"); return maybeTooltip({ @@ -41,12 +43,13 @@ export function Chip, X children: ( + {icon && } {text} ), diff --git a/src/components/Icon.tsx b/src/components/Icon.tsx index ddab9e531..fd20cc3f9 100644 --- a/src/components/Icon.tsx +++ b/src/components/Icon.tsx @@ -11,7 +11,7 @@ export interface IconProps extends AriaAttributes, DOMProps { /** The size of the icon in increments, i.e. 1 == 8px, default is 3 == 24px. */ inc?: number; /** Styles overrides */ - xss?: Xss; + xss?: Xss; tooltip?: ReactNode; }