forked from WordPress/gutenberg
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Enhancement : Badge Component (WordPress#66555)
* Create badge component * Imports and Manifest * Add test and capability for additional props using spread operator * Enhance componenet furthermore * Generate README via manifest & Add in ignore list * Lock Badge * Convert Storybook from CSF 2 to CSF 3 Format * Improve the component * New iteration * Add new icons: Error and Caution * Utilize new icons * Update icons * decrease icon size * Address feedback * Fix SVG formatting * Fix unit test * Remove unnecessary type (already included) * Update readme * Adjust icon keywords * Add changelog --------- Co-authored-by: Vrishabhsk <[email protected]> Co-authored-by: jameskoster <[email protected]> Co-authored-by: mirka <[email protected]> Co-authored-by: rogermattic <[email protected]> Co-authored-by: jasmussen <[email protected]>
- Loading branch information
1 parent
5931dd5
commit 24d5f78
Showing
17 changed files
with
289 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
# Badge | ||
|
||
<!-- This file is generated automatically and cannot be edited directly. Make edits via TypeScript types and TSDocs. --> | ||
|
||
<p class="callout callout-info">See the <a href="https://wordpress.github.io/gutenberg/?path=/docs/components-badge--docs">WordPress Storybook</a> for more detailed, interactive documentation.</p> | ||
|
||
## Props | ||
|
||
### `children` | ||
|
||
Text to display inside the badge. | ||
|
||
- Type: `string` | ||
- Required: Yes | ||
|
||
### `intent` | ||
|
||
Badge variant. | ||
|
||
- Type: `"default" | "info" | "success" | "warning" | "error"` | ||
- Required: No | ||
- Default: `default` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
{ | ||
"$schema": "../../schemas/docs-manifest.json", | ||
"displayName": "Badge", | ||
"filePath": "./index.tsx" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
/** | ||
* External dependencies | ||
*/ | ||
import clsx from 'clsx'; | ||
|
||
/** | ||
* WordPress dependencies | ||
*/ | ||
import { info, caution, error, published } from '@wordpress/icons'; | ||
|
||
/** | ||
* Internal dependencies | ||
*/ | ||
import type { BadgeProps } from './types'; | ||
import type { WordPressComponentProps } from '../context'; | ||
import Icon from '../icon'; | ||
|
||
function Badge( { | ||
className, | ||
intent = 'default', | ||
children, | ||
...props | ||
}: WordPressComponentProps< BadgeProps, 'span', false > ) { | ||
/** | ||
* Returns an icon based on the badge context. | ||
* | ||
* @return The corresponding icon for the provided context. | ||
*/ | ||
function contextBasedIcon() { | ||
switch ( intent ) { | ||
case 'info': | ||
return info; | ||
case 'success': | ||
return published; | ||
case 'warning': | ||
return caution; | ||
case 'error': | ||
return error; | ||
default: | ||
return null; | ||
} | ||
} | ||
|
||
return ( | ||
<span | ||
className={ clsx( | ||
'components-badge', | ||
`is-${ intent }`, | ||
intent !== 'default' && 'has-icon', | ||
className | ||
) } | ||
{ ...props } | ||
> | ||
{ intent !== 'default' && ( | ||
<Icon | ||
icon={ contextBasedIcon() } | ||
size={ 16 } | ||
fill="currentColor" | ||
/> | ||
) } | ||
{ children } | ||
</span> | ||
); | ||
} | ||
|
||
export default Badge; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
/** | ||
* External dependencies | ||
*/ | ||
import type { Meta, StoryObj } from '@storybook/react'; | ||
|
||
/** | ||
* Internal dependencies | ||
*/ | ||
import Badge from '..'; | ||
|
||
const meta = { | ||
component: Badge, | ||
title: 'Components/Containers/Badge', | ||
tags: [ 'status-private' ], | ||
} satisfies Meta< typeof Badge >; | ||
|
||
export default meta; | ||
|
||
type Story = StoryObj< typeof meta >; | ||
|
||
export const Default: Story = { | ||
args: { | ||
children: 'Code is Poetry', | ||
}, | ||
}; | ||
|
||
export const Info: Story = { | ||
args: { | ||
...Default.args, | ||
intent: 'info', | ||
}, | ||
}; | ||
|
||
export const Success: Story = { | ||
args: { | ||
...Default.args, | ||
intent: 'success', | ||
}, | ||
}; | ||
|
||
export const Warning: Story = { | ||
args: { | ||
...Default.args, | ||
intent: 'warning', | ||
}, | ||
}; | ||
|
||
export const Error: Story = { | ||
args: { | ||
...Default.args, | ||
intent: 'error', | ||
}, | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
$badge-colors: ( | ||
"info": #3858e9, | ||
"warning": $alert-yellow, | ||
"error": $alert-red, | ||
"success": $alert-green, | ||
); | ||
|
||
.components-badge { | ||
background-color: color-mix(in srgb, $white 90%, var(--base-color)); | ||
color: color-mix(in srgb, $black 50%, var(--base-color)); | ||
padding: 0 $grid-unit-10; | ||
min-height: $grid-unit-30; | ||
border-radius: $radius-small; | ||
font-size: $font-size-small; | ||
font-weight: 400; | ||
flex-shrink: 0; | ||
line-height: $font-line-height-small; | ||
width: fit-content; | ||
display: flex; | ||
align-items: center; | ||
gap: 2px; | ||
|
||
&:where(.is-default) { | ||
background-color: $gray-100; | ||
color: $gray-800; | ||
} | ||
|
||
&.has-icon { | ||
padding-inline-start: $grid-unit-05; | ||
} | ||
|
||
// Generate color variants | ||
@each $type, $color in $badge-colors { | ||
&.is-#{$type} { | ||
--base-color: #{$color}; | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
/** | ||
* External dependencies | ||
*/ | ||
import { render, screen } from '@testing-library/react'; | ||
|
||
/** | ||
* Internal dependencies | ||
*/ | ||
import Badge from '..'; | ||
|
||
describe( 'Badge', () => { | ||
it( 'should render correctly with default props', () => { | ||
render( <Badge>Code is Poetry</Badge> ); | ||
const badge = screen.getByText( 'Code is Poetry' ); | ||
expect( badge ).toBeInTheDocument(); | ||
expect( badge.tagName ).toBe( 'SPAN' ); | ||
expect( badge ).toHaveClass( 'components-badge' ); | ||
} ); | ||
|
||
it( 'should render as per its intent and contain an icon', () => { | ||
render( <Badge intent="error">Code is Poetry</Badge> ); | ||
const badge = screen.getByText( 'Code is Poetry' ); | ||
expect( badge ).toHaveClass( 'components-badge', 'is-error' ); | ||
expect( badge ).toHaveClass( 'has-icon' ); | ||
} ); | ||
|
||
it( 'should combine custom className with default class', () => { | ||
render( <Badge className="custom-class">Code is Poetry</Badge> ); | ||
const badge = screen.getByText( 'Code is Poetry' ); | ||
expect( badge ).toHaveClass( 'components-badge' ); | ||
expect( badge ).toHaveClass( 'custom-class' ); | ||
} ); | ||
|
||
it( 'should pass through additional props', () => { | ||
render( <Badge data-testid="custom-badge">Code is Poetry</Badge> ); | ||
const badge = screen.getByTestId( 'custom-badge' ); | ||
expect( badge ).toHaveTextContent( 'Code is Poetry' ); | ||
expect( badge ).toHaveClass( 'components-badge' ); | ||
} ); | ||
} ); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
export type BadgeProps = { | ||
/** | ||
* Badge variant. | ||
* | ||
* @default 'default' | ||
*/ | ||
intent?: 'default' | 'info' | 'success' | 'warning' | 'error'; | ||
/** | ||
* Text to display inside the badge. | ||
*/ | ||
children: string; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
/** | ||
* WordPress dependencies | ||
*/ | ||
import { SVG, Path } from '@wordpress/primitives'; | ||
|
||
const caution = ( | ||
<SVG viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"> | ||
<Path | ||
fillRule="evenodd" | ||
clipRule="evenodd" | ||
d="M5.5 12a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0ZM12 4a8 8 0 1 0 0 16 8 8 0 0 0 0-16Zm-.75 12v-1.5h1.5V16h-1.5Zm0-8v5h1.5V8h-1.5Z" | ||
/> | ||
</SVG> | ||
); | ||
|
||
export default caution; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
/** | ||
* WordPress dependencies | ||
*/ | ||
import { SVG, Path } from '@wordpress/primitives'; | ||
|
||
const error = ( | ||
<SVG viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"> | ||
<Path | ||
fillRule="evenodd" | ||
clipRule="evenodd" | ||
d="M12.218 5.377a.25.25 0 0 0-.436 0l-7.29 12.96a.25.25 0 0 0 .218.373h14.58a.25.25 0 0 0 .218-.372l-7.29-12.96Zm-1.743-.735c.669-1.19 2.381-1.19 3.05 0l7.29 12.96a1.75 1.75 0 0 1-1.525 2.608H4.71a1.75 1.75 0 0 1-1.525-2.608l7.29-12.96ZM12.75 17.46h-1.5v-1.5h1.5v1.5Zm-1.5-3h1.5v-5h-1.5v5Z" | ||
/> | ||
</SVG> | ||
); | ||
|
||
export default error; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters