@windstream/react-shared-components 0.1.79 → 0.1.80

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.
Files changed (208) hide show
  1. package/README.md +635 -635
  2. package/dist/contentful/index.esm.js +3 -3
  3. package/dist/contentful/index.esm.js.map +1 -1
  4. package/dist/contentful/index.js +3 -3
  5. package/dist/contentful/index.js.map +1 -1
  6. package/dist/core.d.ts +1 -1
  7. package/dist/index.d.ts +1 -1
  8. package/dist/index.esm.js +13 -5
  9. package/dist/index.esm.js.map +1 -1
  10. package/dist/index.js +13 -5
  11. package/dist/index.js.map +1 -1
  12. package/dist/next/index.esm.js +2 -2
  13. package/dist/next/index.esm.js.map +1 -1
  14. package/dist/next/index.js +2 -2
  15. package/dist/next/index.js.map +1 -1
  16. package/dist/utils/index.esm.js +1 -1
  17. package/dist/utils/index.esm.js.map +1 -1
  18. package/dist/utils/index.js +1 -1
  19. package/dist/utils/index.js.map +1 -1
  20. package/package.json +185 -185
  21. package/src/components/accordion/Accordion.stories.tsx +230 -230
  22. package/src/components/accordion/index.tsx +70 -70
  23. package/src/components/accordion/types.ts +12 -12
  24. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  25. package/src/components/alert-card/index.tsx +41 -41
  26. package/src/components/alert-card/types.ts +13 -13
  27. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  28. package/src/components/brand-button/helpers.ts +35 -35
  29. package/src/components/brand-button/index.tsx +120 -120
  30. package/src/components/brand-button/types.ts +38 -38
  31. package/src/components/button/Button.stories.tsx +108 -108
  32. package/src/components/button/index.tsx +27 -27
  33. package/src/components/button/types.ts +14 -14
  34. package/src/components/call-button/CallButton.stories.tsx +324 -324
  35. package/src/components/call-button/index.tsx +106 -106
  36. package/src/components/call-button/types.ts +16 -16
  37. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  38. package/src/components/checkbox/index.tsx +197 -197
  39. package/src/components/checkbox/types.ts +27 -27
  40. package/src/components/checklist/Checklist.stories.tsx +150 -150
  41. package/src/components/checklist/index.tsx +61 -61
  42. package/src/components/checklist/types.ts +17 -17
  43. package/src/components/collapse/Collapse.stories.tsx +255 -255
  44. package/src/components/collapse/index.tsx +46 -46
  45. package/src/components/collapse/types.ts +6 -6
  46. package/src/components/divider/Divider.stories.tsx +205 -205
  47. package/src/components/divider/index.tsx +22 -22
  48. package/src/components/divider/type.ts +3 -3
  49. package/src/components/image/Image.stories.tsx +113 -113
  50. package/src/components/image/index.tsx +25 -25
  51. package/src/components/image/types.ts +40 -40
  52. package/src/components/input/Input.stories.tsx +325 -325
  53. package/src/components/input/index.tsx +177 -177
  54. package/src/components/input/types.ts +37 -37
  55. package/src/components/link/Link.stories.tsx +163 -163
  56. package/src/components/link/index.tsx +116 -116
  57. package/src/components/link/types.ts +25 -25
  58. package/src/components/list/List.stories.tsx +272 -272
  59. package/src/components/list/index.tsx +88 -88
  60. package/src/components/list/list-item/index.tsx +38 -38
  61. package/src/components/list/list-item/types.ts +13 -13
  62. package/src/components/list/types.ts +29 -29
  63. package/src/components/material-icon/MaterialIcon.stories.tsx +322 -322
  64. package/src/components/material-icon/constants.ts +99 -99
  65. package/src/components/material-icon/index.tsx +47 -47
  66. package/src/components/material-icon/types.ts +31 -31
  67. package/src/components/modal/Modal.stories.tsx +171 -171
  68. package/src/components/modal/index.tsx +164 -164
  69. package/src/components/modal/types.ts +24 -24
  70. package/src/components/next-image/index.tsx +74 -74
  71. package/src/components/next-image/types.ts +1 -1
  72. package/src/components/pagination/index.tsx +91 -91
  73. package/src/components/pagination/types.ts +6 -6
  74. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  75. package/src/components/radio-button/index.tsx +75 -75
  76. package/src/components/radio-button/types.ts +21 -21
  77. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  78. package/src/components/see-more/index.tsx +44 -44
  79. package/src/components/see-more/types.ts +4 -4
  80. package/src/components/select/Select.stories.tsx +411 -411
  81. package/src/components/select/index.tsx +155 -155
  82. package/src/components/select/types.ts +36 -36
  83. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  84. package/src/components/select-plan-button/index.tsx +63 -63
  85. package/src/components/select-plan-button/types.ts +17 -17
  86. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  87. package/src/components/skeleton/index.tsx +61 -61
  88. package/src/components/skeleton/types.ts +4 -4
  89. package/src/components/spinner/Spinner.stories.tsx +335 -335
  90. package/src/components/spinner/index.tsx +44 -44
  91. package/src/components/spinner/types.ts +5 -5
  92. package/src/components/text/Text.stories.tsx +321 -321
  93. package/src/components/text/index.tsx +25 -25
  94. package/src/components/text/types.ts +45 -45
  95. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  96. package/src/components/tooltip/index.tsx +74 -74
  97. package/src/components/tooltip/types.ts +7 -7
  98. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  99. package/src/components/view-cart-button/index.tsx +42 -42
  100. package/src/components/view-cart-button/types.ts +5 -5
  101. package/src/contentful/blocks/accordion/Accordion.stories.mocks.tsx +128 -128
  102. package/src/contentful/blocks/accordion/Accordion.stories.tsx +98 -98
  103. package/src/contentful/blocks/accordion/index.tsx +112 -112
  104. package/src/contentful/blocks/accordion/types.ts +34 -34
  105. package/src/contentful/blocks/address-input-banner/index.tsx +52 -52
  106. package/src/contentful/blocks/address-input-banner/types.ts +14 -14
  107. package/src/contentful/blocks/anchored-bottom-banner/index.tsx +181 -181
  108. package/src/contentful/blocks/anchored-bottom-banner/types.ts +13 -13
  109. package/src/contentful/blocks/blogs-grid/BlogGrid.stories.mocks.tsx +144 -144
  110. package/src/contentful/blocks/blogs-grid/BlogGrid.stories.tsx +156 -156
  111. package/src/contentful/blocks/blogs-grid/index.tsx +134 -134
  112. package/src/contentful/blocks/blogs-grid/types.ts +26 -26
  113. package/src/contentful/blocks/blogs-grid-base/index.tsx +119 -119
  114. package/src/contentful/blocks/blogs-grid-base/types.ts +36 -36
  115. package/src/contentful/blocks/breadcrumbs/BreadcrumbNavigation.stories.tsx +147 -147
  116. package/src/contentful/blocks/breadcrumbs/index.tsx +95 -95
  117. package/src/contentful/blocks/breadcrumbs/types.ts +8 -8
  118. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  119. package/src/contentful/blocks/button/index.tsx +131 -131
  120. package/src/contentful/blocks/button/types.ts +39 -39
  121. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  122. package/src/contentful/blocks/callout/index.tsx +265 -265
  123. package/src/contentful/blocks/callout/types.ts +72 -72
  124. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  125. package/src/contentful/blocks/cards/blog-card/index.tsx +129 -129
  126. package/src/contentful/blocks/cards/blog-card/types.ts +34 -34
  127. package/src/contentful/blocks/cards/floating-image-card/index.tsx +119 -119
  128. package/src/contentful/blocks/cards/floating-image-card/types.ts +30 -30
  129. package/src/contentful/blocks/cards/full-image-card/index.tsx +130 -130
  130. package/src/contentful/blocks/cards/full-image-card/types.ts +29 -29
  131. package/src/contentful/blocks/cards/index.tsx +13 -13
  132. package/src/contentful/blocks/cards/product-card/index.tsx +251 -251
  133. package/src/contentful/blocks/cards/product-card/types.ts +28 -28
  134. package/src/contentful/blocks/cards/simple-card/index.tsx +325 -325
  135. package/src/contentful/blocks/cards/simple-card/types.ts +71 -71
  136. package/src/contentful/blocks/cards/testimonial-card/index.tsx +90 -90
  137. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  138. package/src/contentful/blocks/cards/types.ts +1 -1
  139. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  140. package/src/contentful/blocks/carousel/helper.tsx +440 -440
  141. package/src/contentful/blocks/carousel/index.tsx +85 -85
  142. package/src/contentful/blocks/carousel/types.ts +144 -144
  143. package/src/contentful/blocks/cart-retention-banner/index.tsx +105 -105
  144. package/src/contentful/blocks/cart-retention-banner/types.ts +11 -11
  145. package/src/contentful/blocks/comparison-table/index.tsx +29 -29
  146. package/src/contentful/blocks/comparison-table/types.ts +6 -6
  147. package/src/contentful/blocks/cookiebanner/index.tsx +146 -146
  148. package/src/contentful/blocks/cookiebanner/type.ts +7 -7
  149. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  150. package/src/contentful/blocks/cta-callout/index.tsx +71 -71
  151. package/src/contentful/blocks/cta-callout/types.ts +26 -26
  152. package/src/contentful/blocks/dynamic-tabs/index.tsx +204 -204
  153. package/src/contentful/blocks/dynamic-tabs/types.ts +21 -21
  154. package/src/contentful/blocks/email-input-block/index.tsx +116 -116
  155. package/src/contentful/blocks/email-input-block/types.ts +16 -16
  156. package/src/contentful/blocks/find-kinetic/FindKinetic.stories.tsx +23 -23
  157. package/src/contentful/blocks/find-kinetic/index.tsx +130 -130
  158. package/src/contentful/blocks/find-kinetic/types.ts +19 -19
  159. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  160. package/src/contentful/blocks/floating-banner/index.tsx +97 -97
  161. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  162. package/src/contentful/blocks/footer/Footer.stories.tsx +317 -317
  163. package/src/contentful/blocks/footer/index.tsx +91 -91
  164. package/src/contentful/blocks/footer/types.ts +13 -13
  165. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  166. package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
  167. package/src/contentful/blocks/image-promo-bar/index.tsx +246 -246
  168. package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
  169. package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
  170. package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
  171. package/src/contentful/blocks/modal/constants.ts +53 -53
  172. package/src/contentful/blocks/modal/index.tsx +107 -107
  173. package/src/contentful/blocks/modal/types.ts +12 -12
  174. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +139 -139
  175. package/src/contentful/blocks/navigation/index.tsx +568 -568
  176. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +82 -82
  177. package/src/contentful/blocks/navigation/types.ts +71 -71
  178. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  179. package/src/contentful/blocks/primary-hero/index.tsx +236 -236
  180. package/src/contentful/blocks/primary-hero/types.ts +37 -37
  181. package/src/contentful/blocks/search-block/index.tsx +90 -90
  182. package/src/contentful/blocks/search-block/types.ts +15 -15
  183. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  184. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  185. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  186. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  187. package/src/contentful/blocks/text/index.tsx +12 -12
  188. package/src/contentful/blocks/text/types.ts +1 -1
  189. package/src/contentful/index.ts +105 -105
  190. package/src/hooks/contentful/use-contentful-rich-text.tsx +309 -309
  191. package/src/hooks/contentful/use-processed-check-list.ts +63 -63
  192. package/src/hooks/use-body-scroll-lock.ts +34 -34
  193. package/src/hooks/use-carousel-swipe.ts +264 -264
  194. package/src/hooks/use-outside-click.ts +17 -17
  195. package/src/index.ts +101 -101
  196. package/src/next/index.ts +5 -5
  197. package/src/setupTests.ts +46 -46
  198. package/src/stories/DocsTemplate.tsx +24 -24
  199. package/src/styles/globals.css +343 -343
  200. package/src/types/global.d.ts +9 -9
  201. package/src/types/micro-components.ts +99 -99
  202. package/src/types/utm.ts +49 -49
  203. package/src/utils/contentful/to-document.ts +24 -24
  204. package/src/utils/cookie.ts +84 -84
  205. package/src/utils/cx.ts +49 -49
  206. package/src/utils/index.ts +41 -41
  207. package/src/utils/speed-card-bg.ts +24 -24
  208. package/src/utils/utm.ts +221 -221
