@windstream/react-shared-components 0.0.39 → 0.0.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/contentful/index.d.ts +2 -0
- package/dist/contentful/index.esm.js +1 -1
- package/dist/contentful/index.esm.js.map +1 -1
- package/dist/contentful/index.js +1 -1
- package/dist/contentful/index.js.map +1 -1
- package/dist/core.d.ts +2 -2
- package/dist/index.d.ts +2 -2
- package/dist/index.js.map +1 -1
- package/dist/styles.css +1 -1
- package/package.json +1 -1
- package/src/components/accordion/Accordion.stories.tsx +230 -230
- package/src/components/accordion/index.tsx +49 -49
- package/src/components/accordion/types.ts +9 -9
- package/src/components/alert-card/AlertCard.stories.tsx +171 -171
- package/src/components/alert-card/index.tsx +32 -32
- package/src/components/alert-card/types.ts +9 -9
- package/src/components/brand-button/BrandButton.stories.tsx +219 -219
- package/src/components/brand-button/helpers.ts +35 -35
- package/src/components/brand-button/index.tsx +93 -93
- package/src/components/brand-button/types.ts +25 -25
- package/src/components/button/Button.stories.tsx +108 -108
- package/src/components/button/index.tsx +27 -27
- package/src/components/button/types.ts +14 -14
- package/src/components/call-button/CallButton.stories.tsx +324 -324
- package/src/components/call-button/index.tsx +79 -79
- package/src/components/call-button/types.ts +10 -10
- package/src/components/checkbox/Checkbox.stories.tsx +247 -247
- package/src/components/checkbox/index.tsx +197 -197
- package/src/components/checkbox/types.ts +27 -27
- package/src/components/checklist/Checklist.stories.tsx +150 -150
- package/src/components/checklist/index.tsx +39 -39
- package/src/components/checklist/types.ts +6 -6
- package/src/components/collapse/Collapse.stories.tsx +255 -255
- package/src/components/collapse/index.tsx +46 -46
- package/src/components/collapse/types.ts +6 -6
- package/src/components/divider/Divider.stories.tsx +205 -205
- package/src/components/divider/index.tsx +22 -22
- package/src/components/divider/type.ts +3 -3
- package/src/components/image/Image.stories.tsx +113 -113
- package/src/components/image/index.tsx +25 -25
- package/src/components/image/types.ts +40 -40
- package/src/components/input/Input.stories.tsx +325 -325
- package/src/components/input/index.tsx +177 -177
- package/src/components/input/types.ts +37 -37
- package/src/components/link/Link.stories.tsx +163 -163
- package/src/components/link/index.tsx +97 -97
- package/src/components/link/types.ts +25 -25
- package/src/components/list/List.stories.tsx +272 -272
- package/src/components/list/index.tsx +88 -88
- package/src/components/list/list-item/index.tsx +38 -38
- package/src/components/list/list-item/types.ts +13 -13
- package/src/components/list/types.ts +29 -29
- package/src/components/material-icon/MaterialIcon.stories.tsx +330 -330
- package/src/components/material-icon/constants.ts +95 -95
- package/src/components/material-icon/index.tsx +44 -44
- package/src/components/material-icon/types.ts +31 -31
- package/src/components/modal/Modal.stories.tsx +171 -171
- package/src/components/modal/index.tsx +164 -164
- package/src/components/modal/types.ts +24 -24
- package/src/components/next-image/index.tsx +18 -18
- package/src/components/next-image/types.ts +1 -1
- package/src/components/radio-button/RadioButton.stories.tsx +307 -307
- package/src/components/radio-button/index.tsx +75 -75
- package/src/components/radio-button/types.ts +21 -21
- package/src/components/see-more/SeeMore.stories.tsx +181 -181
- package/src/components/see-more/index.tsx +44 -44
- package/src/components/see-more/types.ts +4 -4
- package/src/components/select/Select.stories.tsx +411 -411
- package/src/components/select/index.tsx +150 -150
- package/src/components/select/types.ts +35 -35
- package/src/components/select-plan-button/SelectPlanButton.stories.tsx +168 -168
- package/src/components/select-plan-button/index.tsx +29 -29
- package/src/components/select-plan-button/types.ts +4 -4
- package/src/components/skeleton/Skeleton.stories.tsx +179 -179
- package/src/components/skeleton/index.tsx +61 -61
- package/src/components/skeleton/types.ts +4 -4
- package/src/components/spinner/Spinner.stories.tsx +335 -335
- package/src/components/spinner/index.tsx +44 -44
- package/src/components/spinner/types.ts +5 -5
- package/src/components/text/Text.stories.tsx +321 -321
- package/src/components/text/index.tsx +25 -25
- package/src/components/text/types.ts +45 -45
- package/src/components/tooltip/Tooltip.stories.tsx +219 -219
- package/src/components/tooltip/index.tsx +74 -74
- package/src/components/tooltip/types.ts +7 -7
- package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
- package/src/components/view-cart-button/index.tsx +44 -44
- package/src/components/view-cart-button/types.ts +5 -5
- package/src/contentful/blocks/button/Button.stories.tsx +40 -40
- package/src/contentful/blocks/button/index.tsx +64 -64
- package/src/contentful/blocks/button/types.ts +24 -24
- package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
- package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
- package/src/contentful/blocks/cards/index.tsx +13 -13
- package/src/contentful/blocks/cards/types.ts +1 -1
- package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
- package/src/contentful/blocks/carousel/index.tsx +13 -13
- package/src/contentful/blocks/carousel/types.ts +1 -1
- package/src/contentful/blocks/comparison-table/index.tsx +6 -0
- package/src/contentful/blocks/comparison-table/types.ts +1 -0
- package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
- package/src/contentful/blocks/cta-callout/index.tsx +54 -54
- package/src/contentful/blocks/cta-callout/types.ts +22 -22
- package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
- package/src/contentful/blocks/floating-banner/index.tsx +102 -102
- package/src/contentful/blocks/floating-banner/types.ts +22 -22
- package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
- package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
- package/src/contentful/blocks/image-promo-bar/index.tsx +10 -31
- package/src/contentful/blocks/image-promo-bar/types.ts +27 -25
- package/src/contentful/blocks/modal/Modal.stories.tsx +23 -23
- package/src/contentful/blocks/modal/index.tsx +12 -12
- package/src/contentful/blocks/modal/types.ts +1 -1
- package/src/contentful/blocks/navigation/Navigation.stories.tsx +23 -23
- package/src/contentful/blocks/navigation/index.tsx +56 -56
- package/src/contentful/blocks/navigation/types.ts +21 -21
- package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
- package/src/contentful/blocks/primary-hero/index.tsx +160 -160
- package/src/contentful/blocks/primary-hero/types.ts +30 -30
- package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
- package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
- package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
- package/src/contentful/blocks/text/Text.stories.tsx +23 -23
- package/src/contentful/blocks/text/index.tsx +12 -12
- package/src/contentful/blocks/text/types.ts +1 -1
- package/src/hooks/use-body-scroll-lock.ts +34 -34
- package/src/index.ts +96 -96
- package/src/next/index.ts +5 -5
- package/src/setupTests.ts +46 -46
- package/src/stories/DocsTemplate.tsx +24 -24
- package/src/styles/globals.css +275 -275
- package/src/types/global.d.ts +9 -9
- package/src/utils/index.ts +49 -49
|
@@ -1,307 +1,307 @@
|
|
|
1
|
-
import { useState } from "react";
|
|
2
|
-
import { RadioButton } from "./index";
|
|
3
|
-
|
|
4
|
-
import { DocsPage } from "@shared/stories/DocsTemplate";
|
|
5
|
-
import type { Meta, StoryObj } from "@storybook/react";
|
|
6
|
-
|
|
7
|
-
const meta: Meta<typeof RadioButton> = {
|
|
8
|
-
title: "Components/RadioButton",
|
|
9
|
-
component: RadioButton,
|
|
10
|
-
tags: ["autodocs"],
|
|
11
|
-
parameters: {
|
|
12
|
-
layout: "centered",
|
|
13
|
-
docs: {
|
|
14
|
-
page: DocsPage,
|
|
15
|
-
description: {
|
|
16
|
-
component:
|
|
17
|
-
"A radio button component with support for labels, subtext, error states, and custom variants.",
|
|
18
|
-
},
|
|
19
|
-
},
|
|
20
|
-
},
|
|
21
|
-
argTypes: {
|
|
22
|
-
name: {
|
|
23
|
-
control: { type: "text" },
|
|
24
|
-
description: "Radio button group name",
|
|
25
|
-
},
|
|
26
|
-
value: {
|
|
27
|
-
control: { type: "text" },
|
|
28
|
-
description: "Radio button value",
|
|
29
|
-
},
|
|
30
|
-
checked: {
|
|
31
|
-
control: { type: "boolean" },
|
|
32
|
-
description: "Whether the radio button is checked",
|
|
33
|
-
},
|
|
34
|
-
label: {
|
|
35
|
-
control: { type: "text" },
|
|
36
|
-
description: "Label text",
|
|
37
|
-
},
|
|
38
|
-
subText: {
|
|
39
|
-
control: { type: "text" },
|
|
40
|
-
description: "Subtext displayed below the label",
|
|
41
|
-
},
|
|
42
|
-
variant: {
|
|
43
|
-
control: { type: "select" },
|
|
44
|
-
options: ["circle"],
|
|
45
|
-
description: "Radio button variant",
|
|
46
|
-
},
|
|
47
|
-
hasError: {
|
|
48
|
-
control: { type: "boolean" },
|
|
49
|
-
description: "Show error state",
|
|
50
|
-
},
|
|
51
|
-
disabled: {
|
|
52
|
-
control: { type: "boolean" },
|
|
53
|
-
description: "Disable the radio button",
|
|
54
|
-
},
|
|
55
|
-
},
|
|
56
|
-
args: {
|
|
57
|
-
name: "radio-group",
|
|
58
|
-
value: "option1",
|
|
59
|
-
checked: false,
|
|
60
|
-
label: "Radio Button Label",
|
|
61
|
-
},
|
|
62
|
-
};
|
|
63
|
-
|
|
64
|
-
export default meta;
|
|
65
|
-
type Story = StoryObj<typeof meta>;
|
|
66
|
-
|
|
67
|
-
// Default radio button
|
|
68
|
-
export const Default: Story = {
|
|
69
|
-
args: {},
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
// Checked radio button
|
|
73
|
-
export const Checked: Story = {
|
|
74
|
-
args: {
|
|
75
|
-
checked: true,
|
|
76
|
-
label: "Checked Radio Button",
|
|
77
|
-
},
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
// Unchecked radio button
|
|
81
|
-
export const Unchecked: Story = {
|
|
82
|
-
args: {
|
|
83
|
-
checked: false,
|
|
84
|
-
label: "Unchecked Radio Button",
|
|
85
|
-
},
|
|
86
|
-
};
|
|
87
|
-
|
|
88
|
-
// With label
|
|
89
|
-
export const WithLabel: Story = {
|
|
90
|
-
args: {
|
|
91
|
-
label: "Option with Label",
|
|
92
|
-
},
|
|
93
|
-
};
|
|
94
|
-
|
|
95
|
-
// With subtext
|
|
96
|
-
export const WithSubtext: Story = {
|
|
97
|
-
args: {
|
|
98
|
-
label: "Premium Plan",
|
|
99
|
-
subText: "$29.99/month - Best value",
|
|
100
|
-
},
|
|
101
|
-
};
|
|
102
|
-
|
|
103
|
-
// Error state
|
|
104
|
-
export const Error: Story = {
|
|
105
|
-
args: {
|
|
106
|
-
label: "Radio Button with Error",
|
|
107
|
-
hasError: true,
|
|
108
|
-
},
|
|
109
|
-
};
|
|
110
|
-
|
|
111
|
-
// Disabled state
|
|
112
|
-
export const Disabled: Story = {
|
|
113
|
-
args: {
|
|
114
|
-
label: "Disabled Radio Button",
|
|
115
|
-
disabled: true,
|
|
116
|
-
},
|
|
117
|
-
};
|
|
118
|
-
|
|
119
|
-
// Disabled checked
|
|
120
|
-
export const DisabledChecked: Story = {
|
|
121
|
-
args: {
|
|
122
|
-
checked: true,
|
|
123
|
-
label: "Disabled Checked Radio Button",
|
|
124
|
-
disabled: true,
|
|
125
|
-
},
|
|
126
|
-
};
|
|
127
|
-
|
|
128
|
-
// Radio group
|
|
129
|
-
export const RadioGroup: Story = {
|
|
130
|
-
render: () => {
|
|
131
|
-
const [selected, setSelected] = useState("option1");
|
|
132
|
-
return (
|
|
133
|
-
<div className="space-y-3">
|
|
134
|
-
<RadioButton
|
|
135
|
-
name="plan"
|
|
136
|
-
value="option1"
|
|
137
|
-
checked={selected === "option1"}
|
|
138
|
-
onChange={() => setSelected("option1")}
|
|
139
|
-
label="Basic Plan"
|
|
140
|
-
subText="$9.99/month"
|
|
141
|
-
/>
|
|
142
|
-
<RadioButton
|
|
143
|
-
name="plan"
|
|
144
|
-
value="option2"
|
|
145
|
-
checked={selected === "option2"}
|
|
146
|
-
onChange={() => setSelected("option2")}
|
|
147
|
-
label="Standard Plan"
|
|
148
|
-
subText="$19.99/month"
|
|
149
|
-
/>
|
|
150
|
-
<RadioButton
|
|
151
|
-
name="plan"
|
|
152
|
-
value="option3"
|
|
153
|
-
checked={selected === "option3"}
|
|
154
|
-
onChange={() => setSelected("option3")}
|
|
155
|
-
label="Premium Plan"
|
|
156
|
-
subText="$29.99/month"
|
|
157
|
-
/>
|
|
158
|
-
</div>
|
|
159
|
-
);
|
|
160
|
-
},
|
|
161
|
-
parameters: {
|
|
162
|
-
docs: {
|
|
163
|
-
description: {
|
|
164
|
-
story: "Radio button group where only one option can be selected.",
|
|
165
|
-
},
|
|
166
|
-
},
|
|
167
|
-
},
|
|
168
|
-
};
|
|
169
|
-
|
|
170
|
-
// With error in group
|
|
171
|
-
export const GroupWithError: Story = {
|
|
172
|
-
render: () => {
|
|
173
|
-
const [selected, setSelected] = useState<string | undefined>();
|
|
174
|
-
return (
|
|
175
|
-
<div className="space-y-3">
|
|
176
|
-
<RadioButton
|
|
177
|
-
name="payment"
|
|
178
|
-
value="credit"
|
|
179
|
-
checked={selected === "credit"}
|
|
180
|
-
onChange={val =>
|
|
181
|
-
setSelected(
|
|
182
|
-
typeof val === "string" || typeof val === "number"
|
|
183
|
-
? String(val)
|
|
184
|
-
: undefined
|
|
185
|
-
)
|
|
186
|
-
}
|
|
187
|
-
label="Credit Card"
|
|
188
|
-
hasError={!selected}
|
|
189
|
-
/>
|
|
190
|
-
<RadioButton
|
|
191
|
-
name="payment"
|
|
192
|
-
value="debit"
|
|
193
|
-
checked={selected === "debit"}
|
|
194
|
-
onChange={val =>
|
|
195
|
-
setSelected(
|
|
196
|
-
typeof val === "string" || typeof val === "number"
|
|
197
|
-
? String(val)
|
|
198
|
-
: undefined
|
|
199
|
-
)
|
|
200
|
-
}
|
|
201
|
-
label="Debit Card"
|
|
202
|
-
hasError={!selected}
|
|
203
|
-
/>
|
|
204
|
-
<RadioButton
|
|
205
|
-
name="payment"
|
|
206
|
-
value="paypal"
|
|
207
|
-
checked={selected === "paypal"}
|
|
208
|
-
onChange={val =>
|
|
209
|
-
setSelected(
|
|
210
|
-
typeof val === "string" || typeof val === "number"
|
|
211
|
-
? String(val)
|
|
212
|
-
: undefined
|
|
213
|
-
)
|
|
214
|
-
}
|
|
215
|
-
label="PayPal"
|
|
216
|
-
hasError={!selected}
|
|
217
|
-
/>
|
|
218
|
-
{!selected && (
|
|
219
|
-
<p className="text-sm text-red-600">Please select a payment method</p>
|
|
220
|
-
)}
|
|
221
|
-
</div>
|
|
222
|
-
);
|
|
223
|
-
},
|
|
224
|
-
parameters: {
|
|
225
|
-
docs: {
|
|
226
|
-
description: {
|
|
227
|
-
story:
|
|
228
|
-
"Radio button group with error state when no option is selected.",
|
|
229
|
-
},
|
|
230
|
-
},
|
|
231
|
-
},
|
|
232
|
-
};
|
|
233
|
-
|
|
234
|
-
// All variants showcase
|
|
235
|
-
export const AllVariants: Story = {
|
|
236
|
-
render: () => (
|
|
237
|
-
<div className="space-y-6">
|
|
238
|
-
<div>
|
|
239
|
-
<h3 className="mb-3 text-lg font-semibold">States</h3>
|
|
240
|
-
<div className="space-y-3">
|
|
241
|
-
<RadioButton
|
|
242
|
-
name="demo1"
|
|
243
|
-
value="unchecked"
|
|
244
|
-
checked={false}
|
|
245
|
-
label="Unchecked"
|
|
246
|
-
/>
|
|
247
|
-
<RadioButton
|
|
248
|
-
name="demo2"
|
|
249
|
-
value="checked"
|
|
250
|
-
checked={true}
|
|
251
|
-
label="Checked"
|
|
252
|
-
/>
|
|
253
|
-
<RadioButton
|
|
254
|
-
name="demo3"
|
|
255
|
-
value="disabled"
|
|
256
|
-
checked={false}
|
|
257
|
-
label="Disabled"
|
|
258
|
-
disabled
|
|
259
|
-
/>
|
|
260
|
-
<RadioButton
|
|
261
|
-
name="demo4"
|
|
262
|
-
value="disabled-checked"
|
|
263
|
-
checked={true}
|
|
264
|
-
label="Disabled Checked"
|
|
265
|
-
disabled
|
|
266
|
-
/>
|
|
267
|
-
</div>
|
|
268
|
-
</div>
|
|
269
|
-
<div>
|
|
270
|
-
<h3 className="mb-3 text-lg font-semibold">With Subtext</h3>
|
|
271
|
-
<div className="space-y-3">
|
|
272
|
-
<RadioButton
|
|
273
|
-
name="demo5"
|
|
274
|
-
value="plan1"
|
|
275
|
-
checked={true}
|
|
276
|
-
label="Basic Plan"
|
|
277
|
-
subText="$9.99/month"
|
|
278
|
-
/>
|
|
279
|
-
<RadioButton
|
|
280
|
-
name="demo6"
|
|
281
|
-
value="plan2"
|
|
282
|
-
checked={false}
|
|
283
|
-
label="Premium Plan"
|
|
284
|
-
subText="$29.99/month - Best value"
|
|
285
|
-
/>
|
|
286
|
-
</div>
|
|
287
|
-
</div>
|
|
288
|
-
<div>
|
|
289
|
-
<h3 className="mb-3 text-lg font-semibold">Error State</h3>
|
|
290
|
-
<RadioButton
|
|
291
|
-
name="demo7"
|
|
292
|
-
value="error"
|
|
293
|
-
checked={false}
|
|
294
|
-
label="Radio Button with Error"
|
|
295
|
-
hasError
|
|
296
|
-
/>
|
|
297
|
-
</div>
|
|
298
|
-
</div>
|
|
299
|
-
),
|
|
300
|
-
parameters: {
|
|
301
|
-
docs: {
|
|
302
|
-
description: {
|
|
303
|
-
story: "Showcase of all radio button variants and states.",
|
|
304
|
-
},
|
|
305
|
-
},
|
|
306
|
-
},
|
|
307
|
-
};
|
|
1
|
+
import { useState } from "react";
|
|
2
|
+
import { RadioButton } from "./index";
|
|
3
|
+
|
|
4
|
+
import { DocsPage } from "@shared/stories/DocsTemplate";
|
|
5
|
+
import type { Meta, StoryObj } from "@storybook/react";
|
|
6
|
+
|
|
7
|
+
const meta: Meta<typeof RadioButton> = {
|
|
8
|
+
title: "Components/RadioButton",
|
|
9
|
+
component: RadioButton,
|
|
10
|
+
tags: ["autodocs"],
|
|
11
|
+
parameters: {
|
|
12
|
+
layout: "centered",
|
|
13
|
+
docs: {
|
|
14
|
+
page: DocsPage,
|
|
15
|
+
description: {
|
|
16
|
+
component:
|
|
17
|
+
"A radio button component with support for labels, subtext, error states, and custom variants.",
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
argTypes: {
|
|
22
|
+
name: {
|
|
23
|
+
control: { type: "text" },
|
|
24
|
+
description: "Radio button group name",
|
|
25
|
+
},
|
|
26
|
+
value: {
|
|
27
|
+
control: { type: "text" },
|
|
28
|
+
description: "Radio button value",
|
|
29
|
+
},
|
|
30
|
+
checked: {
|
|
31
|
+
control: { type: "boolean" },
|
|
32
|
+
description: "Whether the radio button is checked",
|
|
33
|
+
},
|
|
34
|
+
label: {
|
|
35
|
+
control: { type: "text" },
|
|
36
|
+
description: "Label text",
|
|
37
|
+
},
|
|
38
|
+
subText: {
|
|
39
|
+
control: { type: "text" },
|
|
40
|
+
description: "Subtext displayed below the label",
|
|
41
|
+
},
|
|
42
|
+
variant: {
|
|
43
|
+
control: { type: "select" },
|
|
44
|
+
options: ["circle"],
|
|
45
|
+
description: "Radio button variant",
|
|
46
|
+
},
|
|
47
|
+
hasError: {
|
|
48
|
+
control: { type: "boolean" },
|
|
49
|
+
description: "Show error state",
|
|
50
|
+
},
|
|
51
|
+
disabled: {
|
|
52
|
+
control: { type: "boolean" },
|
|
53
|
+
description: "Disable the radio button",
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
args: {
|
|
57
|
+
name: "radio-group",
|
|
58
|
+
value: "option1",
|
|
59
|
+
checked: false,
|
|
60
|
+
label: "Radio Button Label",
|
|
61
|
+
},
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
export default meta;
|
|
65
|
+
type Story = StoryObj<typeof meta>;
|
|
66
|
+
|
|
67
|
+
// Default radio button
|
|
68
|
+
export const Default: Story = {
|
|
69
|
+
args: {},
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
// Checked radio button
|
|
73
|
+
export const Checked: Story = {
|
|
74
|
+
args: {
|
|
75
|
+
checked: true,
|
|
76
|
+
label: "Checked Radio Button",
|
|
77
|
+
},
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
// Unchecked radio button
|
|
81
|
+
export const Unchecked: Story = {
|
|
82
|
+
args: {
|
|
83
|
+
checked: false,
|
|
84
|
+
label: "Unchecked Radio Button",
|
|
85
|
+
},
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
// With label
|
|
89
|
+
export const WithLabel: Story = {
|
|
90
|
+
args: {
|
|
91
|
+
label: "Option with Label",
|
|
92
|
+
},
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
// With subtext
|
|
96
|
+
export const WithSubtext: Story = {
|
|
97
|
+
args: {
|
|
98
|
+
label: "Premium Plan",
|
|
99
|
+
subText: "$29.99/month - Best value",
|
|
100
|
+
},
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
// Error state
|
|
104
|
+
export const Error: Story = {
|
|
105
|
+
args: {
|
|
106
|
+
label: "Radio Button with Error",
|
|
107
|
+
hasError: true,
|
|
108
|
+
},
|
|
109
|
+
};
|
|
110
|
+
|
|
111
|
+
// Disabled state
|
|
112
|
+
export const Disabled: Story = {
|
|
113
|
+
args: {
|
|
114
|
+
label: "Disabled Radio Button",
|
|
115
|
+
disabled: true,
|
|
116
|
+
},
|
|
117
|
+
};
|
|
118
|
+
|
|
119
|
+
// Disabled checked
|
|
120
|
+
export const DisabledChecked: Story = {
|
|
121
|
+
args: {
|
|
122
|
+
checked: true,
|
|
123
|
+
label: "Disabled Checked Radio Button",
|
|
124
|
+
disabled: true,
|
|
125
|
+
},
|
|
126
|
+
};
|
|
127
|
+
|
|
128
|
+
// Radio group
|
|
129
|
+
export const RadioGroup: Story = {
|
|
130
|
+
render: () => {
|
|
131
|
+
const [selected, setSelected] = useState("option1");
|
|
132
|
+
return (
|
|
133
|
+
<div className="space-y-3">
|
|
134
|
+
<RadioButton
|
|
135
|
+
name="plan"
|
|
136
|
+
value="option1"
|
|
137
|
+
checked={selected === "option1"}
|
|
138
|
+
onChange={() => setSelected("option1")}
|
|
139
|
+
label="Basic Plan"
|
|
140
|
+
subText="$9.99/month"
|
|
141
|
+
/>
|
|
142
|
+
<RadioButton
|
|
143
|
+
name="plan"
|
|
144
|
+
value="option2"
|
|
145
|
+
checked={selected === "option2"}
|
|
146
|
+
onChange={() => setSelected("option2")}
|
|
147
|
+
label="Standard Plan"
|
|
148
|
+
subText="$19.99/month"
|
|
149
|
+
/>
|
|
150
|
+
<RadioButton
|
|
151
|
+
name="plan"
|
|
152
|
+
value="option3"
|
|
153
|
+
checked={selected === "option3"}
|
|
154
|
+
onChange={() => setSelected("option3")}
|
|
155
|
+
label="Premium Plan"
|
|
156
|
+
subText="$29.99/month"
|
|
157
|
+
/>
|
|
158
|
+
</div>
|
|
159
|
+
);
|
|
160
|
+
},
|
|
161
|
+
parameters: {
|
|
162
|
+
docs: {
|
|
163
|
+
description: {
|
|
164
|
+
story: "Radio button group where only one option can be selected.",
|
|
165
|
+
},
|
|
166
|
+
},
|
|
167
|
+
},
|
|
168
|
+
};
|
|
169
|
+
|
|
170
|
+
// With error in group
|
|
171
|
+
export const GroupWithError: Story = {
|
|
172
|
+
render: () => {
|
|
173
|
+
const [selected, setSelected] = useState<string | undefined>();
|
|
174
|
+
return (
|
|
175
|
+
<div className="space-y-3">
|
|
176
|
+
<RadioButton
|
|
177
|
+
name="payment"
|
|
178
|
+
value="credit"
|
|
179
|
+
checked={selected === "credit"}
|
|
180
|
+
onChange={val =>
|
|
181
|
+
setSelected(
|
|
182
|
+
typeof val === "string" || typeof val === "number"
|
|
183
|
+
? String(val)
|
|
184
|
+
: undefined
|
|
185
|
+
)
|
|
186
|
+
}
|
|
187
|
+
label="Credit Card"
|
|
188
|
+
hasError={!selected}
|
|
189
|
+
/>
|
|
190
|
+
<RadioButton
|
|
191
|
+
name="payment"
|
|
192
|
+
value="debit"
|
|
193
|
+
checked={selected === "debit"}
|
|
194
|
+
onChange={val =>
|
|
195
|
+
setSelected(
|
|
196
|
+
typeof val === "string" || typeof val === "number"
|
|
197
|
+
? String(val)
|
|
198
|
+
: undefined
|
|
199
|
+
)
|
|
200
|
+
}
|
|
201
|
+
label="Debit Card"
|
|
202
|
+
hasError={!selected}
|
|
203
|
+
/>
|
|
204
|
+
<RadioButton
|
|
205
|
+
name="payment"
|
|
206
|
+
value="paypal"
|
|
207
|
+
checked={selected === "paypal"}
|
|
208
|
+
onChange={val =>
|
|
209
|
+
setSelected(
|
|
210
|
+
typeof val === "string" || typeof val === "number"
|
|
211
|
+
? String(val)
|
|
212
|
+
: undefined
|
|
213
|
+
)
|
|
214
|
+
}
|
|
215
|
+
label="PayPal"
|
|
216
|
+
hasError={!selected}
|
|
217
|
+
/>
|
|
218
|
+
{!selected && (
|
|
219
|
+
<p className="text-sm text-red-600">Please select a payment method</p>
|
|
220
|
+
)}
|
|
221
|
+
</div>
|
|
222
|
+
);
|
|
223
|
+
},
|
|
224
|
+
parameters: {
|
|
225
|
+
docs: {
|
|
226
|
+
description: {
|
|
227
|
+
story:
|
|
228
|
+
"Radio button group with error state when no option is selected.",
|
|
229
|
+
},
|
|
230
|
+
},
|
|
231
|
+
},
|
|
232
|
+
};
|
|
233
|
+
|
|
234
|
+
// All variants showcase
|
|
235
|
+
export const AllVariants: Story = {
|
|
236
|
+
render: () => (
|
|
237
|
+
<div className="space-y-6">
|
|
238
|
+
<div>
|
|
239
|
+
<h3 className="mb-3 text-lg font-semibold">States</h3>
|
|
240
|
+
<div className="space-y-3">
|
|
241
|
+
<RadioButton
|
|
242
|
+
name="demo1"
|
|
243
|
+
value="unchecked"
|
|
244
|
+
checked={false}
|
|
245
|
+
label="Unchecked"
|
|
246
|
+
/>
|
|
247
|
+
<RadioButton
|
|
248
|
+
name="demo2"
|
|
249
|
+
value="checked"
|
|
250
|
+
checked={true}
|
|
251
|
+
label="Checked"
|
|
252
|
+
/>
|
|
253
|
+
<RadioButton
|
|
254
|
+
name="demo3"
|
|
255
|
+
value="disabled"
|
|
256
|
+
checked={false}
|
|
257
|
+
label="Disabled"
|
|
258
|
+
disabled
|
|
259
|
+
/>
|
|
260
|
+
<RadioButton
|
|
261
|
+
name="demo4"
|
|
262
|
+
value="disabled-checked"
|
|
263
|
+
checked={true}
|
|
264
|
+
label="Disabled Checked"
|
|
265
|
+
disabled
|
|
266
|
+
/>
|
|
267
|
+
</div>
|
|
268
|
+
</div>
|
|
269
|
+
<div>
|
|
270
|
+
<h3 className="mb-3 text-lg font-semibold">With Subtext</h3>
|
|
271
|
+
<div className="space-y-3">
|
|
272
|
+
<RadioButton
|
|
273
|
+
name="demo5"
|
|
274
|
+
value="plan1"
|
|
275
|
+
checked={true}
|
|
276
|
+
label="Basic Plan"
|
|
277
|
+
subText="$9.99/month"
|
|
278
|
+
/>
|
|
279
|
+
<RadioButton
|
|
280
|
+
name="demo6"
|
|
281
|
+
value="plan2"
|
|
282
|
+
checked={false}
|
|
283
|
+
label="Premium Plan"
|
|
284
|
+
subText="$29.99/month - Best value"
|
|
285
|
+
/>
|
|
286
|
+
</div>
|
|
287
|
+
</div>
|
|
288
|
+
<div>
|
|
289
|
+
<h3 className="mb-3 text-lg font-semibold">Error State</h3>
|
|
290
|
+
<RadioButton
|
|
291
|
+
name="demo7"
|
|
292
|
+
value="error"
|
|
293
|
+
checked={false}
|
|
294
|
+
label="Radio Button with Error"
|
|
295
|
+
hasError
|
|
296
|
+
/>
|
|
297
|
+
</div>
|
|
298
|
+
</div>
|
|
299
|
+
),
|
|
300
|
+
parameters: {
|
|
301
|
+
docs: {
|
|
302
|
+
description: {
|
|
303
|
+
story: "Showcase of all radio button variants and states.",
|
|
304
|
+
},
|
|
305
|
+
},
|
|
306
|
+
},
|
|
307
|
+
};
|