Card
A container that groups related content and actions into a box with optional header, content, and footer sections.
Loading...
<twig:Card class="w-full max-w-sm">
<twig:Card:Header>
<twig:Card:Title>Login to your account</twig:Card:Title>
<twig:Card:Description>
Enter your email below to login to your account
</twig:Card:Description>
</twig:Card:Header>
<twig:Card:Content>
<form>
<div class="flex flex-col gap-6">
<div class="grid gap-2">
<twig:Label for="email">Email</twig:Label>
<twig:Input
id="email"
type="email"
placeholder="m@example.com"
required
/>
</div>
<div class="grid gap-2">
<div class="flex items-center">
<twig:Label for="password">Password</twig:Label>
<a
href="#"
class="ml-auto inline-block text-sm underline-offset-4 hover:underline"
>
Forgot your password?
</a>
</div>
<twig:Input id="password" type="password" required />
</div>
</div>
</form>
</twig:Card:Content>
<twig:Card:Footer class="flex-col gap-2">
<twig:Button type="submit" class="w-full">
Login
</twig:Button>
<twig:Button variant="outline" class="w-full">
Login with Google
</twig:Button>
</twig:Card:Footer>
</twig:Card>
Installation
bin/console ux:install card --kit shadcn
That's it!
Install the following Composer dependencies:
composer require tales-from-a-dev/twig-tailwind-extra:^1.0.0
Copy the following file(s) into your Symfony app:
{# @block content The default block #}
<div
class="{{ 'rounded-lg border bg-card text-card-foreground shadow-sm ' ~ attributes.render('class')|tailwind_merge }}"
{{ attributes }}
>
{%- block content %}{% endblock -%}
</div>
{# @block content The default block #}
<div
class="{{ 'p-6 pt-0 ' ~ attributes.render('class')|tailwind_merge }}"
{{ attributes }}
>
{%- block content %}{% endblock -%}
</div>
{# @block content The default block #}
<div
class="{{ 'text-muted-foreground text-sm ' ~ attributes.render('class')|tailwind_merge }}"
{{ attributes }}
>
{%- block content %}{% endblock -%}
</div>
{# @block content The default block #}
<div
class="{{ 'flex items-center p-6 pt-0 ' ~ attributes.render('class')|tailwind_merge }}"
{{ attributes }}
>
{%- block content %}{% endblock -%}
</div>
{# @block content The default block #}
<div
class="{{ 'flex flex-col space-y-1.5 p-6 ' ~ attributes.render('class')|tailwind_merge }}"
{{ attributes }}
>
{%- block content %}{% endblock -%}
</div>
{# @block content The default block #}
<div
class="{{ 'leading-none font-semibold ' ~ attributes.render('class')|tailwind_merge }}"
{{ attributes }}
>
{%- block content %}{% endblock -%}
</div>
Happy coding!
Usage
<twig:Card>
<twig:Card:Header>
<twig:Card:Title>Card Title</twig:Card:Title>
<twig:Card:Description>Card Description</twig:Card:Description>
</twig:Card:Header>
<twig:Card:Content>
<p>Card Content</p>
</twig:Card:Content>
<twig:Card:Footer>
<p>Card Footer</p>
</twig:Card:Footer>
</twig:Card>
API Reference
Card
| Block | Description |
|---|---|
content |
The default block |
Card:Content
| Block | Description |
|---|---|
content |
The default block |
Card:Description
| Block | Description |
|---|---|
content |
The default block |
Card:Footer
| Block | Description |
|---|---|
content |
The default block |
Card:Header
| Block | Description |
|---|---|
content |
The default block |
Card:Title
| Block | Description |
|---|---|
content |
The default block |