@windstream/react-shared-components 0.0.90 → 0.0.92

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 (149) hide show
  1. package/README.md +635 -635
  2. package/dist/contentful/index.d.ts +0 -1
  3. package/dist/contentful/index.esm.js +1 -1
  4. package/dist/contentful/index.esm.js.map +1 -1
  5. package/dist/contentful/index.js +1 -1
  6. package/dist/contentful/index.js.map +1 -1
  7. package/dist/core.d.ts +3 -3
  8. package/dist/index.d.ts +3 -3
  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/package.json +177 -177
  15. package/src/components/accordion/Accordion.stories.tsx +230 -230
  16. package/src/components/accordion/types.ts +10 -10
  17. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  18. package/src/components/alert-card/index.tsx +32 -32
  19. package/src/components/alert-card/types.ts +9 -9
  20. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  21. package/src/components/brand-button/helpers.ts +35 -35
  22. package/src/components/brand-button/index.tsx +115 -115
  23. package/src/components/brand-button/types.ts +37 -37
  24. package/src/components/button/Button.stories.tsx +108 -108
  25. package/src/components/button/index.tsx +27 -27
  26. package/src/components/button/types.ts +14 -14
  27. package/src/components/call-button/CallButton.stories.tsx +324 -324
  28. package/src/components/call-button/index.tsx +86 -86
  29. package/src/components/call-button/types.ts +11 -11
  30. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  31. package/src/components/checkbox/index.tsx +197 -197
  32. package/src/components/checkbox/types.ts +27 -27
  33. package/src/components/checklist/Checklist.stories.tsx +150 -150
  34. package/src/components/checklist/index.tsx +55 -55
  35. package/src/components/checklist/types.ts +14 -14
  36. package/src/components/collapse/Collapse.stories.tsx +255 -255
  37. package/src/components/collapse/index.tsx +46 -46
  38. package/src/components/collapse/types.ts +6 -6
  39. package/src/components/divider/Divider.stories.tsx +205 -205
  40. package/src/components/divider/index.tsx +22 -22
  41. package/src/components/divider/type.ts +3 -3
  42. package/src/components/image/Image.stories.tsx +113 -113
  43. package/src/components/image/index.tsx +25 -25
  44. package/src/components/image/types.ts +40 -40
  45. package/src/components/input/Input.stories.tsx +325 -325
  46. package/src/components/input/index.tsx +177 -177
  47. package/src/components/input/types.ts +37 -37
  48. package/src/components/link/Link.stories.tsx +163 -163
  49. package/src/components/link/types.ts +25 -25
  50. package/src/components/list/List.stories.tsx +272 -272
  51. package/src/components/list/index.tsx +88 -88
  52. package/src/components/list/list-item/index.tsx +38 -38
  53. package/src/components/list/list-item/types.ts +13 -13
  54. package/src/components/list/types.ts +29 -29
  55. package/src/components/material-icon/MaterialIcon.stories.tsx +330 -330
  56. package/src/components/material-icon/constants.ts +98 -98
  57. package/src/components/material-icon/index.tsx +44 -44
  58. package/src/components/material-icon/types.ts +31 -31
  59. package/src/components/modal/Modal.stories.tsx +171 -171
  60. package/src/components/modal/index.tsx +164 -164
  61. package/src/components/modal/types.ts +24 -24
  62. package/src/components/next-image/index.tsx +32 -32
  63. package/src/components/next-image/types.ts +1 -1
  64. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  65. package/src/components/radio-button/index.tsx +75 -75
  66. package/src/components/radio-button/types.ts +21 -21
  67. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  68. package/src/components/see-more/index.tsx +44 -44
  69. package/src/components/see-more/types.ts +4 -4
  70. package/src/components/select/Select.stories.tsx +411 -411
  71. package/src/components/select/index.tsx +150 -150
  72. package/src/components/select/types.ts +35 -35
  73. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  74. package/src/components/select-plan-button/index.tsx +31 -31
  75. package/src/components/select-plan-button/types.ts +5 -5
  76. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  77. package/src/components/skeleton/index.tsx +61 -61
  78. package/src/components/skeleton/types.ts +4 -4
  79. package/src/components/spinner/Spinner.stories.tsx +335 -335
  80. package/src/components/spinner/index.tsx +44 -44
  81. package/src/components/spinner/types.ts +5 -5
  82. package/src/components/text/Text.stories.tsx +321 -321
  83. package/src/components/text/index.tsx +25 -25
  84. package/src/components/text/types.ts +45 -45
  85. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  86. package/src/components/tooltip/index.tsx +74 -74
  87. package/src/components/tooltip/types.ts +7 -7
  88. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  89. package/src/components/view-cart-button/index.tsx +42 -42
  90. package/src/components/view-cart-button/types.ts +5 -5
  91. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  92. package/src/contentful/blocks/button/index.tsx +99 -99
  93. package/src/contentful/blocks/button/types.ts +31 -31
  94. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  95. package/src/contentful/blocks/callout/index.tsx +66 -66
  96. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  97. package/src/contentful/blocks/cards/index.tsx +13 -13
  98. package/src/contentful/blocks/cards/product-card/index.tsx +199 -199
  99. package/src/contentful/blocks/cards/product-card/types.ts +21 -21
  100. package/src/contentful/blocks/cards/simple-card/index.tsx +77 -77
  101. package/src/contentful/blocks/cards/simple-card/types.ts +31 -31
  102. package/src/contentful/blocks/cards/testimonial-card/index.tsx +88 -88
  103. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  104. package/src/contentful/blocks/cards/types.ts +1 -1
  105. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  106. package/src/contentful/blocks/carousel/helper.tsx +349 -349
  107. package/src/contentful/blocks/carousel/index.tsx +68 -68
  108. package/src/contentful/blocks/carousel/types.ts +139 -140
  109. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  110. package/src/contentful/blocks/cta-callout/index.tsx +54 -54
  111. package/src/contentful/blocks/cta-callout/types.ts +22 -22
  112. package/src/contentful/blocks/find-kinetic/index.tsx +124 -124
  113. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  114. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  115. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  116. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  117. package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
  118. package/src/contentful/blocks/image-promo-bar/index.tsx +231 -231
  119. package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
  120. package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
  121. package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
  122. package/src/contentful/blocks/modal/constants.ts +53 -53
  123. package/src/contentful/blocks/modal/index.tsx +91 -91
  124. package/src/contentful/blocks/modal/types.ts +12 -12
  125. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +111 -111
  126. package/src/contentful/blocks/navigation/index.tsx +385 -385
  127. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +80 -80
  128. package/src/contentful/blocks/navigation/types.ts +41 -41
  129. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  130. package/src/contentful/blocks/primary-hero/index.tsx +228 -228
  131. package/src/contentful/blocks/primary-hero/types.ts +35 -35
  132. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  133. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  134. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  135. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  136. package/src/contentful/blocks/text/index.tsx +12 -12
  137. package/src/contentful/blocks/text/types.ts +1 -1
  138. package/src/contentful/index.ts +57 -57
  139. package/src/hooks/use-body-scroll-lock.ts +34 -34
  140. package/src/hooks/use-outside-click.ts +17 -17
  141. package/src/index.ts +96 -96
  142. package/src/next/index.ts +5 -5
  143. package/src/setupTests.ts +46 -46
  144. package/src/stories/DocsTemplate.tsx +24 -24
  145. package/src/styles/globals.css +307 -307
  146. package/src/types/global.d.ts +9 -9
  147. package/src/types/micro-components.ts +89 -89
  148. package/src/utils/index.ts +49 -49
  149. package/tailwind.config.cjs +8 -24
