@windstream/react-shared-components 0.1.92 → 0.1.94

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 (293) hide show
  1. package/README.md +635 -635
  2. package/dist/contentful/index.d.ts +1 -0
  3. package/dist/contentful/index.esm.js +2 -2
  4. package/dist/contentful/index.esm.js.map +1 -1
  5. package/dist/contentful/index.js +3 -3
  6. package/dist/contentful/index.js.map +1 -1
  7. package/dist/core.d.ts +5 -5
  8. package/dist/index.d.ts +2 -2
  9. package/dist/index.esm.js +1 -1
  10. package/dist/index.esm.js.map +1 -1
  11. package/dist/index.js +1 -1
  12. package/dist/index.js.map +1 -1
  13. package/dist/styles.css +1 -1
  14. package/dist/utils/index.esm.js +1 -1
  15. package/dist/utils/index.js +1 -1
  16. package/package.json +191 -185
  17. package/src/components/accordion/Accordion.stories.tsx +230 -230
  18. package/src/components/accordion/index.test.tsx +270 -0
  19. package/src/components/accordion/index.tsx +70 -70
  20. package/src/components/accordion/types.ts +12 -12
  21. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  22. package/src/components/alert-card/index.test.tsx +152 -0
  23. package/src/components/alert-card/index.tsx +41 -41
  24. package/src/components/alert-card/types.ts +13 -13
  25. package/src/components/animation-wrapper/index.test.tsx +424 -0
  26. package/src/components/animation-wrapper/index.tsx +129 -129
  27. package/src/components/animation-wrapper/types.ts +11 -11
  28. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  29. package/src/components/brand-button/helpers.ts +35 -35
  30. package/src/components/brand-button/index.test.tsx +292 -0
  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.test.tsx +91 -0
  35. package/src/components/button/index.tsx +27 -27
  36. package/src/components/button/types.ts +14 -14
  37. package/src/components/call-button/CallButton.stories.tsx +324 -324
  38. package/src/components/call-button/index.test.tsx +260 -0
  39. package/src/components/call-button/index.tsx +106 -106
  40. package/src/components/call-button/types.ts +16 -16
  41. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  42. package/src/components/checkbox/index.test.tsx +252 -0
  43. package/src/components/checkbox/index.tsx +197 -197
  44. package/src/components/checkbox/types.ts +27 -27
  45. package/src/components/checklist/Checklist.stories.tsx +150 -150
  46. package/src/components/checklist/index.test.tsx +231 -0
  47. package/src/components/checklist/index.tsx +96 -61
  48. package/src/components/checklist/types.ts +23 -17
  49. package/src/components/collapse/Collapse.stories.tsx +255 -255
  50. package/src/components/collapse/index.test.tsx +277 -0
  51. package/src/components/collapse/index.tsx +47 -46
  52. package/src/components/collapse/types.ts +6 -6
  53. package/src/components/divider/Divider.stories.tsx +205 -205
  54. package/src/components/divider/index.test.tsx +53 -0
  55. package/src/components/divider/index.tsx +22 -22
  56. package/src/components/divider/type.ts +3 -3
  57. package/src/components/image/Image.stories.tsx +113 -113
  58. package/src/components/image/index.test.tsx +174 -0
  59. package/src/components/image/index.tsx +25 -25
  60. package/src/components/image/types.ts +40 -40
  61. package/src/components/input/Input.stories.tsx +325 -325
  62. package/src/components/input/index.test.tsx +348 -0
  63. package/src/components/input/index.tsx +177 -177
  64. package/src/components/input/types.ts +37 -37
  65. package/src/components/link/Link.stories.tsx +163 -163
  66. package/src/components/link/index.test.tsx +199 -0
  67. package/src/components/link/index.tsx +116 -116
  68. package/src/components/link/types.ts +25 -25
  69. package/src/components/list/List.stories.tsx +272 -272
  70. package/src/components/list/index.test.tsx +166 -0
  71. package/src/components/list/index.tsx +88 -88
  72. package/src/components/list/list-item/index.tsx +38 -38
  73. package/src/components/list/list-item/types.ts +13 -13
  74. package/src/components/list/types.ts +29 -29
  75. package/src/components/material-icon/MaterialIcon.stories.tsx +322 -322
  76. package/src/components/material-icon/constants.ts +99 -99
  77. package/src/components/material-icon/index.test.tsx +130 -0
  78. package/src/components/material-icon/index.tsx +47 -47
  79. package/src/components/material-icon/types.ts +31 -31
  80. package/src/components/modal/Modal.stories.tsx +171 -171
  81. package/src/components/modal/index.test.tsx +310 -0
  82. package/src/components/modal/index.tsx +164 -164
  83. package/src/components/modal/types.ts +24 -24
  84. package/src/components/next-image/index.test.tsx +406 -0
  85. package/src/components/next-image/index.tsx +74 -74
  86. package/src/components/next-image/types.ts +1 -1
  87. package/src/components/pagination/index.test.tsx +521 -0
  88. package/src/components/pagination/index.tsx +91 -91
  89. package/src/components/pagination/types.ts +6 -6
  90. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  91. package/src/components/radio-button/index.test.tsx +151 -0
  92. package/src/components/radio-button/index.tsx +75 -75
  93. package/src/components/radio-button/types.ts +21 -21
  94. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  95. package/src/components/see-more/index.test.tsx +96 -0
  96. package/src/components/see-more/index.tsx +44 -44
  97. package/src/components/see-more/types.ts +4 -4
  98. package/src/components/select/Select.stories.tsx +411 -411
  99. package/src/components/select/index.test.tsx +256 -0
  100. package/src/components/select/index.tsx +155 -155
  101. package/src/components/select/types.ts +36 -36
  102. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  103. package/src/components/select-plan-button/index.test.tsx +173 -0
  104. package/src/components/select-plan-button/index.tsx +63 -63
  105. package/src/components/select-plan-button/types.ts +17 -17
  106. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  107. package/src/components/skeleton/index.test.tsx +74 -0
  108. package/src/components/skeleton/index.tsx +61 -61
  109. package/src/components/skeleton/types.ts +4 -4
  110. package/src/components/spinner/Spinner.stories.tsx +335 -335
  111. package/src/components/spinner/index.test.tsx +76 -0
  112. package/src/components/spinner/index.tsx +44 -44
  113. package/src/components/spinner/types.ts +5 -5
  114. package/src/components/text/Text.stories.tsx +321 -321
  115. package/src/components/text/index.test.tsx +65 -0
  116. package/src/components/text/index.tsx +25 -25
  117. package/src/components/text/types.ts +45 -45
  118. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  119. package/src/components/tooltip/index.test.tsx +50 -0
  120. package/src/components/tooltip/index.tsx +74 -74
  121. package/src/components/tooltip/types.ts +7 -7
  122. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  123. package/src/components/view-cart-button/index.test.tsx +57 -0
  124. package/src/components/view-cart-button/index.tsx +42 -42
  125. package/src/components/view-cart-button/types.ts +5 -5
  126. package/src/contentful/blocks/accordion/Accordion.stories.mocks.tsx +128 -128
  127. package/src/contentful/blocks/accordion/Accordion.stories.tsx +98 -98
  128. package/src/contentful/blocks/accordion/index.test.tsx +218 -0
  129. package/src/contentful/blocks/accordion/index.tsx +114 -112
  130. package/src/contentful/blocks/accordion/types.ts +34 -34
  131. package/src/contentful/blocks/address-input-banner/index.test.tsx +132 -0
  132. package/src/contentful/blocks/address-input-banner/index.tsx +52 -52
  133. package/src/contentful/blocks/address-input-banner/types.ts +14 -14
  134. package/src/contentful/blocks/anchored-bottom-banner/index.test.tsx +287 -0
  135. package/src/contentful/blocks/anchored-bottom-banner/index.tsx +181 -181
  136. package/src/contentful/blocks/anchored-bottom-banner/types.ts +13 -13
  137. package/src/contentful/blocks/blogs-grid/BlogGrid.stories.mocks.tsx +144 -144
  138. package/src/contentful/blocks/blogs-grid/BlogGrid.stories.tsx +157 -156
  139. package/src/contentful/blocks/blogs-grid/index.test.tsx +355 -0
  140. package/src/contentful/blocks/blogs-grid/index.tsx +134 -134
  141. package/src/contentful/blocks/blogs-grid/types.ts +26 -26
  142. package/src/contentful/blocks/blogs-grid-base/index.test.tsx +274 -0
  143. package/src/contentful/blocks/blogs-grid-base/index.tsx +119 -119
  144. package/src/contentful/blocks/blogs-grid-base/types.ts +36 -36
  145. package/src/contentful/blocks/breadcrumbs/BreadcrumbNavigation.stories.tsx +147 -147
  146. package/src/contentful/blocks/breadcrumbs/index.test.tsx +281 -0
  147. package/src/contentful/blocks/breadcrumbs/index.tsx +95 -95
  148. package/src/contentful/blocks/breadcrumbs/types.ts +8 -8
  149. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  150. package/src/contentful/blocks/button/index.test.tsx +339 -0
  151. package/src/contentful/blocks/button/index.tsx +131 -131
  152. package/src/contentful/blocks/button/types.ts +39 -39
  153. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  154. package/src/contentful/blocks/callout/index.test.tsx +539 -0
  155. package/src/contentful/blocks/callout/index.tsx +277 -277
  156. package/src/contentful/blocks/callout/types.ts +78 -78
  157. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  158. package/src/contentful/blocks/cards/blog-card/index.test.tsx +218 -0
  159. package/src/contentful/blocks/cards/blog-card/index.tsx +129 -129
  160. package/src/contentful/blocks/cards/blog-card/types.ts +34 -34
  161. package/src/contentful/blocks/cards/floating-image-card/index.test.tsx +201 -0
  162. package/src/contentful/blocks/cards/floating-image-card/index.tsx +119 -119
  163. package/src/contentful/blocks/cards/floating-image-card/types.ts +30 -30
  164. package/src/contentful/blocks/cards/full-image-card/index.test.tsx +216 -0
  165. package/src/contentful/blocks/cards/full-image-card/index.tsx +130 -130
  166. package/src/contentful/blocks/cards/full-image-card/types.ts +29 -29
  167. package/src/contentful/blocks/cards/index.test.tsx +39 -0
  168. package/src/contentful/blocks/cards/index.tsx +13 -13
  169. package/src/contentful/blocks/cards/product-card/index.test.tsx +263 -0
  170. package/src/contentful/blocks/cards/product-card/index.tsx +251 -251
  171. package/src/contentful/blocks/cards/product-card/types.ts +28 -28
  172. package/src/contentful/blocks/cards/simple-card/index.test.tsx +364 -0
  173. package/src/contentful/blocks/cards/simple-card/index.tsx +325 -325
  174. package/src/contentful/blocks/cards/simple-card/types.ts +71 -71
  175. package/src/contentful/blocks/cards/testimonial-card/index.test.tsx +180 -0
  176. package/src/contentful/blocks/cards/testimonial-card/index.tsx +90 -90
  177. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  178. package/src/contentful/blocks/cards/types.ts +1 -1
  179. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  180. package/src/contentful/blocks/carousel/helper.test.tsx +539 -0
  181. package/src/contentful/blocks/carousel/helper.tsx +494 -494
  182. package/src/contentful/blocks/carousel/index.test.tsx +308 -0
  183. package/src/contentful/blocks/carousel/index.tsx +87 -87
  184. package/src/contentful/blocks/carousel/types.test.ts +16 -0
  185. package/src/contentful/blocks/carousel/types.ts +145 -145
  186. package/src/contentful/blocks/cart-retention-banner/index.test.tsx +409 -0
  187. package/src/contentful/blocks/cart-retention-banner/index.tsx +109 -109
  188. package/src/contentful/blocks/cart-retention-banner/types.ts +11 -11
  189. package/src/contentful/blocks/comparison-table/index.test.tsx +114 -0
  190. package/src/contentful/blocks/comparison-table/index.tsx +29 -29
  191. package/src/contentful/blocks/comparison-table/types.ts +6 -6
  192. package/src/contentful/blocks/cookiebanner/index.test.tsx +277 -0
  193. package/src/contentful/blocks/cookiebanner/index.tsx +146 -146
  194. package/src/contentful/blocks/cookiebanner/type.ts +7 -7
  195. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  196. package/src/contentful/blocks/cta-callout/index.test.tsx +244 -0
  197. package/src/contentful/blocks/cta-callout/index.tsx +73 -73
  198. package/src/contentful/blocks/cta-callout/types.ts +26 -26
  199. package/src/contentful/blocks/dynamic-tabs/index.test.tsx +240 -0
  200. package/src/contentful/blocks/dynamic-tabs/index.tsx +204 -204
  201. package/src/contentful/blocks/dynamic-tabs/types.ts +21 -21
  202. package/src/contentful/blocks/email-input-block/index.test.tsx +213 -0
  203. package/src/contentful/blocks/email-input-block/index.tsx +121 -116
  204. package/src/contentful/blocks/email-input-block/types.ts +16 -16
  205. package/src/contentful/blocks/find-kinetic/FindKinetic.stories.tsx +23 -23
  206. package/src/contentful/blocks/find-kinetic/index.test.tsx +269 -0
  207. package/src/contentful/blocks/find-kinetic/index.tsx +138 -130
  208. package/src/contentful/blocks/find-kinetic/types.ts +20 -19
  209. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  210. package/src/contentful/blocks/floating-banner/index.test.tsx +246 -0
  211. package/src/contentful/blocks/floating-banner/index.tsx +97 -97
  212. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  213. package/src/contentful/blocks/footer/Footer.stories.tsx +317 -317
  214. package/src/contentful/blocks/footer/index.test.tsx +302 -0
  215. package/src/contentful/blocks/footer/index.tsx +91 -91
  216. package/src/contentful/blocks/footer/types.ts +13 -13
  217. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  218. package/src/contentful/blocks/image-promo-bar/helper.test.tsx +61 -0
  219. package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
  220. package/src/contentful/blocks/image-promo-bar/index.test.tsx +467 -0
  221. package/src/contentful/blocks/image-promo-bar/index.tsx +246 -246
  222. package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
  223. package/src/contentful/blocks/image-promo-bar/vimeo-embed.test.tsx +142 -0
  224. package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
  225. package/src/contentful/blocks/image-promo-bar/youtube-embed.test.tsx +104 -0
  226. package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
  227. package/src/contentful/blocks/modal/constants.ts +53 -53
  228. package/src/contentful/blocks/modal/index.test.tsx +209 -0
  229. package/src/contentful/blocks/modal/index.tsx +108 -108
  230. package/src/contentful/blocks/modal/types.ts +12 -12
  231. package/src/contentful/blocks/navigation/Navigation.stories.mocks.tsx +78 -0
  232. package/src/contentful/blocks/navigation/Navigation.stories.tsx +138 -0
  233. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.test.tsx +208 -0
  234. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +141 -139
  235. package/src/contentful/blocks/navigation/index.test.tsx +924 -0
  236. package/src/contentful/blocks/navigation/index.tsx +569 -568
  237. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.test.tsx +131 -0
  238. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +82 -82
  239. package/src/contentful/blocks/navigation/types.ts +71 -71
  240. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  241. package/src/contentful/blocks/primary-hero/index.test.tsx +286 -0
  242. package/src/contentful/blocks/primary-hero/index.tsx +239 -236
  243. package/src/contentful/blocks/primary-hero/types.ts +37 -37
  244. package/src/contentful/blocks/search-block/index.test.tsx +268 -0
  245. package/src/contentful/blocks/search-block/index.tsx +90 -90
  246. package/src/contentful/blocks/search-block/types.ts +15 -15
  247. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  248. package/src/contentful/blocks/shape-background-wrapper/index.test.tsx +284 -0
  249. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  250. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  251. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  252. package/src/contentful/blocks/text/index.test.tsx +36 -0
  253. package/src/contentful/blocks/text/index.tsx +12 -12
  254. package/src/contentful/blocks/text/types.ts +1 -1
  255. package/src/contentful/index.test.ts +45 -0
  256. package/src/contentful/index.ts +105 -105
  257. package/src/global-mocks/contentful/to-document.ts +25 -0
  258. package/src/global-mocks/cookie.ts +48 -0
  259. package/src/global-mocks/cx.ts +37 -0
  260. package/src/global-mocks/index.ts +89 -0
  261. package/src/global-mocks/speed-card-bg.ts +27 -0
  262. package/src/global-mocks/utm.ts +49 -0
  263. package/src/hooks/contentful/use-contentful-rich-text.test.tsx +1758 -0
  264. package/src/hooks/contentful/use-contentful-rich-text.tsx +309 -309
  265. package/src/hooks/contentful/use-processed-check-list.test.tsx +277 -0
  266. package/src/hooks/contentful/use-processed-check-list.ts +63 -63
  267. package/src/hooks/use-body-scroll-lock.test.ts +134 -0
  268. package/src/hooks/use-body-scroll-lock.ts +34 -34
  269. package/src/hooks/use-carousel-swipe.test.ts +393 -0
  270. package/src/hooks/use-carousel-swipe.ts +264 -264
  271. package/src/hooks/use-outside-click.test.ts +142 -0
  272. package/src/hooks/use-outside-click.ts +17 -17
  273. package/src/index.ts +107 -107
  274. package/src/next/index.test.ts +7 -0
  275. package/src/next/index.ts +5 -5
  276. package/src/setupTests.ts +52 -46
  277. package/src/stories/DocsTemplate.tsx +24 -24
  278. package/src/styles/globals.css +343 -343
  279. package/src/types/global.d.ts +9 -9
  280. package/src/types/micro-components.ts +99 -99
  281. package/src/types/utm.ts +49 -49
  282. package/src/utils/contentful/to-document.test.ts +85 -0
  283. package/src/utils/contentful/to-document.ts +24 -24
  284. package/src/utils/cookie.test.ts +180 -0
  285. package/src/utils/cookie.ts +84 -84
  286. package/src/utils/cx.test.ts +90 -0
  287. package/src/utils/cx.ts +49 -49
  288. package/src/utils/index.test.ts +115 -0
  289. package/src/utils/index.ts +41 -41
  290. package/src/utils/speed-card-bg.test.ts +46 -0
  291. package/src/utils/speed-card-bg.ts +24 -24
  292. package/src/utils/utm.test.ts +359 -0
  293. package/src/utils/utm.ts +221 -221
