@windstream/react-shared-components 0.1.90 → 0.1.91

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 (210) 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/index.d.ts +2 -2
  7. package/dist/index.esm.js +13 -5
  8. package/dist/index.esm.js.map +1 -1
  9. package/dist/index.js +13 -5
  10. package/dist/index.js.map +1 -1
  11. package/dist/next/index.esm.js +2 -2
  12. package/dist/next/index.esm.js.map +1 -1
  13. package/dist/next/index.js +2 -2
  14. package/dist/next/index.js.map +1 -1
  15. package/dist/styles.css +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/animation-wrapper/index.tsx +129 -129
  28. package/src/components/animation-wrapper/types.ts +11 -11
  29. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  30. package/src/components/brand-button/helpers.ts +35 -35
  31. package/src/components/brand-button/index.tsx +120 -120
  32. package/src/components/brand-button/types.ts +38 -38
  33. package/src/components/button/Button.stories.tsx +108 -108
  34. package/src/components/button/index.tsx +27 -27
  35. package/src/components/button/types.ts +14 -14
  36. package/src/components/call-button/CallButton.stories.tsx +324 -324
  37. package/src/components/call-button/index.tsx +106 -106
  38. package/src/components/call-button/types.ts +16 -16
  39. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  40. package/src/components/checkbox/index.tsx +197 -197
  41. package/src/components/checkbox/types.ts +27 -27
  42. package/src/components/checklist/Checklist.stories.tsx +150 -150
  43. package/src/components/checklist/index.tsx +61 -61
  44. package/src/components/checklist/types.ts +17 -17
  45. package/src/components/collapse/Collapse.stories.tsx +255 -255
  46. package/src/components/collapse/index.tsx +46 -46
  47. package/src/components/collapse/types.ts +6 -6
  48. package/src/components/divider/Divider.stories.tsx +205 -205
  49. package/src/components/divider/index.tsx +22 -22
  50. package/src/components/divider/type.ts +3 -3
  51. package/src/components/image/Image.stories.tsx +113 -113
  52. package/src/components/image/index.tsx +25 -25
  53. package/src/components/image/types.ts +40 -40
  54. package/src/components/input/Input.stories.tsx +325 -325
  55. package/src/components/input/index.tsx +177 -177
  56. package/src/components/input/types.ts +37 -37
  57. package/src/components/link/Link.stories.tsx +163 -163
  58. package/src/components/link/index.tsx +116 -116
  59. package/src/components/link/types.ts +25 -25
  60. package/src/components/list/List.stories.tsx +272 -272
  61. package/src/components/list/index.tsx +88 -88
  62. package/src/components/list/list-item/index.tsx +38 -38
  63. package/src/components/list/list-item/types.ts +13 -13
  64. package/src/components/list/types.ts +29 -29
  65. package/src/components/material-icon/MaterialIcon.stories.tsx +322 -322
  66. package/src/components/material-icon/constants.ts +99 -99
  67. package/src/components/material-icon/index.tsx +47 -47
  68. package/src/components/material-icon/types.ts +31 -31
  69. package/src/components/modal/Modal.stories.tsx +171 -171
  70. package/src/components/modal/index.tsx +164 -164
  71. package/src/components/modal/types.ts +24 -24
  72. package/src/components/next-image/index.tsx +74 -74
  73. package/src/components/next-image/types.ts +1 -1
  74. package/src/components/pagination/index.tsx +91 -91
  75. package/src/components/pagination/types.ts +6 -6
  76. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  77. package/src/components/radio-button/index.tsx +75 -75
  78. package/src/components/radio-button/types.ts +21 -21
  79. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  80. package/src/components/see-more/index.tsx +44 -44
  81. package/src/components/see-more/types.ts +4 -4
  82. package/src/components/select/Select.stories.tsx +411 -411
  83. package/src/components/select/index.tsx +155 -155
  84. package/src/components/select/types.ts +36 -36
  85. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  86. package/src/components/select-plan-button/index.tsx +63 -63
  87. package/src/components/select-plan-button/types.ts +17 -17
  88. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  89. package/src/components/skeleton/index.tsx +61 -61
  90. package/src/components/skeleton/types.ts +4 -4
  91. package/src/components/spinner/Spinner.stories.tsx +335 -335
  92. package/src/components/spinner/index.tsx +44 -44
  93. package/src/components/spinner/types.ts +5 -5
  94. package/src/components/text/Text.stories.tsx +321 -321
  95. package/src/components/text/index.tsx +25 -25
  96. package/src/components/text/types.ts +45 -45
  97. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  98. package/src/components/tooltip/index.tsx +74 -74
  99. package/src/components/tooltip/types.ts +7 -7
  100. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  101. package/src/components/view-cart-button/index.tsx +42 -42
  102. package/src/components/view-cart-button/types.ts +5 -5
  103. package/src/contentful/blocks/accordion/Accordion.stories.mocks.tsx +128 -128
  104. package/src/contentful/blocks/accordion/Accordion.stories.tsx +98 -98
  105. package/src/contentful/blocks/accordion/index.tsx +112 -112
  106. package/src/contentful/blocks/accordion/types.ts +34 -34
  107. package/src/contentful/blocks/address-input-banner/index.tsx +52 -52
  108. package/src/contentful/blocks/address-input-banner/types.ts +14 -14
  109. package/src/contentful/blocks/anchored-bottom-banner/index.tsx +181 -181
  110. package/src/contentful/blocks/anchored-bottom-banner/types.ts +13 -13
  111. package/src/contentful/blocks/blogs-grid/BlogGrid.stories.mocks.tsx +144 -144
  112. package/src/contentful/blocks/blogs-grid/BlogGrid.stories.tsx +156 -156
  113. package/src/contentful/blocks/blogs-grid/index.tsx +134 -134
  114. package/src/contentful/blocks/blogs-grid/types.ts +26 -26
  115. package/src/contentful/blocks/blogs-grid-base/index.tsx +119 -119
  116. package/src/contentful/blocks/blogs-grid-base/types.ts +36 -36
  117. package/src/contentful/blocks/breadcrumbs/BreadcrumbNavigation.stories.tsx +147 -147
  118. package/src/contentful/blocks/breadcrumbs/index.tsx +95 -95
  119. package/src/contentful/blocks/breadcrumbs/types.ts +8 -8
  120. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  121. package/src/contentful/blocks/button/index.tsx +131 -131
  122. package/src/contentful/blocks/button/types.ts +39 -39
  123. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  124. package/src/contentful/blocks/callout/index.tsx +277 -279
  125. package/src/contentful/blocks/callout/types.ts +78 -78
  126. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  127. package/src/contentful/blocks/cards/blog-card/index.tsx +129 -129
  128. package/src/contentful/blocks/cards/blog-card/types.ts +34 -34
  129. package/src/contentful/blocks/cards/floating-image-card/index.tsx +119 -119
  130. package/src/contentful/blocks/cards/floating-image-card/types.ts +30 -30
  131. package/src/contentful/blocks/cards/full-image-card/index.tsx +130 -130
  132. package/src/contentful/blocks/cards/full-image-card/types.ts +29 -29
  133. package/src/contentful/blocks/cards/index.tsx +13 -13
  134. package/src/contentful/blocks/cards/product-card/index.tsx +251 -251
  135. package/src/contentful/blocks/cards/product-card/types.ts +28 -28
  136. package/src/contentful/blocks/cards/simple-card/index.tsx +325 -325
  137. package/src/contentful/blocks/cards/simple-card/types.ts +71 -71
  138. package/src/contentful/blocks/cards/testimonial-card/index.tsx +90 -90
  139. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  140. package/src/contentful/blocks/cards/types.ts +1 -1
  141. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  142. package/src/contentful/blocks/carousel/helper.tsx +494 -494
  143. package/src/contentful/blocks/carousel/index.tsx +87 -87
  144. package/src/contentful/blocks/carousel/types.ts +145 -145
  145. package/src/contentful/blocks/cart-retention-banner/index.tsx +109 -109
  146. package/src/contentful/blocks/cart-retention-banner/types.ts +11 -11
  147. package/src/contentful/blocks/comparison-table/index.tsx +29 -29
  148. package/src/contentful/blocks/comparison-table/types.ts +6 -6
  149. package/src/contentful/blocks/cookiebanner/index.tsx +146 -146
  150. package/src/contentful/blocks/cookiebanner/type.ts +7 -7
  151. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  152. package/src/contentful/blocks/cta-callout/index.tsx +73 -71
  153. package/src/contentful/blocks/cta-callout/types.ts +26 -26
  154. package/src/contentful/blocks/dynamic-tabs/index.tsx +204 -204
  155. package/src/contentful/blocks/dynamic-tabs/types.ts +21 -21
  156. package/src/contentful/blocks/email-input-block/index.tsx +116 -116
  157. package/src/contentful/blocks/email-input-block/types.ts +16 -16
  158. package/src/contentful/blocks/find-kinetic/FindKinetic.stories.tsx +23 -23
  159. package/src/contentful/blocks/find-kinetic/index.tsx +130 -130
  160. package/src/contentful/blocks/find-kinetic/types.ts +19 -19
  161. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  162. package/src/contentful/blocks/floating-banner/index.tsx +97 -97
  163. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  164. package/src/contentful/blocks/footer/Footer.stories.tsx +317 -317
  165. package/src/contentful/blocks/footer/index.tsx +91 -91
  166. package/src/contentful/blocks/footer/types.ts +13 -13
  167. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  168. package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
  169. package/src/contentful/blocks/image-promo-bar/index.tsx +246 -246
  170. package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
  171. package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
  172. package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
  173. package/src/contentful/blocks/modal/constants.ts +53 -53
  174. package/src/contentful/blocks/modal/index.tsx +107 -107
  175. package/src/contentful/blocks/modal/types.ts +12 -12
  176. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +139 -139
  177. package/src/contentful/blocks/navigation/index.tsx +568 -568
  178. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +82 -82
  179. package/src/contentful/blocks/navigation/types.ts +71 -71
  180. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  181. package/src/contentful/blocks/primary-hero/index.tsx +236 -236
  182. package/src/contentful/blocks/primary-hero/types.ts +37 -37
  183. package/src/contentful/blocks/search-block/index.tsx +90 -90
  184. package/src/contentful/blocks/search-block/types.ts +15 -15
  185. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  186. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  187. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  188. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  189. package/src/contentful/blocks/text/index.tsx +12 -12
  190. package/src/contentful/blocks/text/types.ts +1 -1
  191. package/src/contentful/index.ts +105 -105
  192. package/src/hooks/contentful/use-contentful-rich-text.tsx +309 -309
  193. package/src/hooks/contentful/use-processed-check-list.ts +63 -63
  194. package/src/hooks/use-body-scroll-lock.ts +34 -34
  195. package/src/hooks/use-carousel-swipe.ts +264 -264
  196. package/src/hooks/use-outside-click.ts +17 -17
  197. package/src/index.ts +107 -107
  198. package/src/next/index.ts +5 -5
  199. package/src/setupTests.ts +46 -46
  200. package/src/stories/DocsTemplate.tsx +24 -24
  201. package/src/styles/globals.css +343 -343
  202. package/src/types/global.d.ts +9 -9
  203. package/src/types/micro-components.ts +99 -99
  204. package/src/types/utm.ts +49 -49
  205. package/src/utils/contentful/to-document.ts +24 -24
  206. package/src/utils/cookie.ts +84 -84
  207. package/src/utils/cx.ts +49 -49
  208. package/src/utils/index.ts +41 -41
  209. package/src/utils/speed-card-bg.ts +24 -24
  210. package/src/utils/utm.ts +221 -221
