diff --git a/.changeset/four-donuts-chew.md b/.changeset/four-donuts-chew.md new file mode 100644 index 000000000..b4be6170d --- /dev/null +++ b/.changeset/four-donuts-chew.md @@ -0,0 +1,5 @@ +--- +"@khanacademy/wonder-blocks-icon-button": minor +--- + +IconButton: Add option for `large` value for `size` prop (24x24 icon size with target area of 48x48) diff --git a/__docs__/wonder-blocks-icon-button/icon-button-variants.stories.tsx b/__docs__/wonder-blocks-icon-button/icon-button-variants.stories.tsx index 1aaa4b420..c55f658a5 100644 --- a/__docs__/wonder-blocks-icon-button/icon-button-variants.stories.tsx +++ b/__docs__/wonder-blocks-icon-button/icon-button-variants.stories.tsx @@ -25,6 +25,13 @@ export default { type StoryComponentType = StoryObj; +const sizes: ("xsmall" | "small" | "medium" | "large")[] = [ + "xsmall", + "small", + "medium", + "large", +]; + const KindVariants = ({ kind, light, @@ -38,7 +45,7 @@ const KindVariants = ({ <> {kind}-default - + + {sizes.map((size) => ( + + ))} + {kind}-destructive - + + {sizes.map((size) => ( + + ))} + {kind}-disabled - + + {sizes.map((size) => ( + + ))} + )} @@ -160,11 +188,17 @@ const styles = StyleSheet.create({ gridTemplateColumns: "repeat(3, 250px)", gap: spacing.large_24, }, - gridRow: { - flexDirection: "row", + gridCol: { + flexDirection: "column", alignItems: "center", - gap: spacing.medium_16, + gap: spacing.large_24, justifyContent: "space-between", padding: spacing.medium_16, }, + iconButtons: { + display: "flex", + flexDirection: "row", + alignItems: "center", + gap: spacing.xLarge_32, + }, }); diff --git a/__docs__/wonder-blocks-icon-button/icon-button.argtypes.ts b/__docs__/wonder-blocks-icon-button/icon-button.argtypes.ts index 4e97b5293..eb5e1ac47 100644 --- a/__docs__/wonder-blocks-icon-button/icon-button.argtypes.ts +++ b/__docs__/wonder-blocks-icon-button/icon-button.argtypes.ts @@ -49,14 +49,27 @@ export default { type: "select", }, description: "The size of the icon button.", - options: ["xsmall", "small", "medium"], + options: ["xsmall", "small", "medium", "large"], table: { type: { - summary: `"xsmall" | "small" | "medium"`, + summary: `"xsmall" | "small" | "medium" | "large"`, }, defaultValue: { summary: `"medium"`, }, }, }, + "aria-label": { + description: + "The description of this component for the screenreader to read.", + control: { + type: "text", + }, + table: { + category: "Accessibility", + type: { + summary: "string", + }, + }, + }, }; diff --git a/__docs__/wonder-blocks-icon-button/icon-button.stories.tsx b/__docs__/wonder-blocks-icon-button/icon-button.stories.tsx index 79aed0cfc..7e1e004f2 100644 --- a/__docs__/wonder-blocks-icon-button/icon-button.stories.tsx +++ b/__docs__/wonder-blocks-icon-button/icon-button.stories.tsx @@ -84,6 +84,9 @@ export default { }, }, argTypes: IconButtonArgtypes, + args: { + "aria-label": "Search", + }, } as Meta; type StoryComponentType = StoryObj; @@ -115,6 +118,7 @@ export const Default: StoryComponentType = { * - `xsmall` (16px icon with a 24px touch target). * - `small` (24px icon with a 32px touch target). * - `medium` (24px icon with a 40px touch target). + * - `large` (24px icon with a 48px touch target). */ export const Sizes: StoryComponentType = { ...Default, @@ -139,6 +143,10 @@ export const Sizes: StoryComponentType = { medium + + large + + ), }; @@ -185,26 +193,30 @@ export const Variants: StoryComponentType = { */ export const WithColor: StoryComponentType = { name: "Color", - render: () => ( + render: (args) => ( {}} color="destructive" /> {}} kind="secondary" color="destructive" /> {}} kind="tertiary" color="destructive" /> > & { /** @@ -42,7 +42,8 @@ export type SharedProps = Partial> & { testId?: string; /** * Size of the icon button. - * One of `xsmall` (16 icon, 20 target), `small` (24, 32), or `medium (24, 40). + * One of `xsmall` (16 icon, 20 target), `small` (24, 32), `medium` (24, 40), + * or `large` (24, 48). * Defaults to `medium`. */ size?: IconButtonSize; diff --git a/packages/wonder-blocks-icon-button/src/util/icon-button-util.test.ts b/packages/wonder-blocks-icon-button/src/util/icon-button-util.test.ts index 039290f28..ea2b0f221 100644 --- a/packages/wonder-blocks-icon-button/src/util/icon-button-util.test.ts +++ b/packages/wonder-blocks-icon-button/src/util/icon-button-util.test.ts @@ -6,6 +6,7 @@ describe("iconSizeForButtonSize", () => { ${"xsmall"} | ${"small"} ${"small"} | ${"medium"} ${"medium"} | ${"medium"} + ${"large"} | ${"medium"} `( "should return $expectedIconSize icon for $buttonSize icon button", ({buttonSize, expectedIconSize}) => { @@ -20,6 +21,7 @@ describe("targetPixelsForSize", () => { ${"xsmall"} | ${24} ${"small"} | ${32} ${"medium"} | ${40} + ${"large"} | ${48} `( "should return $expectedTargetPixels for $size icon button", ({size, expectedTargetPixels}) => { diff --git a/packages/wonder-blocks-icon-button/src/util/icon-button-util.ts b/packages/wonder-blocks-icon-button/src/util/icon-button-util.ts index 3b4d6dacd..652e4ccd8 100644 --- a/packages/wonder-blocks-icon-button/src/util/icon-button-util.ts +++ b/packages/wonder-blocks-icon-button/src/util/icon-button-util.ts @@ -12,6 +12,8 @@ export const iconSizeForButtonSize = (size: IconButtonSize): IconSize => { return "medium"; case "medium": return "medium"; + case "large": + return "medium"; } }; @@ -19,4 +21,4 @@ export const iconSizeForButtonSize = (size: IconButtonSize): IconSize => { * A function that returns the size of the touch target in pixels for a given icon button size. */ export const targetPixelsForSize = (size: IconButtonSize): number => - ({xsmall: 24, small: 32, medium: 40}[size]); + ({xsmall: 24, small: 32, medium: 40, large: 48}[size]);