Skip to content

Commit

Permalink
BREAKING CHANGE: the type property was renamed to "variant", IconButt…
Browse files Browse the repository at this point in the history
…ons extends now the native ButtonHTMLAttributes
  • Loading branch information
coderwelsch committed Oct 2, 2024
1 parent 81d93ff commit ca7a12f
Show file tree
Hide file tree
Showing 4 changed files with 10 additions and 23 deletions.
2 changes: 1 addition & 1 deletion src/components/dialog/dialog.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,7 @@ export const Dialog = ({
<IconButton
className="absolute right-0 top-0"
Icon={CrossIcon}
type="minimal"
variant="minimal"
onClick={() => handleClose(false)}
/>
)}
Expand Down
6 changes: 3 additions & 3 deletions src/components/icon-button/icon-button.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import type { Meta, StoryObj } from "@storybook/react";
import { IconButton, IconButtonProps } from "./icon-button";
import { WalkIcon } from "../../icons";

const IconTypes: IconButtonProps["type"][] = [
const VariantTypes: IconButtonProps["variant"][] = [
"primary",
"secondary",
"minimal",
Expand All @@ -15,12 +15,12 @@ const meta: Meta<typeof IconButton> = {
title: "IconButton",
component: IconButton,
args: {
type: "primary",
variant: "primary",
disabled: false,
Icon: WalkIcon,
},
argTypes: {
type: { options: IconTypes },
variant: { options: VariantTypes },
},
};

Expand Down
23 changes: 5 additions & 18 deletions src/components/icon-button/icon-button.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,34 +16,21 @@ const iconButtonVariants = {
"bg-neutral-0 text-danger-500 border border-danger-500 hover:bg-danger-50 hover:text-danger-600 active:border-danger-700 active:text-danger-700 active:bg-danger-100 focus:ring-2 focus:ring-danger-100 focus:text-danger-600 disabled:border-danger-100 disabled:text-danger-100 disabled:bg-neutral-0 fill-danger-600",
};

export interface IconButtonProps {
export interface IconButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {
Icon: React.ElementType;
type: keyof typeof iconButtonVariants;
onClick: () => void;
disabled?: boolean;
className?: string;
ariaLabel?: string;
variant?: keyof typeof iconButtonVariants;
}

export const IconButton = ({
Icon,
onClick,
disabled = false,
type = "primary",
className,
ariaLabel,
}: IconButtonProps) => {
export const IconButton = ({ Icon, variant = "primary", className, ...props }: IconButtonProps) => {
return (
<button
type="button"
aria-label={ariaLabel}
className={classNames(
`inline-flex h-8 w-8 flex-shrink-0 items-center justify-center rounded focus:outline-none`,
iconButtonVariants[type],
iconButtonVariants[variant],
className
)}
onClick={onClick}
disabled={disabled}
{...props}
>
<Icon className="h-3 w-3" />
</button>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,7 @@ export const Draggable = () => {
width: 80,
},
cell: (row) => (
<IconButton onClick={() => row.getValue()} Icon={TrashIcon} type="danger" />
<IconButton onClick={() => row.getValue()} Icon={TrashIcon} variant="danger" />
),
}),
];
Expand Down

0 comments on commit ca7a12f

Please sign in to comment.