design system token v0.1

This commit is contained in:
Juan
2026-04-13 15:33:00 -05:00
parent 52b4156653
commit c3215945f2
63 changed files with 11562 additions and 181 deletions

View File

@@ -0,0 +1,87 @@
import type { Meta, StoryObj } from '@storybook/react'
import {
Accordion,
AccordionItem,
AccordionTrigger,
AccordionContent,
} from '@/components/ui/accordion'
const meta = {
title: 'Layout/Accordion',
component: Accordion,
tags: ['autodocs'],
parameters: { layout: 'centered' },
} satisfies Meta<typeof Accordion>
export default meta
type Story = StoryObj<typeof meta>
export const Single: Story = {
render: () => (
<Accordion type="single" collapsible className="w-100">
<AccordionItem value="item-1">
<AccordionTrigger>Is it accessible?</AccordionTrigger>
<AccordionContent>
Yes. It adheres to the WAI-ARIA design pattern.
</AccordionContent>
</AccordionItem>
<AccordionItem value="item-2">
<AccordionTrigger>Is it styled?</AccordionTrigger>
<AccordionContent>
Yes. It comes with default styles that match the other components.
</AccordionContent>
</AccordionItem>
<AccordionItem value="item-3">
<AccordionTrigger>Is it animated?</AccordionTrigger>
<AccordionContent>
Yes. It uses CSS animations for smooth open and close transitions.
</AccordionContent>
</AccordionItem>
</Accordion>
),
}
export const Multiple: Story = {
render: () => (
<Accordion type="multiple" className="w-100">
<AccordionItem value="item-1">
<AccordionTrigger>What is Greyhaven?</AccordionTrigger>
<AccordionContent>
Greyhaven is a design system built with Radix UI and Tailwind CSS.
</AccordionContent>
</AccordionItem>
<AccordionItem value="item-2">
<AccordionTrigger>How do I install it?</AccordionTrigger>
<AccordionContent>
You can install it via npm or pnpm. Check the documentation for details.
</AccordionContent>
</AccordionItem>
<AccordionItem value="item-3">
<AccordionTrigger>Can I customize themes?</AccordionTrigger>
<AccordionContent>
Absolutely. The design system uses CSS custom properties for full theme control.
</AccordionContent>
</AccordionItem>
</Accordion>
),
}
export const DefaultOpen: Story = {
render: () => (
<Accordion type="single" defaultValue="item-1" collapsible className="w-100">
<AccordionItem value="item-1">
<AccordionTrigger>Open by default</AccordionTrigger>
<AccordionContent>
This accordion item is open by default.
</AccordionContent>
</AccordionItem>
<AccordionItem value="item-2">
<AccordionTrigger>Click to open</AccordionTrigger>
<AccordionContent>
This accordion item starts closed.
</AccordionContent>
</AccordionItem>
</Accordion>
),
}

View File

@@ -0,0 +1,97 @@
import type { Meta, StoryObj } from '@storybook/react'
import {
Card,
CardHeader,
CardTitle,
CardDescription,
CardContent,
CardFooter,
CardAction,
} from '@/components/ui/card'
import { Button } from '@/components/ui/button'
const meta = {
title: 'Layout/Card',
component: Card,
tags: ['autodocs'],
parameters: { layout: 'centered' },
} satisfies Meta<typeof Card>
export default meta
type Story = StoryObj<typeof meta>
export const Default: Story = {
render: () => (
<Card className="w-87.5">
<CardHeader>
<CardTitle>Card Title</CardTitle>
<CardDescription>Card description goes here.</CardDescription>
</CardHeader>
<CardContent>
<p>Card content with some example text to demonstrate the layout.</p>
</CardContent>
<CardFooter>
<Button>Action</Button>
</CardFooter>
</Card>
),
}
export const WithAction: Story = {
render: () => (
<Card className="w-87.5">
<CardHeader>
<CardTitle>Notifications</CardTitle>
<CardDescription>You have 3 unread messages.</CardDescription>
<CardAction>
<Button variant="outline" size="sm">Mark all read</Button>
</CardAction>
</CardHeader>
<CardContent>
<p>Here are your latest notifications.</p>
</CardContent>
</Card>
),
}
export const Simple: Story = {
render: () => (
<Card className="w-87.5">
<CardHeader>
<CardTitle>Simple Card</CardTitle>
</CardHeader>
<CardContent>
<p>A card with just a title and content.</p>
</CardContent>
</Card>
),
}
export const WithFooter: Story = {
render: () => (
<Card className="w-87.5">
<CardHeader>
<CardTitle>Create project</CardTitle>
<CardDescription>Deploy your new project in one click.</CardDescription>
</CardHeader>
<CardContent>
<p>Configure your project settings below.</p>
</CardContent>
<CardFooter className="flex justify-between">
<Button variant="outline">Cancel</Button>
<Button>Deploy</Button>
</CardFooter>
</Card>
),
}
export const ContentOnly: Story = {
render: () => (
<Card className="w-87.5">
<CardContent>
<p>A minimal card with only content, no header or footer.</p>
</CardContent>
</Card>
),
}

View File

@@ -0,0 +1,59 @@
import type { Meta, StoryObj } from '@storybook/react'
import { Separator } from '@/components/ui/separator'
const meta = {
title: 'Layout/Separator',
component: Separator,
tags: ['autodocs'],
parameters: { layout: 'centered' },
argTypes: {
orientation: {
control: 'select',
options: ['horizontal', 'vertical'],
},
decorative: { control: 'boolean' },
},
} satisfies Meta<typeof Separator>
export default meta
type Story = StoryObj<typeof meta>
export const Horizontal: Story = {
args: {
orientation: 'horizontal',
},
decorators: [
(Story) => (
<div className="w-75">
<div className="space-y-1">
<h4 className="text-sm font-medium leading-none">Greyhaven Design System</h4>
<p className="text-sm text-muted-foreground">An open-source UI component library.</p>
</div>
<Story />
<div className="flex h-5 items-center space-x-4 text-sm">
<div>Blog</div>
<div>Docs</div>
<div>Source</div>
</div>
</div>
),
],
}
export const Vertical: Story = {
args: {
orientation: 'vertical',
},
decorators: [
(Story) => (
<div className="flex h-5 items-center space-x-4 text-sm">
<div>Blog</div>
<Story />
<div>Docs</div>
<Story />
<div>Source</div>
</div>
),
],
}