Files
community-rule/stories/Input.stories.js
T
2025-10-10 09:07:47 -06:00

270 lines
5.8 KiB
JavaScript

import React from "react";
import Input from "../app/components/Input";
export default {
title: "Forms/Input",
component: Input,
parameters: {
layout: "centered",
},
argTypes: {
size: {
control: { type: "select" },
options: ["small", "medium", "large"],
},
labelVariant: {
control: { type: "select" },
options: ["default", "horizontal"],
},
state: {
control: { type: "select" },
options: ["default", "active", "hover", "focus", "error", "disabled"],
},
disabled: {
control: { type: "boolean" },
},
error: {
control: { type: "boolean" },
},
label: {
control: { type: "text" },
},
placeholder: {
control: { type: "text" },
},
value: {
control: { type: "text" },
},
},
};
const Template = (args) => <Input {...args} />;
// Default story
export const Default = Template.bind({});
Default.args = {
label: "Default Input",
placeholder: "Enter text...",
size: "medium",
labelVariant: "default",
state: "default",
};
// Size variants
export const Small = Template.bind({});
Small.args = {
label: "Small Input",
placeholder: "Small size",
size: "small",
labelVariant: "default",
state: "default",
};
export const Medium = Template.bind({});
Medium.args = {
label: "Medium Input",
placeholder: "Medium size",
size: "medium",
labelVariant: "default",
state: "default",
};
export const Large = Template.bind({});
Large.args = {
label: "Large Input",
placeholder: "Large size",
size: "large",
labelVariant: "default",
state: "default",
};
// Label variants
export const DefaultLabel = Template.bind({});
DefaultLabel.args = {
label: "Default Label (Top)",
placeholder: "Top label",
size: "medium",
labelVariant: "default",
state: "default",
};
export const HorizontalLabel = Template.bind({});
HorizontalLabel.args = {
label: "Horizontal Label",
placeholder: "Left label",
size: "medium",
labelVariant: "horizontal",
state: "default",
};
// States
export const Active = Template.bind({});
Active.args = {
label: "Active State",
placeholder: "Active input",
size: "medium",
labelVariant: "default",
state: "active",
};
export const Hover = Template.bind({});
Hover.args = {
label: "Hover State",
placeholder: "Hover input",
size: "medium",
labelVariant: "default",
state: "hover",
};
export const Focus = Template.bind({});
Focus.args = {
label: "Focus State",
placeholder: "Focused input",
size: "medium",
labelVariant: "default",
state: "focus",
};
export const Error = Template.bind({});
Error.args = {
label: "Error State",
placeholder: "Error input",
size: "medium",
labelVariant: "default",
state: "default",
error: true,
};
export const Disabled = Template.bind({});
Disabled.args = {
label: "Disabled State",
placeholder: "Disabled input",
size: "medium",
labelVariant: "default",
state: "default",
disabled: true,
};
// Interactive example
export const Interactive = (args) => {
const [value, setValue] = React.useState("");
return (
<div className="space-y-4">
<Input
{...args}
value={value}
onChange={(e) => setValue(e.target.value)}
/>
<p className="text-sm text-gray-600">Current value: "{value}"</p>
</div>
);
};
Interactive.args = {
label: "Interactive Input",
placeholder: "Type something...",
size: "medium",
labelVariant: "default",
state: "default",
};
// All sizes comparison
export const AllSizes = () => (
<div className="space-y-6">
<div>
<h3 className="text-lg font-semibold mb-4">Small Size</h3>
<div className="space-y-4">
<Input
label="Small Default"
placeholder="Small with top label"
size="small"
labelVariant="default"
/>
</div>
</div>
<div>
<h3 className="text-lg font-semibold mb-4">Medium Size</h3>
<div className="space-y-4">
<Input
label="Medium Default"
placeholder="Medium with top label"
size="medium"
labelVariant="default"
/>
<Input
label="Medium Horizontal"
placeholder="Medium with left label"
size="medium"
labelVariant="horizontal"
/>
</div>
</div>
<div>
<h3 className="text-lg font-semibold mb-4">Large Size</h3>
<div className="space-y-4">
<Input
label="Large Default"
placeholder="Large with top label"
size="large"
labelVariant="default"
/>
<Input
label="Large Horizontal"
placeholder="Large with left label"
size="large"
labelVariant="horizontal"
/>
</div>
</div>
</div>
);
// All states comparison
export const AllStates = () => (
<div className="space-y-6">
<div>
<h3 className="text-lg font-semibold mb-4">Input States</h3>
<div className="space-y-4">
<Input
label="Default State"
placeholder="Default input"
size="medium"
state="default"
/>
<Input
label="Active State"
placeholder="Active input"
size="medium"
state="active"
/>
<Input
label="Hover State"
placeholder="Hover input"
size="medium"
state="hover"
/>
<Input
label="Focus State"
placeholder="Focused input"
size="medium"
state="focus"
/>
<Input
label="Error State"
placeholder="Error input"
size="medium"
error={true}
/>
<Input
label="Disabled State"
placeholder="Disabled input"
size="medium"
disabled={true}
/>
</div>
</div>
</div>
);