@windstream/react-shared-components 0.0.97 → 0.0.99

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 (139) hide show
  1. package/README.md +635 -635
  2. package/dist/contentful/index.esm.js +1 -1
  3. package/dist/contentful/index.esm.js.map +1 -1
  4. package/dist/contentful/index.js +1 -1
  5. package/dist/contentful/index.js.map +1 -1
  6. package/dist/index.js.map +1 -1
  7. package/package.json +177 -177
  8. package/src/components/accordion/Accordion.stories.tsx +230 -230
  9. package/src/components/accordion/types.ts +11 -11
  10. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  11. package/src/components/alert-card/index.tsx +38 -38
  12. package/src/components/alert-card/types.ts +12 -12
  13. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  14. package/src/components/brand-button/helpers.ts +35 -35
  15. package/src/components/brand-button/index.tsx +115 -115
  16. package/src/components/brand-button/types.ts +37 -37
  17. package/src/components/button/Button.stories.tsx +108 -108
  18. package/src/components/button/index.tsx +27 -27
  19. package/src/components/button/types.ts +14 -14
  20. package/src/components/call-button/CallButton.stories.tsx +324 -324
  21. package/src/components/call-button/index.tsx +86 -86
  22. package/src/components/call-button/types.ts +11 -11
  23. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  24. package/src/components/checkbox/index.tsx +197 -197
  25. package/src/components/checkbox/types.ts +27 -27
  26. package/src/components/checklist/Checklist.stories.tsx +150 -150
  27. package/src/components/checklist/index.tsx +55 -55
  28. package/src/components/checklist/types.ts +14 -14
  29. package/src/components/collapse/Collapse.stories.tsx +255 -255
  30. package/src/components/collapse/index.tsx +46 -46
  31. package/src/components/collapse/types.ts +6 -6
  32. package/src/components/divider/Divider.stories.tsx +205 -205
  33. package/src/components/divider/index.tsx +22 -22
  34. package/src/components/divider/type.ts +3 -3
  35. package/src/components/image/Image.stories.tsx +113 -113
  36. package/src/components/image/index.tsx +25 -25
  37. package/src/components/image/types.ts +40 -40
  38. package/src/components/input/Input.stories.tsx +325 -325
  39. package/src/components/input/index.tsx +177 -177
  40. package/src/components/input/types.ts +37 -37
  41. package/src/components/link/Link.stories.tsx +163 -163
  42. package/src/components/link/types.ts +25 -25
  43. package/src/components/list/List.stories.tsx +272 -272
  44. package/src/components/list/index.tsx +88 -88
  45. package/src/components/list/list-item/index.tsx +38 -38
  46. package/src/components/list/list-item/types.ts +13 -13
  47. package/src/components/list/types.ts +29 -29
  48. package/src/components/material-icon/MaterialIcon.stories.tsx +322 -322
  49. package/src/components/material-icon/constants.ts +98 -98
  50. package/src/components/material-icon/index.tsx +47 -47
  51. package/src/components/material-icon/types.ts +31 -31
  52. package/src/components/modal/Modal.stories.tsx +171 -171
  53. package/src/components/modal/index.tsx +164 -164
  54. package/src/components/modal/types.ts +24 -24
  55. package/src/components/next-image/index.tsx +32 -32
  56. package/src/components/next-image/types.ts +1 -1
  57. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  58. package/src/components/radio-button/index.tsx +75 -75
  59. package/src/components/radio-button/types.ts +21 -21
  60. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  61. package/src/components/see-more/index.tsx +44 -44
  62. package/src/components/see-more/types.ts +4 -4
  63. package/src/components/select/Select.stories.tsx +411 -411
  64. package/src/components/select/index.tsx +150 -150
  65. package/src/components/select/types.ts +35 -35
  66. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  67. package/src/components/select-plan-button/index.tsx +57 -57
  68. package/src/components/select-plan-button/types.ts +14 -14
  69. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  70. package/src/components/skeleton/index.tsx +61 -61
  71. package/src/components/skeleton/types.ts +4 -4
  72. package/src/components/spinner/Spinner.stories.tsx +335 -335
  73. package/src/components/spinner/index.tsx +44 -44
  74. package/src/components/spinner/types.ts +5 -5
  75. package/src/components/text/Text.stories.tsx +321 -321
  76. package/src/components/text/index.tsx +25 -25
  77. package/src/components/text/types.ts +45 -45
  78. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  79. package/src/components/tooltip/index.tsx +74 -74
  80. package/src/components/tooltip/types.ts +7 -7
  81. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  82. package/src/components/view-cart-button/index.tsx +42 -42
  83. package/src/components/view-cart-button/types.ts +5 -5
  84. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  85. package/src/contentful/blocks/button/index.tsx +107 -107
  86. package/src/contentful/blocks/button/types.ts +34 -34
  87. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  88. package/src/contentful/blocks/callout/index.tsx +66 -66
  89. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  90. package/src/contentful/blocks/cards/index.tsx +13 -13
  91. package/src/contentful/blocks/cards/product-card/index.tsx +206 -206
  92. package/src/contentful/blocks/cards/product-card/types.ts +28 -28
  93. package/src/contentful/blocks/cards/testimonial-card/index.tsx +88 -88
  94. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  95. package/src/contentful/blocks/cards/types.ts +1 -1
  96. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  97. package/src/contentful/blocks/carousel/helper.tsx +356 -356
  98. package/src/contentful/blocks/carousel/index.tsx +74 -74
  99. package/src/contentful/blocks/carousel/types.ts +143 -143
  100. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  101. package/src/contentful/blocks/cta-callout/index.tsx +60 -60
  102. package/src/contentful/blocks/cta-callout/types.ts +26 -26
  103. package/src/contentful/blocks/find-kinetic/index.tsx +124 -124
  104. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  105. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  106. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  107. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  108. package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
  109. package/src/contentful/blocks/image-promo-bar/index.tsx +234 -234
  110. package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
  111. package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
  112. package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
  113. package/src/contentful/blocks/modal/constants.ts +53 -53
  114. package/src/contentful/blocks/modal/index.tsx +91 -91
  115. package/src/contentful/blocks/modal/types.ts +12 -12
  116. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +111 -111
  117. package/src/contentful/blocks/navigation/index.tsx +385 -385
  118. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +80 -80
  119. package/src/contentful/blocks/navigation/types.ts +41 -41
  120. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  121. package/src/contentful/blocks/primary-hero/index.tsx +229 -229
  122. package/src/contentful/blocks/primary-hero/types.ts +35 -35
  123. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  124. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  125. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  126. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  127. package/src/contentful/blocks/text/index.tsx +12 -12
  128. package/src/contentful/blocks/text/types.ts +1 -1
  129. package/src/contentful/index.ts +57 -57
  130. package/src/hooks/use-body-scroll-lock.ts +34 -34
  131. package/src/hooks/use-outside-click.ts +17 -17
  132. package/src/index.ts +96 -96
  133. package/src/next/index.ts +5 -5
  134. package/src/setupTests.ts +46 -46
  135. package/src/stories/DocsTemplate.tsx +24 -24
  136. package/src/styles/globals.css +343 -343
  137. package/src/types/global.d.ts +9 -9
  138. package/src/types/micro-components.ts +99 -99
  139. package/src/utils/index.ts +49 -49
