feat(components): add InlineWrapper and related styles for improved form handling

This commit is contained in:
2026-01-17 17:29:08 +02:00
parent bc7262cede
commit 31f2a0428f
4 changed files with 264 additions and 0 deletions

View File

@@ -0,0 +1,50 @@
//@ts-nocheck
import type { Meta, StoryObj } from '@storybook/react-vite';
import { Stack } from '@mantine/core';
import { fn } from 'storybook/test';
import { Former, NativeSelectCtrl, TextInputCtrl } from '../../lib';
import { InlineWrapper } from '../Inputs/InlineWrapper';
import NumberInputCtrl from '../Inputs/NumberInputCtrl';
const Renderable = () => {
return (
<Former>
<Stack h="100%" mih="400px" miw="400px" w="100%">
<TextInputCtrl label="Test" name="test" />
<NumberInputCtrl label="AgeTest" name="age" />
<InlineWrapper label="Select One" promptWidth={200}>
<NativeSelectCtrl data={["One","Two","Three"]} name="option1"/>
</InlineWrapper>
</Stack>
</Former>
);
};
const meta = {
// Use `fn` to spy on the onClick arg, which will appear in the actions panel once invoked: https://storybook.js.org/docs/essentials/actions#action-args
args: { onClick: fn() },
// More on argTypes: https://storybook.js.org/docs/api/argtypes
argTypes: {
backgroundColor: { control: 'color' },
},
component: Renderable,
parameters: {
// Optional parameter to center the component in the Canvas. More info: https://storybook.js.org/docs/configure/story-layout
//layout: 'centered',
},
// This component will have an automatically generated Autodocs entry: https://storybook.js.org/docs/writing-docs/autodocs
tags: ['autodocs'],
title: 'Former/Controls Basic',
} satisfies Meta<typeof Renderable>;
export default meta;
type Story = StoryObj<typeof meta>;
// More on writing stories with args: https://storybook.js.org/docs/writing-stories/args
export const BasicExample: Story = {
args: {
label: 'Test',
},
};