@@ -1,128 +1,128 @@
1
- import { AccordionItem } from "./types";
2
-
3
- /* ------------
4
- DEFAULT FAQs (3 – plain text only)
5
- --------------- */
6
-
7
- export const FAQ_ITEMS: AccordionItem[] = [
8
- {
9
- title: "How much speed do I need in my home?",
10
- description:
11
- "The amount of internet speed or bandwidth you need in your home significantly depends on your usage and the number of devices connected to the internet. Connected devices don’t only mean computers and tablets; they include TVs used for streaming, gaming consoles, smart watches, phones, home security cameras and doorbells, home assistants, baby monitors, wireless speakers, and more. Every connected device pulls from your home’s internet bandwidth.",
12
- },
13
- {
14
- title: "Do I qualify for any promotional offers?",
15
- description:
16
- "Be sure to register for updates, promotional offers, and special discounts in the form provided. You’ll be able to enjoy an improved internet experience and benefit from newer, faster, and more advanced fiber technology.",
17
- },
18
- {
19
- title: "How fast is Kinetic internet?",
20
- description:
21
- "Kinetic offers high internet speeds ranging from 200 Mbps up to Fiber Gig speeds of 1000 Mbps.",
22
- },
23
- ];
24
-
25
- /* --------------
26
- RICH TEXT FAQs (4 – JSX formatted)
27
- ----------------- */
28
-
29
- export const RICH_FAQ_ITEMS: AccordionItem[] = [
30
- {
31
- title: "How do I check my Windstream email?",
32
- description: (
33
- <>
34
- <p>
35
- <strong>Already have a windstream.net account?</strong>
36
- </p>
37
-
38
- <p>You can check your windstream.net emails in the following ways:</p>
39
-
40
- <ol className="ml-6 list-decimal">
41
- <li>
42
- Go to <strong>www.windstream.net</strong> and click{" "}
43
- <strong>Email</strong> in the top‑right of the menu bar.
44
- </li>
45
- <li>Use an email application on a smartphone.</li>
46
- <li>Use an email client on a computer.</li>
47
- </ol>
48
-
49
- <p className="mt-4">
50
- <strong>OR</strong>
51
- </p>
52
-
53
- <p>
54
- Log in to <strong>Go Kinetic</strong>, navigate to{" "}
55
- <strong>Other Services</strong>, then select{" "}
56
- <strong>View and Manage Email</strong>.
57
- </p>
58
-
59
- <p className="mt-4">
60
- <strong>Wanting to set up a new .net email account?</strong>
61
- </p>
62
-
63
- <ul className="ml-6 list-disc">
64
- <li>
65
- If you do not already have a windstream.net email account, new
66
- windstream.net email addresses are no longer being created.
67
- </li>
68
- <li>
69
- You can set up a free email account using platforms like{" "}
70
- <strong>Gmail</strong> or <strong>Yahoo</strong>.
71
- </li>
72
- </ul>
73
- </>
74
- ),
75
- },
76
- {
77
- title: "How much speed do I need in my home?",
78
- description: (
79
- <>
80
- <p>
81
- For a household with <strong>4+ internet users</strong> who use the
82
- web for online gaming, music and video streaming, uploading pictures
83
- and videos, as well as email and browsing, a{" "}
84
- <strong>1‑Gigabit plan</strong> would be best suited.
85
- </p>
86
-
87
- <p className="mt-4">
88
- This also supports multiple devices such as laptops, smartphones,
89
- tablets, and TVs connected to the home internet at the same time.
90
- </p>
91
-
92
- <p className="mt-4">
93
- Every connected device in your home pulls from your available internet
94
- bandwidth.
95
- </p>
96
- </>
97
- ),
98
- },
99
- {
100
- title: "Do I qualify for any promotional offers?",
101
- description: (
102
- <>
103
- <p>
104
- Be sure to register for updates, promotional offers, and special
105
- discounts using the form below.
106
- </p>
107
-
108
- <p className="mt-4">
109
- Enjoy an improved internet experience and take advantage of newer,
110
- faster, and more advanced fiber technology.
111
- </p>
112
- </>
113
- ),
114
- },
115
- {
116
- title: "Can I change or cancel my pre‑order?",
117
- description: (
118
- <>
119
- <p>
120
- Yes, of course! You are under no obligation. If a situation arises
121
- that requires a change, simply give us a call at{" "}
122
- <strong>855‑939‑2381</strong>.
123
- </p>
124
- </>
125
- ),
126
- },
127
- ];
128
- ``;
1
+ import { AccordionItem } from "./types";
2
+
3
+ /* ------------
4
+ DEFAULT FAQs (3 – plain text only)
5
+ --------------- */
6
+
7
+ export const FAQ_ITEMS: AccordionItem[] = [
8
+ {
9
+ title: "How much speed do I need in my home?",
10
+ description:
11
+ "The amount of internet speed or bandwidth you need in your home significantly depends on your usage and the number of devices connected to the internet. Connected devices don’t only mean computers and tablets; they include TVs used for streaming, gaming consoles, smart watches, phones, home security cameras and doorbells, home assistants, baby monitors, wireless speakers, and more. Every connected device pulls from your home’s internet bandwidth.",
12
+ },
13
+ {
14
+ title: "Do I qualify for any promotional offers?",
15
+ description:
16
+ "Be sure to register for updates, promotional offers, and special discounts in the form provided. You’ll be able to enjoy an improved internet experience and benefit from newer, faster, and more advanced fiber technology.",
17
+ },
18
+ {
19
+ title: "How fast is Kinetic internet?",
20
+ description:
21
+ "Kinetic offers high internet speeds ranging from 200 Mbps up to Fiber Gig speeds of 1000 Mbps.",
22
+ },
23
+ ];
24
+
25
+ /* --------------
26
+ RICH TEXT FAQs (4 – JSX formatted)
27
+ ----------------- */
28
+
29
+ export const RICH_FAQ_ITEMS: AccordionItem[] = [
30
+ {
31
+ title: "How do I check my Windstream email?",
32
+ description: (
33
+ <>
34
+ <p>
35
+ <strong>Already have a windstream.net account?</strong>
36
+ </p>
37
+
38
+ <p>You can check your windstream.net emails in the following ways:</p>
39
+
40
+ <ol className="ml-6 list-decimal">
41
+ <li>
42
+ Go to <strong>www.windstream.net</strong> and click{" "}
43
+ <strong>Email</strong> in the top‑right of the menu bar.
44
+ </li>
45
+ <li>Use an email application on a smartphone.</li>
46
+ <li>Use an email client on a computer.</li>
47
+ </ol>
48
+
49
+ <p className="mt-4">
50
+ <strong>OR</strong>
51
+ </p>
52
+
53
+ <p>
54
+ Log in to <strong>Go Kinetic</strong>, navigate to{" "}
55
+ <strong>Other Services</strong>, then select{" "}
56
+ <strong>View and Manage Email</strong>.
57
+ </p>
58
+
59
+ <p className="mt-4">
60
+ <strong>Wanting to set up a new .net email account?</strong>
61
+ </p>
62
+
63
+ <ul className="ml-6 list-disc">
64
+ <li>
65
+ If you do not already have a windstream.net email account, new
66
+ windstream.net email addresses are no longer being created.
67
+ </li>
68
+ <li>
69
+ You can set up a free email account using platforms like{" "}
70
+ <strong>Gmail</strong> or <strong>Yahoo</strong>.
71
+ </li>
72
+ </ul>
73
+ </>
74
+ ),
75
+ },
76
+ {
77
+ title: "How much speed do I need in my home?",
78
+ description: (
79
+ <>
80
+ <p>
81
+ For a household with <strong>4+ internet users</strong> who use the
82
+ web for online gaming, music and video streaming, uploading pictures
83
+ and videos, as well as email and browsing, a{" "}
84
+ <strong>1‑Gigabit plan</strong> would be best suited.
85
+ </p>
86
+
87
+ <p className="mt-4">
88
+ This also supports multiple devices such as laptops, smartphones,
89
+ tablets, and TVs connected to the home internet at the same time.
90
+ </p>
91
+
92
+ <p className="mt-4">
93
+ Every connected device in your home pulls from your available internet
94
+ bandwidth.
95
+ </p>
96
+ </>
97
+ ),
98
+ },
99
+ {
100
+ title: "Do I qualify for any promotional offers?",
101
+ description: (
102
+ <>
103
+ <p>
104
+ Be sure to register for updates, promotional offers, and special
105
+ discounts using the form below.
106
+ </p>
107
+
108
+ <p className="mt-4">
109
+ Enjoy an improved internet experience and take advantage of newer,
110
+ faster, and more advanced fiber technology.
111
+ </p>
112
+ </>
113
+ ),
114
+ },
115
+ {
116
+ title: "Can I change or cancel my pre‑order?",
117
+ description: (
118
+ <>
119
+ <p>
120
+ Yes, of course! You are under no obligation. If a situation arises
121
+ that requires a change, simply give us a call at{" "}
122
+ <strong>855‑939‑2381</strong>.
123
+ </p>
124
+ </>
125
+ ),
126
+ },
127
+ ];
128
+ ``;
@@ -1,98 +1,98 @@
1
- import { FAQ_ITEMS, RICH_FAQ_ITEMS } from "./Accordion.stories.mocks";
2
- import { Accordion } from "./index";
3
- import type { AccordionProps } from "./types";
4
-
5
- import { DocsPage } from "@shared/stories/DocsTemplate";
6
- import type { ArgTypes, Meta, StoryObj } from "@storybook/react";
7
-
8
- /* ------------
9
- ArgTypes
10
- --------------- */
11
-
12
- const argTypes: ArgTypes<AccordionProps> = {
13
- title: {
14
- control: { type: "text" as const },
15
- description: "Title displayed above the accordion",
16
- },
17
- items: {
18
- control: { type: "object" as const },
19
- description: "Accordion items",
20
- },
21
- background: {
22
- control: { type: "select" as const },
23
- options: ["blue", "green", "yellow", "purple", "white", "navy", "cream500"],
24
- description: "Background color of the accordion",
25
- },
26
- enableHeading: {
27
- control: { type: "boolean" as const },
28
- },
29
- maxWidth: {
30
- control: { type: "boolean" as const },
31
- },
32
- hashAutoExpand: {
33
- control: { type: "boolean" as const },
34
- },
35
- descriptionMaxWidth: {
36
- control: { type: "text" as const },
37
- },
38
- anchorId: {
39
- control: { type: "text" as const },
40
- },
41
- initialExpandedItems: {
42
- control: { type: "object" as const },
43
- },
44
- itemContainerClassName: {
45
- table: { disable: true },
46
- },
47
- };
48
-
49
- /* --------
50
- Meta
51
- ----------- */
52
-
53
- const meta: Meta<typeof Accordion> = {
54
- title: "Contentful Blocks/Accordion",
55
- component: Accordion,
56
- tags: ["autodocs"],
57
- argTypes,
58
- parameters: {
59
- layout: "centered",
60
- docs: {
61
- page: DocsPage,
62
- description: {
63
- component:
64
- "Contentful accordion block used to render collapsible content.",
65
- },
66
- },
67
- },
68
- args: {
69
- title: "FAQs",
70
- background: "white",
71
- enableHeading: false,
72
- maxWidth: true,
73
- items: [],
74
- initialExpandedItems: [],
75
- hashAutoExpand: false,
76
- descriptionMaxWidth: "max-w-[980px]",
77
- },
78
- };
79
-
80
- export default meta;
81
- type Story = StoryObj<typeof meta>;
82
-
83
- /* --------
84
- Stories
85
- ----------- */
86
-
87
- export const Default: Story = {
88
- args: {
89
- items: FAQ_ITEMS,
90
- },
91
- };
92
-
93
- export const WithRichTextContent = {
94
- args: {
95
- title: "FAQs - Rich Content",
96
- items: RICH_FAQ_ITEMS,
97
- },
98
- };
1
+ import { FAQ_ITEMS, RICH_FAQ_ITEMS } from "./Accordion.stories.mocks";
2
+ import { Accordion } from "./index";
3
+ import type { AccordionProps } from "./types";
4
+
5
+ import { DocsPage } from "@shared/stories/DocsTemplate";
6
+ import type { ArgTypes, Meta, StoryObj } from "@storybook/react";
7
+
8
+ /* ------------
9
+ ArgTypes
10
+ --------------- */
11
+
12
+ const argTypes: ArgTypes<AccordionProps> = {
13
+ title: {
14
+ control: { type: "text" as const },
15
+ description: "Title displayed above the accordion",
16
+ },
17
+ items: {
18
+ control: { type: "object" as const },
19
+ description: "Accordion items",
20
+ },
21
+ background: {
22
+ control: { type: "select" as const },
23
+ options: ["blue", "green", "yellow", "purple", "white", "navy", "cream500"],
24
+ description: "Background color of the accordion",
25
+ },
26
+ enableHeading: {
27
+ control: { type: "boolean" as const },
28
+ },
29
+ maxWidth: {
30
+ control: { type: "boolean" as const },
31
+ },
32
+ hashAutoExpand: {
33
+ control: { type: "boolean" as const },
34
+ },
35
+ descriptionMaxWidth: {
36
+ control: { type: "text" as const },
37
+ },
38
+ anchorId: {
39
+ control: { type: "text" as const },
40
+ },
41
+ initialExpandedItems: {
42
+ control: { type: "object" as const },
43
+ },
44
+ itemContainerClassName: {
45
+ table: { disable: true },
46
+ },
47
+ };
48
+
49
+ /* --------
50
+ Meta
51
+ ----------- */
52
+
53
+ const meta: Meta<typeof Accordion> = {
54
+ title: "Contentful Blocks/Accordion",
55
+ component: Accordion,
56
+ tags: ["autodocs"],
57
+ argTypes,
58
+ parameters: {
59
+ layout: "centered",
60
+ docs: {
61
+ page: DocsPage,
62
+ description: {
63
+ component:
64
+ "Contentful accordion block used to render collapsible content.",
65
+ },
66
+ },
67
+ },
68
+ args: {
69
+ title: "FAQs",
70
+ background: "white",
71
+ enableHeading: false,
72
+ maxWidth: true,
73
+ items: [],
74
+ initialExpandedItems: [],
75
+ hashAutoExpand: false,
76
+ descriptionMaxWidth: "max-w-[980px]",
77
+ },
78
+ };
79
+
80
+ export default meta;
81
+ type Story = StoryObj<typeof meta>;
82
+
83
+ /* --------
84
+ Stories
85
+ ----------- */
86
+
87
+ export const Default: Story = {
88
+ args: {
89
+ items: FAQ_ITEMS,
90
+ },
91
+ };
92
+
93
+ export const WithRichTextContent = {
94
+ args: {
95
+ title: "FAQs - Rich Content",
96
+ items: RICH_FAQ_ITEMS,
97
+ },
98
+ };
@@ -0,0 +1,218 @@
1
+ import Accordion from "./index";
2
+ import { AccordionItem } from "./types";
3
+
4
+ import { fireEvent, render, screen } from "@testing-library/react";
5
+
6
+ const items: AccordionItem[] = [
7
+ { anchorId: "item-1", title: "First Question", description: "Answer one" },
8
+ { anchorId: "item-2", title: "Second Question", description: "Answer two" },
9
+ { anchorId: "item-3", title: "Third Question", description: "Answer three" },
10
+ ];
11
+
12
+ describe("Contentful Accordion", () => {
13
+ beforeEach(() => {
14
+ Object.defineProperty(window, "location", {
15
+ writable: true,
16
+ value: { hash: "" },
17
+ });
18
+ });
19
+
20
+ it("renders the title as h2 by default", () => {
21
+ render(<Accordion items={items} title="FAQ" />);
22
+ const heading = screen.getByText("FAQ");
23
+ expect(heading.tagName).toBe("H2");
24
+ });
25
+
26
+ it("renders the title as h1 when enableHeading is true", () => {
27
+ render(<Accordion items={items} title="FAQ" enableHeading={true} />);
28
+ const heading = screen.getByText("FAQ");
29
+ expect(heading.tagName).toBe("H1");
30
+ });
31
+
32
+ it("renders all accordion item titles", () => {
33
+ render(<Accordion items={items} title="FAQ" />);
34
+ expect(screen.getByText("First Question")).toBeInTheDocument();
35
+ expect(screen.getByText("Second Question")).toBeInTheDocument();
36
+ expect(screen.getByText("Third Question")).toBeInTheDocument();
37
+ });
38
+
39
+ it("renders item descriptions", () => {
40
+ render(<Accordion items={items} title="FAQ" />);
41
+ expect(screen.getByText("Answer one")).toBeInTheDocument();
42
+ expect(screen.getByText("Answer two")).toBeInTheDocument();
43
+ expect(screen.getByText("Answer three")).toBeInTheDocument();
44
+ });
45
+
46
+ it("applies anchorId to the section", () => {
47
+ const { container } = render(
48
+ <Accordion items={items} title="FAQ" anchorId="faq-section" />
49
+ );
50
+ expect(container.querySelector("#faq-section")).toBeInTheDocument();
51
+ });
52
+
53
+ it("applies white background by default", () => {
54
+ const { container } = render(<Accordion items={items} title="FAQ" />);
55
+ expect(container.querySelector(".bg-white")).toBeInTheDocument();
56
+ });
57
+
58
+ it("applies navy background", () => {
59
+ const { container } = render(
60
+ <Accordion items={items} title="FAQ" background="navy" />
61
+ );
62
+ expect(
63
+ container.querySelector('section[class*="bg-[#00002D]"]')
64
+ ).toBeInTheDocument();
65
+ });
66
+
67
+ it("applies blue background", () => {
68
+ const { container } = render(
69
+ <Accordion items={items} title="FAQ" background="blue" />
70
+ );
71
+ expect(
72
+ container.querySelector('section[class*="bg-[#07B2E2]"]')
73
+ ).toBeInTheDocument();
74
+ });
75
+
76
+ it("applies green background", () => {
77
+ const { container } = render(
78
+ <Accordion items={items} title="FAQ" background="green" />
79
+ );
80
+ expect(
81
+ container.querySelector('section[class*="bg-[#26B170]"]')
82
+ ).toBeInTheDocument();
83
+ });
84
+
85
+ it("applies yellow background", () => {
86
+ const { container } = render(
87
+ <Accordion items={items} title="FAQ" background="yellow" />
88
+ );
89
+ expect(
90
+ container.querySelector('section[class*="bg-[#F5FF1E]"]')
91
+ ).toBeInTheDocument();
92
+ });
93
+
94
+ it("applies purple background", () => {
95
+ const { container } = render(
96
+ <Accordion items={items} title="FAQ" background="purple" />
97
+ );
98
+ expect(
99
+ container.querySelector('section[class*="bg-[#931D69]"]')
100
+ ).toBeInTheDocument();
101
+ });
102
+
103
+ it("applies cream500 background", () => {
104
+ const { container } = render(
105
+ <Accordion items={items} title="FAQ" background="cream500" />
106
+ );
107
+ expect(
108
+ container.querySelector('section[class*="bg-[#FFFEEF]"]')
109
+ ).toBeInTheDocument();
110
+ });
111
+
112
+ it("applies maxWidth class by default", () => {
113
+ const { container } = render(<Accordion items={items} title="FAQ" />);
114
+ expect(container.querySelector(".max-w-120")).toBeInTheDocument();
115
+ });
116
+
117
+ it("does not apply maxWidth class when maxWidth is false", () => {
118
+ const { container } = render(
119
+ <Accordion items={items} title="FAQ" maxWidth={false} />
120
+ );
121
+ expect(container.querySelector(".max-w-120")).not.toBeInTheDocument();
122
+ });
123
+
124
+ it("renders dividers between items but not after the last", () => {
125
+ const { container } = render(<Accordion items={items} title="FAQ" />);
126
+ const dividers = container.querySelectorAll(
127
+ ".bg-bg-surface-tertiary-active"
128
+ );
129
+ expect(dividers).toHaveLength(items.length - 1);
130
+ });
131
+
132
+ it("expands items in initialExpandedItems", () => {
133
+ render(
134
+ <Accordion items={items} title="FAQ" initialExpandedItems={["item-1"]} />
135
+ );
136
+ const arrowsUp = screen.getAllByText("keyboard_arrow_up");
137
+ expect(arrowsUp.length).toBeGreaterThanOrEqual(1);
138
+ });
139
+
140
+ it("auto-expands item matching URL hash when hashAutoExpand is true", () => {
141
+ Object.defineProperty(window, "location", {
142
+ writable: true,
143
+ value: { hash: "#item-2" },
144
+ });
145
+ render(<Accordion items={items} title="FAQ" hashAutoExpand={true} />);
146
+ expect(document.getElementById("item-2")).toBeInTheDocument();
147
+ });
148
+
149
+ it("does not auto-expand when hashAutoExpand is false", () => {
150
+ Object.defineProperty(window, "location", {
151
+ writable: true,
152
+ value: { hash: "#item-2" },
153
+ });
154
+ render(<Accordion items={items} title="FAQ" hashAutoExpand={false} />);
155
+ const arrowsDown = screen.getAllByText("keyboard_arrow_down");
156
+ expect(arrowsDown.length).toBe(items.length);
157
+ });
158
+
159
+ it("does not duplicate item in expandedItems if already present", () => {
160
+ Object.defineProperty(window, "location", {
161
+ writable: true,
162
+ value: { hash: "#item-1" },
163
+ });
164
+ render(
165
+ <Accordion
166
+ items={items}
167
+ title="FAQ"
168
+ hashAutoExpand={true}
169
+ initialExpandedItems={["item-1"]}
170
+ />
171
+ );
172
+ expect(document.getElementById("item-1")).toBeInTheDocument();
173
+ });
174
+
175
+ it("applies itemContainerClassName", () => {
176
+ const { container } = render(
177
+ <Accordion items={items} title="FAQ" itemContainerClassName="gap-4" />
178
+ );
179
+ expect(container.querySelector(".gap-4")).toBeInTheDocument();
180
+ });
181
+
182
+ it("applies descriptionMaxWidth class", () => {
183
+ const { container } = render(
184
+ <Accordion
185
+ items={items}
186
+ title="FAQ"
187
+ descriptionMaxWidth="max-w-[500px]"
188
+ />
189
+ );
190
+ expect(container.querySelector(".max-w-\\[500px\\]")).toBeInTheDocument();
191
+ });
192
+
193
+ it("sets id on items with anchorId", () => {
194
+ render(<Accordion items={items} title="FAQ" />);
195
+ expect(document.getElementById("item-1")).toBeInTheDocument();
196
+ expect(document.getElementById("item-2")).toBeInTheDocument();
197
+ });
198
+
199
+ it("handles items without anchorId using index as key", () => {
200
+ const noAnchorItems: AccordionItem[] = [
201
+ { title: "Q1", description: "A1" },
202
+ { title: "Q2", description: "A2" },
203
+ ];
204
+ render(<Accordion items={noAnchorItems} title="FAQ" />);
205
+ expect(screen.getByText("Q1")).toBeInTheDocument();
206
+ expect(screen.getByText("Q2")).toBeInTheDocument();
207
+ });
208
+
209
+ it("toggles expanded state when an accordion item button is clicked", () => {
210
+ render(
211
+ <Accordion items={items} title="FAQ" initialExpandedItems={["item-1"]} />
212
+ );
213
+ const buttons = screen.getAllByRole("button");
214
+ fireEvent.click(buttons[0]);
215
+ fireEvent.click(buttons[0]);
216
+ expect(screen.getByText("First Question")).toBeInTheDocument();
217
+ });
218
+ });