import type { Meta, StoryObj } from '@storybook/react-webpack5'; import { RAGFlowAvatar } from '@/components/ragflow-avatar'; // More on how to set up stories at: https://storybook.js.org/docs/writing-stories#default-export const meta = { title: 'Example/RAGFlowAvatar', component: RAGFlowAvatar, parameters: { // Optional parameter to center the component in the Canvas. More info: https://storybook.js.org/docs/configure/story-layout layout: 'centered', docs: { description: { component: ` ## RAGFlowAvatar Component RAGFlowAvatar is a customizable avatar component that displays user avatars with intelligent fallbacks. When an image is not available, it generates colorful gradient backgrounds with user initials. ### Import Path \`\`\`typescript import { RAGFlowAvatar } from '@/components/ragflow-avatar'; \`\`\` ### Basic Usage \`\`\`tsx import { RAGFlowAvatar } from '@/components/ragflow-avatar'; function MyComponent() { return ( ); } \`\`\` ### Features - Displays user avatar images when available - Generates colorful gradient fallbacks with initials - Supports both person (circular) and non-person (rounded) styles - Automatic font size calculation based on container size - Color generation based on name for consistent appearance - Responsive design with resize observer `, }, }, }, // This component will have an automatically generated Autodocs entry: https://storybook.js.org/docs/writing-docs/autodocs tags: ['autodocs'], // More on argTypes: https://storybook.js.org/docs/api/argtypes argTypes: { name: { description: 'The name to display initials for when no avatar is available', control: { type: 'text' }, type: { name: 'string', required: false }, }, avatar: { description: 'The URL of the avatar image', control: { type: 'text' }, type: { name: 'string', required: false }, }, isPerson: { description: 'Whether this avatar represents a person (affects styling)', control: { type: 'boolean' }, type: { name: 'boolean', required: false }, defaultValue: false, }, className: { description: 'Additional CSS classes to apply', control: { type: 'text' }, type: { name: 'string', required: false }, }, }, args: { name: 'John Doe', isPerson: false, }, } satisfies Meta; export default meta; type Story = StoryObj; // More on writing stories with args: https://storybook.js.org/docs/writing-stories/args export const WithInitials: Story = { args: { name: 'John Doe', isPerson: false, }, parameters: { docs: { description: { story: ` ### With Initials Only Shows the avatar component with only a name, displaying generated initials with a gradient background. \`\`\`tsx \`\`\` `, }, }, }, tags: ['!dev'], }; export const WithAvatar: Story = { args: { name: 'Jane Smith', avatar: '', isPerson: true, }, parameters: { docs: { description: { story: ` ### With Avatar Image Shows the avatar component with an actual image. When isPerson is true, the avatar will be circular. \`\`\`tsx \`\`\` `, }, }, }, tags: ['!dev'], }; export const PersonStyle: Story = { args: { name: 'Alice Johnson', isPerson: true, }, parameters: { docs: { description: { story: ` ### Person Style (Circular) Shows the avatar component with isPerson set to true, which makes it circular. \`\`\`tsx \`\`\` `, }, }, }, tags: ['!dev'], }; export const NonPersonStyle: Story = { args: { name: 'Bot Assistant', isPerson: false, }, parameters: { docs: { description: { story: ` ### Non-Person Style (Rounded Rectangle) Shows the avatar component with isPerson set to false, which makes it a rounded rectangle. \`\`\`tsx \`\`\` `, }, }, }, tags: ['!dev'], };