Files
tf_code/packages/ui/src/components/provider-icon.stories.tsx
Adam 05d77b7d47 chore: storybook (#15285)
Co-authored-by: David Hill <iamdavidhill@gmail.com>
2026-02-26 16:05:04 -06:00

70 lines
1.6 KiB
TypeScript

// @ts-nocheck
import { iconNames } from "./provider-icons/types"
import * as mod from "./provider-icon"
import { create } from "../storybook/scaffold"
const docs = `### Overview
Provider icon sprite renderer for model/provider badges.
Use in model pickers or provider lists.
### API
- Required: \`id\` (provider icon name).
- Accepts standard SVG props.
### Variants and states
- Single visual style; size via CSS.
### Behavior
- Renders from the provider SVG sprite sheet.
### Accessibility
- Provide accessible text nearby when the icon conveys meaning.
### Theming/tokens
- Uses \`data-component="provider-icon"\`.
`
const story = create({ title: "UI/ProviderIcon", mod, args: { id: "openai" } })
export default {
title: "UI/ProviderIcon",
id: "components-provider-icon",
component: story.meta.component,
tags: ["autodocs"],
parameters: {
docs: {
description: {
component: docs,
},
},
},
argTypes: {
id: {
control: "select",
options: iconNames,
},
},
}
export const Basic = story.Basic
export const AllIcons = {
render: () => (
<div
style={{
display: "grid",
gap: "12px",
"grid-template-columns": "repeat(auto-fill, minmax(80px, 1fr))",
}}
>
{iconNames.map((id) => (
<div style={{ display: "grid", gap: "6px", "justify-items": "center" }}>
<mod.ProviderIcon id={id} width="28" height="28" aria-label={id} />
<div style={{ "font-size": "10px", color: "var(--text-weak)", "text-align": "center" }}>{id}</div>
</div>
))}
</div>
),
}