@@ -1,335 +1,335 @@
1
- import { Spinner } from "./index";
2
-
3
- import { DocsPage } from "@shared/stories/DocsTemplate";
4
- import type { Meta, StoryObj } from "@storybook/react";
5
-
6
- const meta: Meta<typeof Spinner> = {
7
- title: "Components/Spinner",
8
- component: Spinner,
9
- tags: ["autodocs"],
10
- parameters: {
11
- layout: "centered",
12
- docs: {
13
- page: DocsPage,
14
- description: {
15
- component:
16
- "A loading spinner component with customizable size, color, and animation.",
17
- },
18
- },
19
- },
20
- argTypes: {
21
- size: {
22
- control: { type: "select" },
23
- options: ["small", "medium", "large", "xlarge"],
24
- description: "Spinner size",
25
- },
26
- color: {
27
- control: { type: "color" },
28
- description: "Spinner color",
29
- },
30
- className: {
31
- control: { type: "text" },
32
- description: "Additional CSS classes",
33
- },
34
- },
35
- args: {
36
- size: "medium",
37
- },
38
- };
39
-
40
- export default meta;
41
- type Story = StoryObj<typeof meta>;
42
-
43
- // Default spinner
44
- export const Default: Story = {
45
- args: {},
46
- };
47
-
48
- // Different sizes
49
- export const Sizes: Story = {
50
- render: () => (
51
- <div className="flex items-center gap-8">
52
- <div className="text-center">
53
- <Spinner size="small" />
54
- <p className="mt-2 text-xs">Small</p>
55
- </div>
56
- <div className="text-center">
57
- <Spinner size="medium" />
58
- <p className="mt-2 text-xs">Medium</p>
59
- </div>
60
- <div className="text-center">
61
- <Spinner size="large" />
62
- <p className="mt-2 text-xs">Large</p>
63
- </div>
64
- <div className="text-center">
65
- <Spinner size="xlarge" />
66
- <p className="mt-2 text-xs">XLarge</p>
67
- </div>
68
- </div>
69
- ),
70
- parameters: {
71
- docs: {
72
- description: {
73
- story: "All available spinner sizes.",
74
- },
75
- },
76
- },
77
- };
78
-
79
- // Colored spinners
80
- export const ColoredSpinners: Story = {
81
- render: () => (
82
- <div className="grid grid-cols-4 gap-6">
83
- <div className="text-center">
84
- <Spinner size="large" color="#3b82f6" />
85
- <p className="mt-2 text-sm text-blue-600">Blue</p>
86
- </div>
87
- <div className="text-center">
88
- <Spinner size="large" color="#10b981" />
89
- <p className="mt-2 text-sm text-green-600">Green</p>
90
- </div>
91
- <div className="text-center">
92
- <Spinner size="large" color="#ef4444" />
93
- <p className="mt-2 text-sm text-red-600">Red</p>
94
- </div>
95
- <div className="text-center">
96
- <Spinner size="large" color="#f59e0b" />
97
- <p className="mt-2 text-sm text-yellow-600">Yellow</p>
98
- </div>
99
- </div>
100
- ),
101
- parameters: {
102
- docs: {
103
- description: {
104
- story: "Spinners with different colors.",
105
- },
106
- },
107
- },
108
- };
109
-
110
- // Spinner with text
111
- export const SpinnerWithText: Story = {
112
- render: () => (
113
- <div className="space-y-6">
114
- <div className="flex items-center gap-3">
115
- <Spinner size="small" />
116
- <span className="text-sm text-gray-600">Loading...</span>
117
- </div>
118
- <div className="flex items-center gap-3">
119
- <Spinner size="medium" />
120
- <span className="text-sm text-gray-600">Processing request...</span>
121
- </div>
122
- <div className="flex items-center gap-3">
123
- <Spinner size="large" />
124
- <span className="text-sm text-gray-600">Saving changes...</span>
125
- </div>
126
- </div>
127
- ),
128
- parameters: {
129
- docs: {
130
- description: {
131
- story: "Spinners used alongside loading text.",
132
- },
133
- },
134
- },
135
- };
136
-
137
- // Button with spinner
138
- export const ButtonWithSpinner: Story = {
139
- render: () => (
140
- <div className="space-y-4">
141
- <button className="flex items-center gap-2 rounded bg-blue-600 px-4 py-2 text-white hover:bg-blue-700 disabled:opacity-50">
142
- <Spinner size="small" color="white" />
143
- <span>Loading...</span>
144
- </button>
145
-
146
- <button className="flex items-center gap-2 rounded bg-gray-600 px-4 py-2 text-white hover:bg-gray-700 disabled:opacity-50">
147
- <Spinner size="small" color="white" />
148
- <span>Processing...</span>
149
- </button>
150
-
151
- <button className="flex items-center gap-2 rounded bg-green-600 px-4 py-2 text-white hover:bg-green-700 disabled:opacity-50">
152
- <Spinner size="small" color="white" />
153
- <span>Saving...</span>
154
- </button>
155
- </div>
156
- ),
157
- parameters: {
158
- docs: {
159
- description: {
160
- story: "Spinners integrated into buttons for loading states.",
161
- },
162
- },
163
- },
164
- };
165
-
166
- // Card with spinner
167
- export const CardWithSpinner: Story = {
168
- render: () => (
169
- <div className="grid grid-cols-2 gap-6">
170
- <div className="rounded-lg border p-6">
171
- <div className="flex h-32 items-center justify-center">
172
- <div className="text-center">
173
- <Spinner size="large" />
174
- <p className="mt-3 text-sm text-gray-600">Loading content...</p>
175
- </div>
176
- </div>
177
- </div>
178
-
179
- <div className="rounded-lg border p-6">
180
- <div className="flex h-32 items-center justify-center">
181
- <div className="text-center">
182
- <Spinner size="large" color="#10b981" />
183
- <p className="mt-3 text-sm text-gray-600">Processing data...</p>
184
- </div>
185
- </div>
186
- </div>
187
- </div>
188
- ),
189
- parameters: {
190
- docs: {
191
- description: {
192
- story: "Spinners in card layouts for content loading states.",
193
- },
194
- },
195
- },
196
- };
197
-
198
- // Inline spinner
199
- export const InlineSpinner: Story = {
200
- render: () => (
201
- <div className="space-y-4">
202
- <p className="text-gray-700">
203
- This is some text with an inline{" "}
204
- <Spinner size="small" className="mx-1 inline" /> spinner.
205
- </p>
206
-
207
- <p className="text-gray-700">
208
- Another example with a{" "}
209
- <Spinner size="small" color="#ef4444" className="mx-1 inline" /> colored
210
- spinner.
211
- </p>
212
-
213
- <div className="flex items-center gap-2">
214
- <span>Status:</span>
215
- <Spinner size="small" />
216
- <span className="text-sm text-gray-500">Checking...</span>
217
- </div>
218
- </div>
219
- ),
220
- parameters: {
221
- docs: {
222
- description: {
223
- story: "Inline spinners within text content.",
224
- },
225
- },
226
- },
227
- };
228
-
229
- // Loading states
230
- export const LoadingStates: Story = {
231
- render: () => (
232
- <div className="space-y-6">
233
- <div className="rounded-lg border p-4">
234
- <h3 className="mb-2 font-medium">Initial Loading</h3>
235
- <div className="flex items-center gap-3">
236
- <Spinner size="medium" />
237
- <span className="text-sm text-gray-600">Loading application...</span>
238
- </div>
239
- </div>
240
-
241
- <div className="rounded-lg border p-4">
242
- <h3 className="mb-2 font-medium">Data Fetching</h3>
243
- <div className="flex items-center gap-3">
244
- <Spinner size="medium" color="#3b82f6" />
245
- <span className="text-sm text-gray-600">Fetching user data...</span>
246
- </div>
247
- </div>
248
-
249
- <div className="rounded-lg border p-4">
250
- <h3 className="mb-2 font-medium">Form Submission</h3>
251
- <div className="flex items-center gap-3">
252
- <Spinner size="medium" color="#10b981" />
253
- <span className="text-sm text-gray-600">Submitting form...</span>
254
- </div>
255
- </div>
256
-
257
- <div className="rounded-lg border p-4">
258
- <h3 className="mb-2 font-medium">File Upload</h3>
259
- <div className="flex items-center gap-3">
260
- <Spinner size="medium" color="#f59e0b" />
261
- <span className="text-sm text-gray-600">Uploading file...</span>
262
- </div>
263
- </div>
264
- </div>
265
- ),
266
- parameters: {
267
- docs: {
268
- description: {
269
- story: "Different loading states with appropriate messaging.",
270
- },
271
- },
272
- },
273
- };
274
-
275
- // All variants showcase
276
- export const AllVariants: Story = {
277
- render: () => (
278
- <div className="space-y-8">
279
- <div>
280
- <h3 className="mb-4 text-lg font-semibold">Spinner Sizes</h3>
281
- <div className="flex items-center gap-8">
282
- <div className="text-center">
283
- <Spinner size="small" />
284
- <p className="mt-2 text-xs">Small</p>
285
- </div>
286
- <div className="text-center">
287
- <Spinner size="medium" />
288
- <p className="mt-2 text-xs">Medium</p>
289
- </div>
290
- <div className="text-center">
291
- <Spinner size="large" />
292
- <p className="mt-2 text-xs">Large</p>
293
- </div>
294
- <div className="text-center">
295
- <Spinner size="xlarge" />
296
- <p className="mt-2 text-xs">XLarge</p>
297
- </div>
298
- </div>
299
- </div>
300
-
301
- <div>
302
- <h3 className="mb-4 text-lg font-semibold">Color Variants</h3>
303
- <div className="grid grid-cols-5 gap-4">
304
- <div className="text-center">
305
- <Spinner size="large" color="#3b82f6" />
306
- <p className="mt-2 text-xs text-blue-600">Blue</p>
307
- </div>
308
- <div className="text-center">
309
- <Spinner size="large" color="#10b981" />
310
- <p className="mt-2 text-xs text-green-600">Green</p>
311
- </div>
312
- <div className="text-center">
313
- <Spinner size="large" color="#ef4444" />
314
- <p className="mt-2 text-xs text-red-600">Red</p>
315
- </div>
316
- <div className="text-center">
317
- <Spinner size="large" color="#f59e0b" />
318
- <p className="mt-2 text-xs text-yellow-600">Yellow</p>
319
- </div>
320
- <div className="text-center">
321
- <Spinner size="large" color="#8b5cf6" />
322
- <p className="mt-2 text-xs text-purple-600">Purple</p>
323
- </div>
324
- </div>
325
- </div>
326
- </div>
327
- ),
328
- parameters: {
329
- docs: {
330
- description: {
331
- story: "Complete showcase of all spinner sizes and colors.",
332
- },
333
- },
334
- },
335
- };
1
+ import { Spinner } from "./index";
2
+
3
+ import { DocsPage } from "@shared/stories/DocsTemplate";
4
+ import type { Meta, StoryObj } from "@storybook/react";
5
+
6
+ const meta: Meta<typeof Spinner> = {
7
+ title: "Components/Spinner",
8
+ component: Spinner,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ layout: "centered",
12
+ docs: {
13
+ page: DocsPage,
14
+ description: {
15
+ component:
16
+ "A loading spinner component with customizable size, color, and animation.",
17
+ },
18
+ },
19
+ },
20
+ argTypes: {
21
+ size: {
22
+ control: { type: "select" },
23
+ options: ["small", "medium", "large", "xlarge"],
24
+ description: "Spinner size",
25
+ },
26
+ color: {
27
+ control: { type: "color" },
28
+ description: "Spinner color",
29
+ },
30
+ className: {
31
+ control: { type: "text" },
32
+ description: "Additional CSS classes",
33
+ },
34
+ },
35
+ args: {
36
+ size: "medium",
37
+ },
38
+ };
39
+
40
+ export default meta;
41
+ type Story = StoryObj<typeof meta>;
42
+
43
+ // Default spinner
44
+ export const Default: Story = {
45
+ args: {},
46
+ };
47
+
48
+ // Different sizes
49
+ export const Sizes: Story = {
50
+ render: () => (
51
+ <div className="flex items-center gap-8">
52
+ <div className="text-center">
53
+ <Spinner size="small" />
54
+ <p className="mt-2 text-xs">Small</p>
55
+ </div>
56
+ <div className="text-center">
57
+ <Spinner size="medium" />
58
+ <p className="mt-2 text-xs">Medium</p>
59
+ </div>
60
+ <div className="text-center">
61
+ <Spinner size="large" />
62
+ <p className="mt-2 text-xs">Large</p>
63
+ </div>
64
+ <div className="text-center">
65
+ <Spinner size="xlarge" />
66
+ <p className="mt-2 text-xs">XLarge</p>
67
+ </div>
68
+ </div>
69
+ ),
70
+ parameters: {
71
+ docs: {
72
+ description: {
73
+ story: "All available spinner sizes.",
74
+ },
75
+ },
76
+ },
77
+ };
78
+
79
+ // Colored spinners
80
+ export const ColoredSpinners: Story = {
81
+ render: () => (
82
+ <div className="grid grid-cols-4 gap-6">
83
+ <div className="text-center">
84
+ <Spinner size="large" color="#3b82f6" />
85
+ <p className="mt-2 text-sm text-blue-600">Blue</p>
86
+ </div>
87
+ <div className="text-center">
88
+ <Spinner size="large" color="#10b981" />
89
+ <p className="mt-2 text-sm text-green-600">Green</p>
90
+ </div>
91
+ <div className="text-center">
92
+ <Spinner size="large" color="#ef4444" />
93
+ <p className="mt-2 text-sm text-red-600">Red</p>
94
+ </div>
95
+ <div className="text-center">
96
+ <Spinner size="large" color="#f59e0b" />
97
+ <p className="mt-2 text-sm text-yellow-600">Yellow</p>
98
+ </div>
99
+ </div>
100
+ ),
101
+ parameters: {
102
+ docs: {
103
+ description: {
104
+ story: "Spinners with different colors.",
105
+ },
106
+ },
107
+ },
108
+ };
109
+
110
+ // Spinner with text
111
+ export const SpinnerWithText: Story = {
112
+ render: () => (
113
+ <div className="space-y-6">
114
+ <div className="flex items-center gap-3">
115
+ <Spinner size="small" />
116
+ <span className="text-sm text-gray-600">Loading...</span>
117
+ </div>
118
+ <div className="flex items-center gap-3">
119
+ <Spinner size="medium" />
120
+ <span className="text-sm text-gray-600">Processing request...</span>
121
+ </div>
122
+ <div className="flex items-center gap-3">
123
+ <Spinner size="large" />
124
+ <span className="text-sm text-gray-600">Saving changes...</span>
125
+ </div>
126
+ </div>
127
+ ),
128
+ parameters: {
129
+ docs: {
130
+ description: {
131
+ story: "Spinners used alongside loading text.",
132
+ },
133
+ },
134
+ },
135
+ };
136
+
137
+ // Button with spinner
138
+ export const ButtonWithSpinner: Story = {
139
+ render: () => (
140
+ <div className="space-y-4">
141
+ <button className="flex items-center gap-2 rounded bg-blue-600 px-4 py-2 text-white hover:bg-blue-700 disabled:opacity-50">
142
+ <Spinner size="small" color="white" />
143
+ <span>Loading...</span>
144
+ </button>
145
+
146
+ <button className="flex items-center gap-2 rounded bg-gray-600 px-4 py-2 text-white hover:bg-gray-700 disabled:opacity-50">
147
+ <Spinner size="small" color="white" />
148
+ <span>Processing...</span>
149
+ </button>
150
+
151
+ <button className="flex items-center gap-2 rounded bg-green-600 px-4 py-2 text-white hover:bg-green-700 disabled:opacity-50">
152
+ <Spinner size="small" color="white" />
153
+ <span>Saving...</span>
154
+ </button>
155
+ </div>
156
+ ),
157
+ parameters: {
158
+ docs: {
159
+ description: {
160
+ story: "Spinners integrated into buttons for loading states.",
161
+ },
162
+ },
163
+ },
164
+ };
165
+
166
+ // Card with spinner
167
+ export const CardWithSpinner: Story = {
168
+ render: () => (
169
+ <div className="grid grid-cols-2 gap-6">
170
+ <div className="rounded-lg border p-6">
171
+ <div className="flex h-32 items-center justify-center">
172
+ <div className="text-center">
173
+ <Spinner size="large" />
174
+ <p className="mt-3 text-sm text-gray-600">Loading content...</p>
175
+ </div>
176
+ </div>
177
+ </div>
178
+
179
+ <div className="rounded-lg border p-6">
180
+ <div className="flex h-32 items-center justify-center">
181
+ <div className="text-center">
182
+ <Spinner size="large" color="#10b981" />
183
+ <p className="mt-3 text-sm text-gray-600">Processing data...</p>
184
+ </div>
185
+ </div>
186
+ </div>
187
+ </div>
188
+ ),
189
+ parameters: {
190
+ docs: {
191
+ description: {
192
+ story: "Spinners in card layouts for content loading states.",
193
+ },
194
+ },
195
+ },
196
+ };
197
+
198
+ // Inline spinner
199
+ export const InlineSpinner: Story = {
200
+ render: () => (
201
+ <div className="space-y-4">
202
+ <p className="text-gray-700">
203
+ This is some text with an inline{" "}
204
+ <Spinner size="small" className="mx-1 inline" /> spinner.
205
+ </p>
206
+
207
+ <p className="text-gray-700">
208
+ Another example with a{" "}
209
+ <Spinner size="small" color="#ef4444" className="mx-1 inline" /> colored
210
+ spinner.
211
+ </p>
212
+
213
+ <div className="flex items-center gap-2">
214
+ <span>Status:</span>
215
+ <Spinner size="small" />
216
+ <span className="text-sm text-gray-500">Checking...</span>
217
+ </div>
218
+ </div>
219
+ ),
220
+ parameters: {
221
+ docs: {
222
+ description: {
223
+ story: "Inline spinners within text content.",
224
+ },
225
+ },
226
+ },
227
+ };
228
+
229
+ // Loading states
230
+ export const LoadingStates: Story = {
231
+ render: () => (
232
+ <div className="space-y-6">
233
+ <div className="rounded-lg border p-4">
234
+ <h3 className="mb-2 font-medium">Initial Loading</h3>
235
+ <div className="flex items-center gap-3">
236
+ <Spinner size="medium" />
237
+ <span className="text-sm text-gray-600">Loading application...</span>
238
+ </div>
239
+ </div>
240
+
241
+ <div className="rounded-lg border p-4">
242
+ <h3 className="mb-2 font-medium">Data Fetching</h3>
243
+ <div className="flex items-center gap-3">
244
+ <Spinner size="medium" color="#3b82f6" />
245
+ <span className="text-sm text-gray-600">Fetching user data...</span>
246
+ </div>
247
+ </div>
248
+
249
+ <div className="rounded-lg border p-4">
250
+ <h3 className="mb-2 font-medium">Form Submission</h3>
251
+ <div className="flex items-center gap-3">
252
+ <Spinner size="medium" color="#10b981" />
253
+ <span className="text-sm text-gray-600">Submitting form...</span>
254
+ </div>
255
+ </div>
256
+
257
+ <div className="rounded-lg border p-4">
258
+ <h3 className="mb-2 font-medium">File Upload</h3>
259
+ <div className="flex items-center gap-3">
260
+ <Spinner size="medium" color="#f59e0b" />
261
+ <span className="text-sm text-gray-600">Uploading file...</span>
262
+ </div>
263
+ </div>
264
+ </div>
265
+ ),
266
+ parameters: {
267
+ docs: {
268
+ description: {
269
+ story: "Different loading states with appropriate messaging.",
270
+ },
271
+ },
272
+ },
273
+ };
274
+
275
+ // All variants showcase
276
+ export const AllVariants: Story = {
277
+ render: () => (
278
+ <div className="space-y-8">
279
+ <div>
280
+ <h3 className="mb-4 text-lg font-semibold">Spinner Sizes</h3>
281
+ <div className="flex items-center gap-8">
282
+ <div className="text-center">
283
+ <Spinner size="small" />
284
+ <p className="mt-2 text-xs">Small</p>
285
+ </div>
286
+ <div className="text-center">
287
+ <Spinner size="medium" />
288
+ <p className="mt-2 text-xs">Medium</p>
289
+ </div>
290
+ <div className="text-center">
291
+ <Spinner size="large" />
292
+ <p className="mt-2 text-xs">Large</p>
293
+ </div>
294
+ <div className="text-center">
295
+ <Spinner size="xlarge" />
296
+ <p className="mt-2 text-xs">XLarge</p>
297
+ </div>
298
+ </div>
299
+ </div>
300
+
301
+ <div>
302
+ <h3 className="mb-4 text-lg font-semibold">Color Variants</h3>
303
+ <div className="grid grid-cols-5 gap-4">
304
+ <div className="text-center">
305
+ <Spinner size="large" color="#3b82f6" />
306
+ <p className="mt-2 text-xs text-blue-600">Blue</p>
307
+ </div>
308
+ <div className="text-center">
309
+ <Spinner size="large" color="#10b981" />
310
+ <p className="mt-2 text-xs text-green-600">Green</p>
311
+ </div>
312
+ <div className="text-center">
313
+ <Spinner size="large" color="#ef4444" />
314
+ <p className="mt-2 text-xs text-red-600">Red</p>
315
+ </div>
316
+ <div className="text-center">
317
+ <Spinner size="large" color="#f59e0b" />
318
+ <p className="mt-2 text-xs text-yellow-600">Yellow</p>
319
+ </div>
320
+ <div className="text-center">
321
+ <Spinner size="large" color="#8b5cf6" />
322
+ <p className="mt-2 text-xs text-purple-600">Purple</p>
323
+ </div>
324
+ </div>
325
+ </div>
326
+ </div>
327
+ ),
328
+ parameters: {
329
+ docs: {
330
+ description: {
331
+ story: "Complete showcase of all spinner sizes and colors.",
332
+ },
333
+ },
334
+ },
335
+ };