2022-09-26 19:43:24 +00:00
|
|
|
import { Meta } from '@storybook/react';
|
|
|
|
|
2023-08-27 21:01:35 +00:00
|
|
|
import { Badge, BadgeType, Props } from './Badge';
|
2022-09-26 19:43:24 +00:00
|
|
|
|
|
|
|
export default {
|
|
|
|
component: Badge,
|
|
|
|
title: 'Components/Badge',
|
|
|
|
argTypes: {
|
|
|
|
type: {
|
|
|
|
control: {
|
|
|
|
type: 'select',
|
|
|
|
options: ['success', 'danger', 'warn', 'info'],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
} as Meta<Props>;
|
|
|
|
|
|
|
|
// : JSX.IntrinsicAttributes & PropsWithChildren<Props>
|
|
|
|
function Template({ type = 'success' }: Props) {
|
2023-08-27 21:01:35 +00:00
|
|
|
const message: Record<BadgeType, string> = {
|
2022-09-26 19:43:24 +00:00
|
|
|
success: 'success badge',
|
|
|
|
danger: 'danger badge',
|
|
|
|
warn: 'warn badge',
|
|
|
|
info: 'info badge',
|
2023-08-27 21:01:35 +00:00
|
|
|
successSecondary: 'successSecondary badge',
|
|
|
|
dangerSecondary: 'dangerSecondary badge',
|
|
|
|
warnSecondary: 'warnSecondary badge',
|
|
|
|
infoSecondary: 'infoSecondary badge',
|
2022-09-26 19:43:24 +00:00
|
|
|
};
|
|
|
|
return <Badge type={type}>{message[type]}</Badge>;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const Example = Template.bind({});
|