@@ -1,177 +1,177 @@
1
- "use client";
2
-
3
- import {
4
- FocusEventHandler,
5
- forwardRef,
6
- ForwardRefRenderFunction,
7
- MouseEventHandler,
8
- useCallback,
9
- useState,
10
- } from "react";
11
- import { InputFieldProps, InputProps } from "./types";
12
-
13
- import { MaterialIcon } from "@shared/components/material-icon";
14
- import { Text } from "@shared/components/text";
15
- import { cx } from "@shared/utils";
16
-
17
- export const InputField: ForwardRefRenderFunction<
18
- HTMLInputElement,
19
- InputFieldProps
20
- > = (props, ref) => {
21
- const {
22
- className,
23
- size,
24
- required,
25
- placeholder,
26
- label,
27
- state,
28
- errorText,
29
- prefixIconName,
30
- prefixIconFill = true,
31
- suffixIconFill = false,
32
- prefixIconSize = 24,
33
- suffixIconName,
34
- suffixIconSize = 24,
35
- containerClassName,
36
- prefixIconClassName,
37
- loading,
38
- hasError,
39
- type,
40
- // Filter out all non-DOM props
41
- ...rest
42
- } = props;
43
-
44
- // Use hasError to override state if provided
45
- const effectiveState = hasError ? "error" : state;
46
-
47
- const sizeClasses = {
48
- sm: "h-[48px] px-3 py-2",
49
- slim: "h-12",
50
- medium: "h-14",
51
- large: "h-[60px]",
52
- };
53
-
54
- const [isHovered, setIsHovered] = useState(false);
55
- const [isFocused, setIsFocused] = useState(false);
56
- const [inputType, setInputType] = useState(type || "text");
57
-
58
- const handleMouseOver = () => setIsHovered(true);
59
- const handleMouseOut = () => setIsHovered(false);
60
- const handleFocus: FocusEventHandler<HTMLInputElement> = e => {
61
- rest.onFocus?.(e);
62
- setIsFocused(true);
63
- };
64
- const handleBlur: FocusEventHandler<HTMLInputElement> = e => {
65
- rest.onBlur?.(e);
66
- setIsFocused(false);
67
- };
68
-
69
- const togglePasswordVisibility = useCallback<
70
- MouseEventHandler<HTMLDivElement>
71
- >(e => {
72
- e.stopPropagation();
73
- setInputType(prevType => (prevType === "password" ? "text" : "password"));
74
- }, []);
75
-
76
- return (
77
- <div className="relative">
78
- {label ? (
79
- <label htmlFor={label} className={cx("inline-block pb-1")}>
80
- <Text as="span" className="footnote text-text">
81
- {label}
82
- {required ? (
83
- <span className="pl-1 text-text-critical">*</span>
84
- ) : null}
85
- </Text>
86
- </label>
87
- ) : null}
88
-
89
- <div
90
- className={cx(
91
- "relative flex flex-row items-center overflow-hidden rounded-input border border-input-border bg-input-bg-surface",
92
- sizeClasses[size || "medium"],
93
- containerClassName,
94
- (isHovered || effectiveState === "hover") &&
95
- !isFocused &&
96
- effectiveState !== "error" &&
97
- "border-input-border-hover",
98
- (isFocused ||
99
- effectiveState === "focus" ||
100
- effectiveState === "active") &&
101
- "border-input-border-selected outline outline-1 outline-input-border-selected",
102
- effectiveState === "error" &&
103
- "border-input-border-critical outline outline-1 outline-input-border-critical"
104
- )}
105
- >
106
- {prefixIconName ? (
107
- <div
108
- className="mr-1"
109
- style={{
110
- width: prefixIconSize,
111
- height: prefixIconSize,
112
- overflow: "hidden",
113
- }}
114
- >
115
- <MaterialIcon
116
- name={prefixIconName}
117
- fill={prefixIconFill ? 1 : 0}
118
- size={prefixIconSize}
119
- className={cx(prefixIconClassName)}
120
- />
121
- </div>
122
- ) : null}
123
- <input
124
- ref={ref}
125
- id={label}
126
- disabled={loading || rest.disabled}
127
- className={cx(
128
- "h-full grow rounded-input p-4 caret-bg-inverse placeholder:text-input-text-placeholder focus:border-none focus:outline-none",
129
- "text-body2",
130
- size === "slim" && "text-body3",
131
- className
132
- )}
133
- placeholder={placeholder}
134
- type={inputType}
135
- {...rest}
136
- onMouseOver={handleMouseOver}
137
- onMouseOut={handleMouseOut}
138
- onFocus={handleFocus}
139
- onBlur={handleBlur}
140
- />
141
- {suffixIconName ? (
142
- <div
143
- className="ml-2"
144
- style={{
145
- width: suffixIconSize,
146
- height: suffixIconSize,
147
- overflow: "hidden",
148
- }}
149
- onClick={togglePasswordVisibility}
150
- >
151
- <MaterialIcon
152
- name={inputType === "text" ? "visibility" : "visibility_off"}
153
- size={suffixIconSize}
154
- fill={suffixIconFill ? 1 : 0}
155
- />
156
- </div>
157
- ) : null}
158
- </div>
159
- {effectiveState === "error" && errorText && errorText != "" ? (
160
- <Text
161
- className={cx(
162
- "footnote left-0 top-full inline-flex items-center pt-1 text-text-critical"
163
- )}
164
- >
165
- <MaterialIcon name="info" size={20} className="mr-1" />
166
- {errorText || "Error"}
167
- </Text>
168
- ) : null}
169
- </div>
170
- );
171
- };
172
-
173
- export const Input = forwardRef<HTMLInputElement, InputFieldProps>(InputField);
174
-
175
- Input.displayName = "Input";
176
-
177
- export type { InputFieldProps, InputProps };
1
+ "use client";
2
+
3
+ import {
4
+ FocusEventHandler,
5
+ forwardRef,
6
+ ForwardRefRenderFunction,
7
+ MouseEventHandler,
8
+ useCallback,
9
+ useState,
10
+ } from "react";
11
+ import { InputFieldProps, InputProps } from "./types";
12
+
13
+ import { MaterialIcon } from "@shared/components/material-icon";
14
+ import { Text } from "@shared/components/text";
15
+ import { cx } from "@shared/utils";
16
+
17
+ export const InputField: ForwardRefRenderFunction<
18
+ HTMLInputElement,
19
+ InputFieldProps
20
+ > = (props, ref) => {
21
+ const {
22
+ className,
23
+ size,
24
+ required,
25
+ placeholder,
26
+ label,
27
+ state,
28
+ errorText,
29
+ prefixIconName,
30
+ prefixIconFill = true,
31
+ suffixIconFill = false,
32
+ prefixIconSize = 24,
33
+ suffixIconName,
34
+ suffixIconSize = 24,
35
+ containerClassName,
36
+ prefixIconClassName,
37
+ loading,
38
+ hasError,
39
+ type,
40
+ // Filter out all non-DOM props
41
+ ...rest
42
+ } = props;
43
+
44
+ // Use hasError to override state if provided
45
+ const effectiveState = hasError ? "error" : state;
46
+
47
+ const sizeClasses = {
48
+ sm: "h-[48px] px-3 py-2",
49
+ slim: "h-12",
50
+ medium: "h-14",
51
+ large: "h-[60px]",
52
+ };
53
+
54
+ const [isHovered, setIsHovered] = useState(false);
55
+ const [isFocused, setIsFocused] = useState(false);
56
+ const [inputType, setInputType] = useState(type || "text");
57
+
58
+ const handleMouseOver = () => setIsHovered(true);
59
+ const handleMouseOut = () => setIsHovered(false);
60
+ const handleFocus: FocusEventHandler<HTMLInputElement> = e => {
61
+ rest.onFocus?.(e);
62
+ setIsFocused(true);
63
+ };
64
+ const handleBlur: FocusEventHandler<HTMLInputElement> = e => {
65
+ rest.onBlur?.(e);
66
+ setIsFocused(false);
67
+ };
68
+
69
+ const togglePasswordVisibility = useCallback<
70
+ MouseEventHandler<HTMLDivElement>
71
+ >(e => {
72
+ e.stopPropagation();
73
+ setInputType(prevType => (prevType === "password" ? "text" : "password"));
74
+ }, []);
75
+
76
+ return (
77
+ <div className="relative">
78
+ {label ? (
79
+ <label htmlFor={label} className={cx("inline-block pb-1")}>
80
+ <Text as="span" className="footnote text-text">
81
+ {label}
82
+ {required ? (
83
+ <span className="pl-1 text-text-critical">*</span>
84
+ ) : null}
85
+ </Text>
86
+ </label>
87
+ ) : null}
88
+
89
+ <div
90
+ className={cx(
91
+ "relative flex flex-row items-center overflow-hidden rounded-input border border-input-border bg-input-bg-surface",
92
+ sizeClasses[size || "medium"],
93
+ containerClassName,
94
+ (isHovered || effectiveState === "hover") &&
95
+ !isFocused &&
96
+ effectiveState !== "error" &&
97
+ "border-input-border-hover",
98
+ (isFocused ||
99
+ effectiveState === "focus" ||
100
+ effectiveState === "active") &&
101
+ "border-input-border-selected outline outline-1 outline-input-border-selected",
102
+ effectiveState === "error" &&
103
+ "border-input-border-critical outline outline-1 outline-input-border-critical"
104
+ )}
105
+ >
106
+ {prefixIconName ? (
107
+ <div
108
+ className="mr-1"
109
+ style={{
110
+ width: prefixIconSize,
111
+ height: prefixIconSize,
112
+ overflow: "hidden",
113
+ }}
114
+ >
115
+ <MaterialIcon
116
+ name={prefixIconName}
117
+ fill={prefixIconFill ? 1 : 0}
118
+ size={prefixIconSize}
119
+ className={cx(prefixIconClassName)}
120
+ />
121
+ </div>
122
+ ) : null}
123
+ <input
124
+ ref={ref}
125
+ id={label}
126
+ disabled={loading || rest.disabled}
127
+ className={cx(
128
+ "h-full grow rounded-input p-4 caret-bg-inverse placeholder:text-input-text-placeholder focus:border-none focus:outline-none",
129
+ "text-body2",
130
+ size === "slim" && "text-body3",
131
+ className
132
+ )}
133
+ placeholder={placeholder}
134
+ type={inputType}
135
+ {...rest}
136
+ onMouseOver={handleMouseOver}
137
+ onMouseOut={handleMouseOut}
138
+ onFocus={handleFocus}
139
+ onBlur={handleBlur}
140
+ />
141
+ {suffixIconName ? (
142
+ <div
143
+ className="ml-2"
144
+ style={{
145
+ width: suffixIconSize,
146
+ height: suffixIconSize,
147
+ overflow: "hidden",
148
+ }}
149
+ onClick={togglePasswordVisibility}
150
+ >
151
+ <MaterialIcon
152
+ name={inputType === "text" ? "visibility" : "visibility_off"}
153
+ size={suffixIconSize}
154
+ fill={suffixIconFill ? 1 : 0}
155
+ />
156
+ </div>
157
+ ) : null}
158
+ </div>
159
+ {effectiveState === "error" && errorText && errorText != "" ? (
160
+ <Text
161
+ className={cx(
162
+ "footnote left-0 top-full inline-flex items-center pt-1 text-text-critical"
163
+ )}
164
+ >
165
+ <MaterialIcon name="info" size={20} className="mr-1" />
166
+ {errorText || "Error"}
167
+ </Text>
168
+ ) : null}
169
+ </div>
170
+ );
171
+ };
172
+
173
+ export const Input = forwardRef<HTMLInputElement, InputFieldProps>(InputField);
174
+
175
+ Input.displayName = "Input";
176
+
177
+ export type { InputFieldProps, InputProps };
@@ -1,37 +1,37 @@
1
- import { InputHTMLAttributes, ReactNode } from "react";
2
-
3
- export type InputProps = Omit<InputHTMLAttributes<HTMLInputElement>, "size"> & {
4
- loading?: boolean;
5
- iconLeft?: ReactNode;
6
- size?: "sm" | "md";
7
- hasError?: boolean;
8
- label?: string;
9
- labelClassName?: string;
10
- containerClassName?: string;
11
- mapPinIcon?: boolean;
12
- isLightMapPinIcon?: boolean;
13
- passwordToggle?: boolean;
14
- helperText?: string;
15
- error?: string;
16
- variant?: "default" | "unstyled";
17
- };
18
-
19
- export type InputFieldProps = Omit<
20
- InputHTMLAttributes<HTMLInputElement>,
21
- "size"
22
- > & {
23
- state?: "default" | "focus" | "active" | "hover" | "filled" | "error";
24
- size?: "slim" | "medium" | "large";
25
- label?: string;
26
- errorText?: string;
27
- prefixIconName?: "location_on" | "search";
28
- prefixIconSize?: 20 | 24 | 40 | 48;
29
- prefixIconFill?: boolean;
30
- suffixIconFill?: boolean;
31
- suffixIconName?: "visibility" | "visibility_off" | "lock";
32
- suffixIconSize?: 20 | 24 | 40 | 48;
33
- containerClassName?: string;
34
- prefixIconClassName?: string;
35
- loading?: boolean;
36
- hasError?: boolean;
37
- };
1
+ import { InputHTMLAttributes, ReactNode } from "react";
2
+
3
+ export type InputProps = Omit<InputHTMLAttributes<HTMLInputElement>, "size"> & {
4
+ loading?: boolean;
5
+ iconLeft?: ReactNode;
6
+ size?: "sm" | "md";
7
+ hasError?: boolean;
8
+ label?: string;
9
+ labelClassName?: string;
10
+ containerClassName?: string;
11
+ mapPinIcon?: boolean;
12
+ isLightMapPinIcon?: boolean;
13
+ passwordToggle?: boolean;
14
+ helperText?: string;
15
+ error?: string;
16
+ variant?: "default" | "unstyled";
17
+ };
18
+
19
+ export type InputFieldProps = Omit<
20
+ InputHTMLAttributes<HTMLInputElement>,
21
+ "size"
22
+ > & {
23
+ state?: "default" | "focus" | "active" | "hover" | "filled" | "error";
24
+ size?: "slim" | "medium" | "large";
25
+ label?: string;
26
+ errorText?: string;
27
+ prefixIconName?: "location_on" | "search";
28
+ prefixIconSize?: 20 | 24 | 40 | 48;
29
+ prefixIconFill?: boolean;
30
+ suffixIconFill?: boolean;
31
+ suffixIconName?: "visibility" | "visibility_off" | "lock";
32
+ suffixIconSize?: 20 | 24 | 40 | 48;
33
+ containerClassName?: string;
34
+ prefixIconClassName?: string;
35
+ loading?: boolean;
36
+ hasError?: boolean;
37
+ };