Card
Card is a container for text, photos, and actions in the context of a single subject.
Installation
npx nextui-cli@latest add card
The above command is for individual installation only. You may skip this step if @nextui-org/react
is already installed globally.
Import
NextUI exports 4 card-related components:
- Card: The main component to display a card.
- CardHeader: Commonly used for the title of a card.
- CardBody: The content of the card.
- CardFooter: Commonly used for actions.
Usage
With Divider
See the Divider component for more details.
With Image
Blurred Footer
You can pass the isFooterBlurred
prop to the card to blur the footer.
Composition
You can use other NextUI components inside the card to compose a more complex card.
Blurred Card
You can pass the isBlurred
prop to the card to blur the card. Card gets blurred properties based on its ancestor element.
Note: While trying out the above example, it is required to provide the necessary background(eg. adding bg-gradient-to-tr from-[#FFB457] to-[#FF705B]
classes) to any ancestor element of the Card component to obtain the blur
effect as seen in the preview.
Primary Action
If you pass the isPressable
prop to the card, it will be rendered as a button.
Note: that the used callback function is
onPress
instead ofonClick
. Please see the usePress component for more details.
Cover Image
You can use Image
component as the cover of the card by taking it out of the CardBody
component.
Slots
- base: The main container of the card, where the header, body, and footer are placed.
- header: The header of the card, usually used for the title.
- body: The body of the card, where the main content is placed.
- footer: The footer of the card, usually used for actions.
Data Attributes
Card
has the following attributes on the base
element:
- data-hover: When the card is being hovered. Based on useHover
- data-focus: When the card is being focused. Based on useFocusRing.
- data-focus-visible: When the card is being focused with the keyboard. Based on useFocusRing.
- data-disabled:
When the card is disabled. Based on
isDisabled
prop. - data-pressed: When the card is pressed. Based on usePress
API
Card Props
Attribute | Type | Description | Default |
---|---|---|---|
children | ReactNode | ReactNode[] | Usually the Card parts, CardHeader , CardBody and CardFooter . | - |
shadow | none | sm | md | lg | The card shadow. | md |
radius | none | sm | md | lg | The card border radius. | lg |
fullWidth | boolean | Whether the card should take the full width of its parent. | false |
isHoverable | boolean | Whether the card should change the background on hover. | false |
isPressable | boolean | Whether the card should allow to be pressed. | false |
isBlurred | boolean | Whether the card background should be blurred. | false |
isFooterBlurred | boolean | Whether the card footer background should be blurred. | false |
isDisabled | boolean | Whether the card should be disabled. The press events will be ignored. | false |
disableAnimation | boolean | Whether to disable the animation. | false |
disableRipple | boolean | Whether to disable ripple effect. Only when isPressable is true. | false |
allowTextSelectionOnPress | boolean | Whether to allow text selection on pressing. Only when isPressable is true. | false |
classNames | Record<"base"| "header"| "body"| "footer", string> | Allows to set custom class names for the card slots. | - |
Card Events
Attribute | Type | Description |
---|---|---|
onPress | (e: PressEvent) => void | Handler that is called when the press is released over the target. |
onPressStart | (e: PressEvent) => void | Handler that is called when a press interaction starts. |
onPressEnd | (e: PressEvent) => void | Handler that is called when a press interaction ends, either over the target or when the pointer leaves the target. |
onPressChange | (isPressed: boolean) => void | Handler that is called when the press state changes. |
onPressUp | (e: PressEvent) => void | Handler that is called when a press is released over the target, regardless of whether it started on the target or not. |