75ee53d1dd
Stand up Storybook so the management console can be designed without a running host, plus the design-system work that surfaced along the way. Storybook (@storybook/react-vite): - Slim Start/Nitro-free vite config; the preview imports the app's real src/styles.css directly so the design tokens stay single-sourced (no mirror). - Stories for the @unom/ui primitives (Button/Card/Inputs/Badge), brand marks, the AppShell (throwaway in-memory TanStack router), and every data-driven page (Dashboard/Host/Clients/Library/Settings) rendered offline via a window.fetch stub + typed fixtures. The route page components are exported so stories can render them. Light theme: - styles.css now carries a light :root (lavender, from the docs palette) with the existing violet chrome moved to .dark; the live console still pins html.dark by default, so this only adds the option (Storybook's toolbar toggles it). - Fixes a stray `*/` inside a comment that prematurely closed it and silently broke Tailwind's @theme processing. Spinner: - The punktfunk lens recreated with motion/react: two circles surge through one another in depth (JS perspective scale + z-index — robust where mix-blend-mode flattens CSS preserve-3d) with a screen-blend lens highlight. Replaces the skeleton loading state in QueryState; removes ui/skeleton.tsx. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
49 lines
1.3 KiB
TypeScript
49 lines
1.3 KiB
TypeScript
import type { Meta, StoryObj } from '@storybook/react-vite'
|
|
import { Play } from 'lucide-react'
|
|
import { Button } from '@/components/ui/button'
|
|
|
|
const VARIANTS = ['default', 'secondary', 'outline', 'ghost', 'link', 'destructive'] as const
|
|
const SIZES = ['default', 'sm', 'lg', 'icon'] as const
|
|
|
|
const meta = {
|
|
title: 'UI/Button',
|
|
component: Button,
|
|
args: { children: 'Stream' },
|
|
argTypes: {
|
|
variant: { control: 'select', options: VARIANTS },
|
|
size: { control: 'select', options: SIZES },
|
|
disabled: { control: 'boolean' },
|
|
},
|
|
} satisfies Meta<typeof Button>
|
|
|
|
export default meta
|
|
type Story = StoryObj<typeof meta>
|
|
|
|
/** Playground — drive variant/size/disabled from the Controls panel. */
|
|
export const Playground: Story = {}
|
|
|
|
export const Variants: Story = {
|
|
render: () => (
|
|
<div className="flex flex-wrap items-center gap-3">
|
|
{VARIANTS.map((variant) => (
|
|
<Button key={variant} variant={variant}>
|
|
{variant}
|
|
</Button>
|
|
))}
|
|
</div>
|
|
),
|
|
}
|
|
|
|
export const Sizes: Story = {
|
|
render: () => (
|
|
<div className="flex flex-wrap items-center gap-3">
|
|
<Button size="sm">Small</Button>
|
|
<Button size="default">Default</Button>
|
|
<Button size="lg">Large</Button>
|
|
<Button size="icon" aria-label="Play">
|
|
<Play className="size-4" />
|
|
</Button>
|
|
</div>
|
|
),
|
|
}
|