@@ -1,230 +1,230 @@
1
- import { Accordion } from "./index";
2
-
3
- import { DocsPage } from "@shared/stories/DocsTemplate";
4
- import type { Meta, StoryObj } from "@storybook/react";
5
-
6
- const meta: Meta<typeof Accordion> = {
7
- title: "Components/Accordion",
8
- component: Accordion,
9
- tags: ["autodocs"],
10
- parameters: {
11
- layout: "centered",
12
- docs: {
13
- page: DocsPage,
14
- description: {
15
- component:
16
- "A collapsible accordion component that can expand and collapse content sections with smooth animations.",
17
- },
18
- },
19
- },
20
- argTypes: {
21
- title: {
22
- control: { type: "text" },
23
- description: "Title text displayed in the accordion header",
24
- },
25
- defaultOpen: {
26
- control: { type: "boolean" },
27
- description: "Whether the accordion is open by default",
28
- },
29
- containerClassName: {
30
- control: { type: "text" },
31
- description: "Additional CSS classes for the container",
32
- },
33
- titleClassName: {
34
- control: { type: "text" },
35
- description: "Additional CSS classes for the title",
36
- },
37
- className: {
38
- control: { type: "text" },
39
- description: "Additional CSS classes for the content area",
40
- },
41
- buttonClassName: {
42
- control: { type: "text" },
43
- description: "Additional CSS classes for the button",
44
- },
45
- },
46
- args: {
47
- title: "Accordion Title",
48
- defaultOpen: false,
49
- children:
50
- "This is the accordion content that can be expanded or collapsed.",
51
- },
52
- };
53
-
54
- export default meta;
55
- type Story = StoryObj<typeof meta>;
56
-
57
- // Default accordion
58
- export const Default: Story = {
59
- args: {},
60
- };
61
-
62
- // Accordion with content
63
- export const WithContent: Story = {
64
- args: {
65
- title: "Frequently Asked Questions",
66
- children: (
67
- <div className="space-y-2">
68
- <p className="body2 text-text">
69
- This accordion contains detailed information that can be expanded or
70
- collapsed by clicking the header.
71
- </p>
72
- <p className="body3 text-text-secondary">
73
- You can include any content here, such as text, images, forms, or
74
- other components.
75
- </p>
76
- </div>
77
- ),
78
- },
79
- };
80
-
81
- // Default open accordion
82
- export const DefaultOpen: Story = {
83
- args: {
84
- title: "Open by Default",
85
- defaultOpen: true,
86
- children: (
87
- <div className="space-y-2">
88
- <p className="body2 text-text">
89
- This accordion is open by default when the page loads.
90
- </p>
91
- <p className="body3 text-text-secondary">
92
- Use the defaultOpen prop to control the initial state.
93
- </p>
94
- </div>
95
- ),
96
- },
97
- };
98
-
99
- // Multiple accordions
100
- export const Multiple: Story = {
101
- render: () => (
102
- <div className="max-w-2xl w-full space-y-4">
103
- <Accordion title="First Section">
104
- <p className="body2 text-text">
105
- Content for the first accordion section.
106
- </p>
107
- </Accordion>
108
- <Accordion title="Second Section" defaultOpen>
109
- <p className="body2 text-text">
110
- Content for the second accordion section. This one is open by default.
111
- </p>
112
- </Accordion>
113
- <Accordion title="Third Section">
114
- <p className="body2 text-text">
115
- Content for the third accordion section.
116
- </p>
117
- </Accordion>
118
- </div>
119
- ),
120
- parameters: {
121
- docs: {
122
- description: {
123
- story:
124
- "Multiple accordions used together to create an FAQ or content section.",
125
- },
126
- },
127
- },
128
- };
129
-
130
- // Custom styling
131
- export const CustomStyling: Story = {
132
- args: {
133
- title: "Custom Styled Accordion",
134
- containerClassName: "border-2 border-border-brand",
135
- titleClassName: "text-text-brand font-bold",
136
- buttonClassName: "bg-surface-secondary",
137
- className: "bg-surface-tertiary",
138
- children: (
139
- <div className="space-y-2">
140
- <p className="body2 text-text">
141
- This accordion has custom styling applied to different parts.
142
- </p>
143
- <ul className="list-disc space-y-1 pl-5">
144
- <li className="body3 text-text-secondary">Custom container border</li>
145
- <li className="body3 text-text-secondary">Custom title styling</li>
146
- <li className="body3 text-text-secondary">
147
- Custom button background
148
- </li>
149
- <li className="body3 text-text-secondary">
150
- Custom content background
151
- </li>
152
- </ul>
153
- </div>
154
- ),
155
- },
156
- };
157
-
158
- // Long content
159
- export const LongContent: Story = {
160
- args: {
161
- title: "Accordion with Long Content",
162
- children: (
163
- <div className="space-y-4">
164
- <p className="body2 text-text">
165
- This accordion demonstrates how it handles longer content sections.
166
- The content area will expand to accommodate all the content, and
167
- scrolling will be handled naturally within the page.
168
- </p>
169
- <div className="space-y-2">
170
- <h4 className="subheading2 text-text">Subsection 1</h4>
171
- <p className="body3 text-text-secondary">
172
- Additional details and information can be placed here.
173
- </p>
174
- </div>
175
- <div className="space-y-2">
176
- <h4 className="subheading2 text-text">Subsection 2</h4>
177
- <p className="body3 text-text-secondary">
178
- More content to demonstrate scrolling behavior.
179
- </p>
180
- </div>
181
- <div className="space-y-2">
182
- <h4 className="subheading2 text-text">Subsection 3</h4>
183
- <p className="body3 text-text-secondary">
184
- Even more content to show how the accordion handles extended content
185
- areas.
186
- </p>
187
- </div>
188
- </div>
189
- ),
190
- },
191
- };
192
-
193
- // All variants showcase
194
- export const AllVariants: Story = {
195
- render: () => (
196
- <div className="max-w-2xl w-full space-y-4">
197
- <div>
198
- <h3 className="mb-3 text-lg font-semibold">Default State</h3>
199
- <Accordion title="Closed Accordion">
200
- <p className="body2 text-text">This accordion starts closed.</p>
201
- </Accordion>
202
- </div>
203
- <div>
204
- <h3 className="mb-3 text-lg font-semibold">Open by Default</h3>
205
- <Accordion title="Open Accordion" defaultOpen>
206
- <p className="body2 text-text">This accordion starts open.</p>
207
- </Accordion>
208
- </div>
209
- <div>
210
- <h3 className="mb-3 text-lg font-semibold">Custom Styled</h3>
211
- <Accordion
212
- title="Styled Accordion"
213
- containerClassName="border-2 border-border-brand"
214
- titleClassName="text-text-brand"
215
- >
216
- <p className="body2 text-text">
217
- This accordion has custom styling applied.
218
- </p>
219
- </Accordion>
220
- </div>
221
- </div>
222
- ),
223
- parameters: {
224
- docs: {
225
- description: {
226
- story: "Showcase of all accordion variants and states.",
227
- },
228
- },
229
- },
230
- };
1
+ import { Accordion } from "./index";
2
+
3
+ import { DocsPage } from "@shared/stories/DocsTemplate";
4
+ import type { Meta, StoryObj } from "@storybook/react";
5
+
6
+ const meta: Meta<typeof Accordion> = {
7
+ title: "Components/Accordion",
8
+ component: Accordion,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ layout: "centered",
12
+ docs: {
13
+ page: DocsPage,
14
+ description: {
15
+ component:
16
+ "A collapsible accordion component that can expand and collapse content sections with smooth animations.",
17
+ },
18
+ },
19
+ },
20
+ argTypes: {
21
+ title: {
22
+ control: { type: "text" },
23
+ description: "Title text displayed in the accordion header",
24
+ },
25
+ defaultOpen: {
26
+ control: { type: "boolean" },
27
+ description: "Whether the accordion is open by default",
28
+ },
29
+ containerClassName: {
30
+ control: { type: "text" },
31
+ description: "Additional CSS classes for the container",
32
+ },
33
+ titleClassName: {
34
+ control: { type: "text" },
35
+ description: "Additional CSS classes for the title",
36
+ },
37
+ className: {
38
+ control: { type: "text" },
39
+ description: "Additional CSS classes for the content area",
40
+ },
41
+ buttonClassName: {
42
+ control: { type: "text" },
43
+ description: "Additional CSS classes for the button",
44
+ },
45
+ },
46
+ args: {
47
+ title: "Accordion Title",
48
+ defaultOpen: false,
49
+ children:
50
+ "This is the accordion content that can be expanded or collapsed.",
51
+ },
52
+ };
53
+
54
+ export default meta;
55
+ type Story = StoryObj<typeof meta>;
56
+
57
+ // Default accordion
58
+ export const Default: Story = {
59
+ args: {},
60
+ };
61
+
62
+ // Accordion with content
63
+ export const WithContent: Story = {
64
+ args: {
65
+ title: "Frequently Asked Questions",
66
+ children: (
67
+ <div className="space-y-2">
68
+ <p className="body2 text-text">
69
+ This accordion contains detailed information that can be expanded or
70
+ collapsed by clicking the header.
71
+ </p>
72
+ <p className="body3 text-text-secondary">
73
+ You can include any content here, such as text, images, forms, or
74
+ other components.
75
+ </p>
76
+ </div>
77
+ ),
78
+ },
79
+ };
80
+
81
+ // Default open accordion
82
+ export const DefaultOpen: Story = {
83
+ args: {
84
+ title: "Open by Default",
85
+ defaultOpen: true,
86
+ children: (
87
+ <div className="space-y-2">
88
+ <p className="body2 text-text">
89
+ This accordion is open by default when the page loads.
90
+ </p>
91
+ <p className="body3 text-text-secondary">
92
+ Use the defaultOpen prop to control the initial state.
93
+ </p>
94
+ </div>
95
+ ),
96
+ },
97
+ };
98
+
99
+ // Multiple accordions
100
+ export const Multiple: Story = {
101
+ render: () => (
102
+ <div className="max-w-2xl w-full space-y-4">
103
+ <Accordion title="First Section">
104
+ <p className="body2 text-text">
105
+ Content for the first accordion section.
106
+ </p>
107
+ </Accordion>
108
+ <Accordion title="Second Section" defaultOpen>
109
+ <p className="body2 text-text">
110
+ Content for the second accordion section. This one is open by default.
111
+ </p>
112
+ </Accordion>
113
+ <Accordion title="Third Section">
114
+ <p className="body2 text-text">
115
+ Content for the third accordion section.
116
+ </p>
117
+ </Accordion>
118
+ </div>
119
+ ),
120
+ parameters: {
121
+ docs: {
122
+ description: {
123
+ story:
124
+ "Multiple accordions used together to create an FAQ or content section.",
125
+ },
126
+ },
127
+ },
128
+ };
129
+
130
+ // Custom styling
131
+ export const CustomStyling: Story = {
132
+ args: {
133
+ title: "Custom Styled Accordion",
134
+ containerClassName: "border-2 border-border-brand",
135
+ titleClassName: "text-text-brand font-bold",
136
+ buttonClassName: "bg-surface-secondary",
137
+ className: "bg-surface-tertiary",
138
+ children: (
139
+ <div className="space-y-2">
140
+ <p className="body2 text-text">
141
+ This accordion has custom styling applied to different parts.
142
+ </p>
143
+ <ul className="list-disc space-y-1 pl-5">
144
+ <li className="body3 text-text-secondary">Custom container border</li>
145
+ <li className="body3 text-text-secondary">Custom title styling</li>
146
+ <li className="body3 text-text-secondary">
147
+ Custom button background
148
+ </li>
149
+ <li className="body3 text-text-secondary">
150
+ Custom content background
151
+ </li>
152
+ </ul>
153
+ </div>
154
+ ),
155
+ },
156
+ };
157
+
158
+ // Long content
159
+ export const LongContent: Story = {
160
+ args: {
161
+ title: "Accordion with Long Content",
162
+ children: (
163
+ <div className="space-y-4">
164
+ <p className="body2 text-text">
165
+ This accordion demonstrates how it handles longer content sections.
166
+ The content area will expand to accommodate all the content, and
167
+ scrolling will be handled naturally within the page.
168
+ </p>
169
+ <div className="space-y-2">
170
+ <h4 className="subheading2 text-text">Subsection 1</h4>
171
+ <p className="body3 text-text-secondary">
172
+ Additional details and information can be placed here.
173
+ </p>
174
+ </div>
175
+ <div className="space-y-2">
176
+ <h4 className="subheading2 text-text">Subsection 2</h4>
177
+ <p className="body3 text-text-secondary">
178
+ More content to demonstrate scrolling behavior.
179
+ </p>
180
+ </div>
181
+ <div className="space-y-2">
182
+ <h4 className="subheading2 text-text">Subsection 3</h4>
183
+ <p className="body3 text-text-secondary">
184
+ Even more content to show how the accordion handles extended content
185
+ areas.
186
+ </p>
187
+ </div>
188
+ </div>
189
+ ),
190
+ },
191
+ };
192
+
193
+ // All variants showcase
194
+ export const AllVariants: Story = {
195
+ render: () => (
196
+ <div className="max-w-2xl w-full space-y-4">
197
+ <div>
198
+ <h3 className="mb-3 text-lg font-semibold">Default State</h3>
199
+ <Accordion title="Closed Accordion">
200
+ <p className="body2 text-text">This accordion starts closed.</p>
201
+ </Accordion>
202
+ </div>
203
+ <div>
204
+ <h3 className="mb-3 text-lg font-semibold">Open by Default</h3>
205
+ <Accordion title="Open Accordion" defaultOpen>
206
+ <p className="body2 text-text">This accordion starts open.</p>
207
+ </Accordion>
208
+ </div>
209
+ <div>
210
+ <h3 className="mb-3 text-lg font-semibold">Custom Styled</h3>
211
+ <Accordion
212
+ title="Styled Accordion"
213
+ containerClassName="border-2 border-border-brand"
214
+ titleClassName="text-text-brand"
215
+ >
216
+ <p className="body2 text-text">
217
+ This accordion has custom styling applied.
218
+ </p>
219
+ </Accordion>
220
+ </div>
221
+ </div>
222
+ ),
223
+ parameters: {
224
+ docs: {
225
+ description: {
226
+ story: "Showcase of all accordion variants and states.",
227
+ },
228
+ },
229
+ },
230
+ };
@@ -1,70 +1,70 @@
1
- "use client";
2
-
3
- import { useEffect, useState } from "react";
4
-
5
- import { AccordionProps } from "@shared/components/accordion/types";
6
- import { Button } from "@shared/components/button";
7
- import { Collapse } from "@shared/components/collapse";
8
- import { MaterialIcon } from "@shared/components/material-icon";
9
- import { cx } from "@shared/utils";
10
-
11
- export const Accordion: React.FC<AccordionProps> = props => {
12
- const {
13
- title,
14
- defaultOpen,
15
- children,
16
- containerClassName,
17
- titleClassName,
18
- className,
19
- buttonClassName,
20
- iconClassName,
21
- openOnlyOnDesktop,
22
- borderRadiusNone = false,
23
- } = props;
24
- const [open, setOpen] = useState<boolean>(Boolean(false));
25
-
26
- useEffect(() => {
27
- // Only execute responsive logic if the prop is true
28
- if (openOnlyOnDesktop) {
29
- const isDesktop = window.innerWidth >= 1024;
30
- setOpen(isDesktop);
31
- } else {
32
- // Otherwise, fall back to standard defaultOpen behavior
33
- setOpen(Boolean(defaultOpen));
34
- }
35
- }, [openOnlyOnDesktop, defaultOpen]);
36
-
37
- return (
38
- <div
39
- className={cx(
40
- borderRadiusNone ? "rounded-none border" : "rounded-surface-xs border",
41
- containerClassName
42
- )}
43
- >
44
- <Button
45
- type="button"
46
- className={cx(
47
- borderRadiusNone ? "rounded-none" : "rounded-t-surface-xs",
48
- "flex w-full items-center justify-between gap-4 px-4 py-3 text-left",
49
- buttonClassName
50
- )}
51
- onClick={() => setOpen(v => !v)}
52
- >
53
- <span className={cx("label5 flex-1", titleClassName)}>{title}</span>
54
- <MaterialIcon
55
- className={cx("flex-shrink-0", iconClassName)}
56
- name={open ? "keyboard_arrow_up" : "keyboard_arrow_down"}
57
- fill={1}
58
- size={24}
59
- />
60
- </Button>
61
- <Collapse open={open}>
62
- <div className={cx("px-4 py-4", className)}>{children}</div>
63
- </Collapse>
64
- </div>
65
- );
66
- };
67
-
68
- Accordion.displayName = "Accordion";
69
-
70
- export type { AccordionProps };
1
+ "use client";
2
+
3
+ import { useEffect, useState } from "react";
4
+
5
+ import { AccordionProps } from "@shared/components/accordion/types";
6
+ import { Button } from "@shared/components/button";
7
+ import { Collapse } from "@shared/components/collapse";
8
+ import { MaterialIcon } from "@shared/components/material-icon";
9
+ import { cx } from "@shared/utils";
10
+
11
+ export const Accordion: React.FC<AccordionProps> = props => {
12
+ const {
13
+ title,
14
+ defaultOpen,
15
+ children,
16
+ containerClassName,
17
+ titleClassName,
18
+ className,
19
+ buttonClassName,
20
+ iconClassName,
21
+ openOnlyOnDesktop,
22
+ borderRadiusNone = false,
23
+ } = props;
24
+ const [open, setOpen] = useState<boolean>(Boolean(false));
25
+
26
+ useEffect(() => {
27
+ // Only execute responsive logic if the prop is true
28
+ if (openOnlyOnDesktop) {
29
+ const isDesktop = window.innerWidth >= 1024;
30
+ setOpen(isDesktop);
31
+ } else {
32
+ // Otherwise, fall back to standard defaultOpen behavior
33
+ setOpen(Boolean(defaultOpen));
34
+ }
35
+ }, [openOnlyOnDesktop, defaultOpen]);
36
+
37
+ return (
38
+ <div
39
+ className={cx(
40
+ borderRadiusNone ? "rounded-none border" : "rounded-surface-xs border",
41
+ containerClassName
42
+ )}
43
+ >
44
+ <Button
45
+ type="button"
46
+ className={cx(
47
+ borderRadiusNone ? "rounded-none" : "rounded-t-surface-xs",
48
+ "flex w-full items-center justify-between gap-4 px-4 py-3 text-left",
49
+ buttonClassName
50
+ )}
51
+ onClick={() => setOpen(v => !v)}
52
+ >
53
+ <span className={cx("label5 flex-1", titleClassName)}>{title}</span>
54
+ <MaterialIcon
55
+ className={cx("flex-shrink-0", iconClassName)}
56
+ name={open ? "keyboard_arrow_up" : "keyboard_arrow_down"}
57
+ fill={1}
58
+ size={24}
59
+ />
60
+ </Button>
61
+ <Collapse open={open}>
62
+ <div className={cx("px-4 py-4", className)}>{children}</div>
63
+ </Collapse>
64
+ </div>
65
+ );
66
+ };
67
+
68
+ Accordion.displayName = "Accordion";
69
+
70
+ export type { AccordionProps };
@@ -1,12 +1,12 @@
1
- export type AccordionProps = {
2
- title: string;
3
- defaultOpen?: boolean;
4
- openOnlyOnDesktop?: boolean;
5
- containerClassName?: string;
6
- children: React.ReactNode;
7
- titleClassName?: string;
8
- className?: string;
9
- buttonClassName?: string;
10
- iconClassName?: string;
11
- borderRadiusNone?: boolean;
12
- };
1
+ export type AccordionProps = {
2
+ title: string;
3
+ defaultOpen?: boolean;
4
+ openOnlyOnDesktop?: boolean;
5
+ containerClassName?: string;
6
+ children: React.ReactNode;
7
+ titleClassName?: string;
8
+ className?: string;
9
+ buttonClassName?: string;
10
+ iconClassName?: string;
11
+ borderRadiusNone?: boolean;
12
+ };