@@ -1,89 +1,89 @@
1
- export interface Asset {
2
- url?: string | null;
3
- title?: string | null;
4
- description?: string | null;
5
- contentType?: string | null;
6
- width?: number | null;
7
- height?: number | null;
8
- }
9
- export interface Button {
10
- anchorId?: string | null;
11
- showButtonAs?: "solid" | "text" | null;
12
- buttonLabel: string; // required in your model
13
- buttonPrefix?: string | null;
14
- href?: string | null;
15
- target?: "_blank" | "_self" | null;
16
- badge?: string | null;
17
- preserveQueryParameters: boolean; // non-null in your model
18
- badgeIcon?: Asset | null;
19
- buttonVariant?: "primary_brand" | "primary_inverse" | "secondary" | null;
20
- buttonIcon?: Asset | null;
21
- buttonIconPosition?: boolean | null; // matches EntryFieldTypes.Boolean in your model
22
- clickToOpen?: "accordion" | "modal" | "tab" | null;
23
- tabmodalNameToOpen?: string | null;
24
- preDefinedFunctionExecution?: "check availability" | null;
25
- }
26
-
27
- export interface ButtonGroup {
28
- __typename: "ComponentButtonGroup";
29
- anchorId?: string | null;
30
- title?: string | null;
31
- itemsCollection?: {
32
- items: Button[];
33
- };
34
- }
35
- export interface Card {
36
- anchorId?: string;
37
- title?: string;
38
- body?: {
39
- json: any; // Contentful Rich Text
40
- };
41
- image?: Asset;
42
- imageLink?: string;
43
- imageAlignment?: "Left" | "Right" | "Center" | string;
44
- imageView?: "Full" | "Inset" | string;
45
- cta?: Button;
46
- ctaAlignment?: "Left" | "Right" | "Center" | string;
47
- textColor?: string;
48
- backgroundColor?: string;
49
- showBackgroundImage?: boolean;
50
- pinwheelColor?: "blue" | "green" | "navy" | "purple" | "white" | "yellow";
51
- iconToRichTextAlignment?: string;
52
- phoneNumber?: string;
53
- workingHours?: string;
54
- titleLocation?: "Top" | "Bottom" | string;
55
- ctaBottom?: Button;
56
- ctaAlignmentBottom?: "Left" | "Right" | "Center" | string;
57
- imageFloatingType?: boolean;
58
- }
59
-
60
- export interface VideoLink {
61
- image?: Asset;
62
- videoPopup?: boolean;
63
- link?: string;
64
- }
65
-
66
- export interface Checklist {
67
- list?: {
68
- items: {
69
- checkListTitle?: { json: any };
70
- icon?: Asset;
71
- anchorId?: string;
72
- }[];
73
- };
74
- }
75
-
76
- export interface RichTextItem {
77
- title?: string;
78
- isTargetBlank?: boolean;
79
- richText?: { json: any };
80
- }
81
-
82
- export type CheckPlansProps = {
83
- className?: string;
84
- title?: string;
85
- ctaAlignment?: "new-row" | "same-row";
86
- ctaText?: string;
87
- buttonVariant?: "primary_brand" | "secondary" | "primary_inverse";
88
- showButtonAs?: "solid" | "unstyled" | "text" | undefined;
89
- };
1
+ export interface Asset {
2
+ url?: string | null;
3
+ title?: string | null;
4
+ description?: string | null;
5
+ contentType?: string | null;
6
+ width?: number | null;
7
+ height?: number | null;
8
+ }
9
+ export interface Button {
10
+ anchorId?: string | null;
11
+ showButtonAs?: "solid" | "text" | null;
12
+ buttonLabel: string; // required in your model
13
+ buttonPrefix?: string | null;
14
+ href?: string | null;
15
+ target?: "_blank" | "_self" | null;
16
+ badge?: string | null;
17
+ preserveQueryParameters: boolean; // non-null in your model
18
+ badgeIcon?: Asset | null;
19
+ buttonVariant?: "primary_brand" | "primary_inverse" | "secondary" | null;
20
+ buttonIcon?: Asset | null;
21
+ buttonIconPosition?: boolean | null; // matches EntryFieldTypes.Boolean in your model
22
+ clickToOpen?: "accordion" | "modal" | "tab" | null;
23
+ tabmodalNameToOpen?: string | null;
24
+ preDefinedFunctionExecution?: "check availability" | null;
25
+ }
26
+
27
+ export interface ButtonGroup {
28
+ __typename: "ComponentButtonGroup";
29
+ anchorId?: string | null;
30
+ title?: string | null;
31
+ itemsCollection?: {
32
+ items: Button[];
33
+ };
34
+ }
35
+ export interface Card {
36
+ anchorId?: string;
37
+ title?: string;
38
+ body?: {
39
+ json: any; // Contentful Rich Text
40
+ };
41
+ image?: Asset;
42
+ imageLink?: string;
43
+ imageAlignment?: "Left" | "Right" | "Center" | string;
44
+ imageView?: "Full" | "Inset" | string;
45
+ cta?: Button;
46
+ ctaAlignment?: "Left" | "Right" | "Center" | string;
47
+ textColor?: string;
48
+ backgroundColor?: string;
49
+ showBackgroundImage?: boolean;
50
+ pinwheelColor?: "blue" | "green" | "navy" | "purple" | "white" | "yellow";
51
+ iconToRichTextAlignment?: string;
52
+ phoneNumber?: string;
53
+ workingHours?: string;
54
+ titleLocation?: "Top" | "Bottom" | string;
55
+ ctaBottom?: Button;
56
+ ctaAlignmentBottom?: "Left" | "Right" | "Center" | string;
57
+ imageFloatingType?: boolean;
58
+ }
59
+
60
+ export interface VideoLink {
61
+ image?: Asset;
62
+ videoPopup?: boolean;
63
+ link?: string;
64
+ }
65
+
66
+ export interface Checklist {
67
+ list?: {
68
+ items: {
69
+ checkListTitle?: { json: any };
70
+ icon?: Asset;
71
+ anchorId?: string;
72
+ }[];
73
+ };
74
+ }
75
+
76
+ export interface RichTextItem {
77
+ title?: string;
78
+ isTargetBlank?: boolean;
79
+ richText?: { json: any };
80
+ }
81
+
82
+ export type CheckPlansProps = {
83
+ className?: string;
84
+ title?: string;
85
+ ctaAlignment?: "new-row" | "same-row";
86
+ ctaText?: string;
87
+ buttonVariant?: "primary_brand" | "secondary" | "primary_inverse";
88
+ showButtonAs?: "solid" | "unstyled" | "text" | undefined;
89
+ };
@@ -1,49 +1,49 @@
1
- import { clsx, type ClassValue } from "clsx";
2
- import { extendTailwindMerge } from "tailwind-merge";
3
-
4
- const twMerge = extendTailwindMerge({
5
- // Define class groups so twMerge knows which classes override each other
6
- extend: {
7
- classGroups: {
8
- ["font-variants" as any]: [
9
- "heading1",
10
- "heading2",
11
- "heading3",
12
- "heading4",
13
- "heading5",
14
- "heading6",
15
- "subheading1",
16
- "subheading2",
17
- "subheading3",
18
- "subheading4",
19
- "subheading5",
20
- "subheading6",
21
- "body1",
22
- "body2",
23
- "body3",
24
- "footnote",
25
- "micro",
26
- "label1",
27
- "label2",
28
- "label3",
29
- "label4",
30
- ],
31
- ["button-sizes" as any]: [
32
- "btn-small",
33
- "btn-medium",
34
- "btn-large",
35
- "btn-x-large",
36
- ],
37
- },
38
- },
39
- });
40
-
41
- /**
42
- * Utility function to combine class names using clsx
43
- * @param inputs - Class values to combine
44
- * @returns Combined class string
45
- */
46
- export const cx = (...val: ClassValue[]) => twMerge(clsx(...val));
47
-
48
- export { clsx };
49
- export type { ClassValue };
1
+ import { clsx, type ClassValue } from "clsx";
2
+ import { extendTailwindMerge } from "tailwind-merge";
3
+
4
+ const twMerge = extendTailwindMerge({
5
+ // Define class groups so twMerge knows which classes override each other
6
+ extend: {
7
+ classGroups: {
8
+ ["font-variants" as any]: [
9
+ "heading1",
10
+ "heading2",
11
+ "heading3",
12
+ "heading4",
13
+ "heading5",
14
+ "heading6",
15
+ "subheading1",
16
+ "subheading2",
17
+ "subheading3",
18
+ "subheading4",
19
+ "subheading5",
20
+ "subheading6",
21
+ "body1",
22
+ "body2",
23
+ "body3",
24
+ "footnote",
25
+ "micro",
26
+ "label1",
27
+ "label2",
28
+ "label3",
29
+ "label4",
30
+ ],
31
+ ["button-sizes" as any]: [
32
+ "btn-small",
33
+ "btn-medium",
34
+ "btn-large",
35
+ "btn-x-large",
36
+ ],
37
+ },
38
+ },
39
+ });
40
+
41
+ /**
42
+ * Utility function to combine class names using clsx
43
+ * @param inputs - Class values to combine
44
+ * @returns Combined class string
45
+ */
46
+ export const cx = (...val: ClassValue[]) => twMerge(clsx(...val));
47
+
48
+ export { clsx };
49
+ export type { ClassValue };
@@ -458,20 +458,20 @@ module.exports = {
458
458
  ".body1": {
459
459
  "font-family": theme("fontFamily.sans"),
460
460
  "font-size": theme("fontSize.body1"), // 1.25rem/20px
461
- "line-height": theme("lineHeight.8"), // 2rem/32px
462
- "font-weight": "400",
461
+ "line-height": theme("lineHeight.7"), // 1.75rem/28px
462
+ "font-weight": "500",
463
463
  },
464
464
  ".body2": {
465
465
  "font-family": theme("fontFamily.sans"),
466
466
  "font-size": theme("fontSize.body2"), // 1.125rem/18px
467
467
  "line-height": theme("lineHeight.7"), // 1.75rem/28px
468
- "font-weight": "400",
468
+ "font-weight": "500",
469
469
  },
470
470
  ".body3": {
471
471
  "font-family": theme("fontFamily.sans"),
472
472
  "font-size": theme("fontSize.body3"), // 1rem/16px
473
473
  "line-height": theme("lineHeight.6"), // 1.5rem/24px
474
- "font-weight": "400",
474
+ "font-weight": "500",
475
475
  },
476
476
 
477
477
  // Footnote & Micro
@@ -493,55 +493,39 @@ module.exports = {
493
493
  "font-family": theme("fontFamily.sans"),
494
494
  "font-size": theme("fontSize.label1"), // 1.25rem/20px
495
495
  "line-height": theme("lineHeight.7"), // 1.75rem/28px
496
- "font-weight": "600",
496
+ "font-weight": "900",
497
497
  },
498
498
  ".label2": {
499
499
  "font-family": theme("fontFamily.sans"),
500
500
  "font-size": theme("fontSize.label2"), // 1.125rem/18px
501
501
  "line-height": theme("lineHeight.7"), // 1.75rem/28px
502
- "font-weight": "600",
502
+ "font-weight": "900",
503
503
  },
504
504
  ".label3": {
505
505
  "font-family": theme("fontFamily.sans"),
506
506
  "font-size": theme("fontSize.label3"), // 1rem/16px
507
507
  "line-height": theme("lineHeight.6"), // 1.5rem/24px
508
- "font-weight": "600",
508
+ "font-weight": "900",
509
509
  },
510
510
  ".label4": {
511
511
  "font-family": theme("fontFamily.sans"),
512
512
  "font-size": theme("fontSize.label4"), // 0.875rem/14px
513
513
  "line-height": theme("lineHeight.5"), // 1.25rem/20px
514
- "font-weight": "600",
515
- },
516
- ".label5": {
517
- "font-family": theme("fontFamily.spirit"),
518
- "font-size": theme("fontSize.label5"), // 1.25rem/20px
519
- "line-height": theme("lineHeight.7"), // 1.75rem/28px
520
- "font-weight": "700",
521
- },
522
- ".label6": {
523
- "font-family": theme("fontFamily.spirit"),
524
- "font-size": theme("fontSize.label6"), // 1.125rem/18px
525
- "line-height": theme("lineHeight.7"), // 1.75rem/28px
526
- "font-weight": "700",
514
+ "font-weight": "900",
527
515
  },
528
516
  }
529
517
 
530
518
  const buttonComponents = {
531
519
  ".btn-small": {
532
- ...typographyComponents[".label6"],
533
520
  height: theme("height.12"),
534
521
  },
535
522
  ".btn-medium": {
536
- ...typographyComponents[".label5"],
537
523
  height: theme("height.14"),
538
524
  },
539
525
  ".btn-large": {
540
- ...typographyComponents[".label5"],
541
526
  height: theme("height.16"),
542
527
  },
543
528
  ".btn-x-large": {
544
- ...typographyComponents[".heading3"],
545
529
  height: theme("height.22"),
546
530
  },
547
531
  };