import type { Meta, StoryObj } from "@storybook/react"; import { Dropdown, DropdownOption } from "../src/components/Dropdown/Dropdown"; import { PdfIcon } from "../src/components/WebFileIcon/PdfIcon"; import { ImageIcon } from "../src/components/WebFileIcon/ImageIcon"; import { ChangeEvent, useState } from "react"; import { fn } from "@storybook/test"; const meta = { title: "Forms/Dropdown", component: Dropdown, parameters: { layout: "centered", }, tags: ["autodocs"], argTypes: {}, args: { onChange: fn(), onSelected: fn(), onFocus: fn(), onBlur: fn(), onMouseEnter: fn(), onMouseLeave: fn(), }, } satisfies Meta; export default meta; type Story = StoryObj; type Props = { onChange: (e: ChangeEvent) => void; onSelected?: (o: DropdownOption) => void; onClick?: () => void; onMouseEnter?: () => void; onBlur?: () => void; }; const Template = (p: Props) => { const [value, setValue] = useState(""); const onChange = (e: ChangeEvent) => { p.onChange(e); setValue(e.currentTarget.value); }; const onSelected = (o: DropdownOption) => { setValue(o.title); p.onSelected?.(o); }; return ( ); }; export const Default = Template; export const CustomStyle: Story = { args: { placeholder: "Select your file", options: [], style: { "--codex-input-border": "1px solid red" }, value: "", }, };