@windstream/react-shared-components 0.0.70 → 0.0.72

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 (141) hide show
  1. package/README.md +629 -629
  2. package/dist/contentful/index.d.ts +17 -8
  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 +2 -2
  8. package/dist/index.d.ts +1 -1
  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 +175 -175
  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 +219 -219
  21. package/src/components/brand-button/helpers.ts +35 -35
  22. package/src/components/brand-button/index.tsx +93 -93
  23. package/src/components/brand-button/types.ts +25 -25
  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 +79 -86
  29. package/src/components/call-button/types.ts +10 -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/collapse/Collapse.stories.tsx +255 -255
  35. package/src/components/collapse/index.tsx +46 -46
  36. package/src/components/collapse/types.ts +6 -6
  37. package/src/components/divider/Divider.stories.tsx +205 -205
  38. package/src/components/divider/index.tsx +22 -22
  39. package/src/components/divider/type.ts +3 -3
  40. package/src/components/image/Image.stories.tsx +113 -113
  41. package/src/components/image/index.tsx +25 -25
  42. package/src/components/image/types.ts +40 -40
  43. package/src/components/input/Input.stories.tsx +325 -325
  44. package/src/components/input/index.tsx +177 -177
  45. package/src/components/input/types.ts +37 -37
  46. package/src/components/link/Link.stories.tsx +163 -163
  47. package/src/components/link/types.ts +25 -25
  48. package/src/components/list/List.stories.tsx +272 -272
  49. package/src/components/list/index.tsx +88 -88
  50. package/src/components/list/list-item/index.tsx +38 -38
  51. package/src/components/list/list-item/types.ts +13 -13
  52. package/src/components/list/types.ts +29 -29
  53. package/src/components/material-icon/MaterialIcon.stories.tsx +330 -330
  54. package/src/components/material-icon/constants.ts +96 -96
  55. package/src/components/material-icon/index.tsx +44 -44
  56. package/src/components/material-icon/types.ts +31 -31
  57. package/src/components/modal/Modal.stories.tsx +171 -171
  58. package/src/components/modal/index.tsx +164 -164
  59. package/src/components/modal/types.ts +24 -24
  60. package/src/components/next-image/index.tsx +32 -32
  61. package/src/components/next-image/types.ts +1 -1
  62. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  63. package/src/components/radio-button/index.tsx +75 -75
  64. package/src/components/radio-button/types.ts +21 -21
  65. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  66. package/src/components/see-more/index.tsx +44 -44
  67. package/src/components/see-more/types.ts +4 -4
  68. package/src/components/select/Select.stories.tsx +411 -411
  69. package/src/components/select/index.tsx +150 -150
  70. package/src/components/select/types.ts +35 -35
  71. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  72. package/src/components/select-plan-button/index.tsx +31 -31
  73. package/src/components/select-plan-button/types.ts +5 -5
  74. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  75. package/src/components/skeleton/index.tsx +61 -61
  76. package/src/components/skeleton/types.ts +4 -4
  77. package/src/components/spinner/Spinner.stories.tsx +335 -335
  78. package/src/components/spinner/index.tsx +44 -44
  79. package/src/components/spinner/types.ts +5 -5
  80. package/src/components/text/Text.stories.tsx +321 -321
  81. package/src/components/text/index.tsx +25 -25
  82. package/src/components/text/types.ts +45 -45
  83. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  84. package/src/components/tooltip/index.tsx +74 -74
  85. package/src/components/tooltip/types.ts +7 -7
  86. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  87. package/src/components/view-cart-button/index.tsx +44 -44
  88. package/src/components/view-cart-button/types.ts +5 -5
  89. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  90. package/src/contentful/blocks/button/index.tsx +64 -64
  91. package/src/contentful/blocks/button/types.ts +24 -24
  92. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  93. package/src/contentful/blocks/callout/index.tsx +66 -52
  94. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  95. package/src/contentful/blocks/cards/index.tsx +13 -13
  96. package/src/contentful/blocks/cards/product-card/index.tsx +199 -199
  97. package/src/contentful/blocks/cards/product-card/types.ts +18 -18
  98. package/src/contentful/blocks/cards/simple-card/index.tsx +77 -45
  99. package/src/contentful/blocks/cards/simple-card/types.ts +31 -9
  100. package/src/contentful/blocks/cards/testimonial-card/index.tsx +88 -88
  101. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  102. package/src/contentful/blocks/cards/types.ts +1 -1
  103. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  104. package/src/contentful/blocks/carousel/helper.tsx +314 -314
  105. package/src/contentful/blocks/carousel/index.tsx +50 -50
  106. package/src/contentful/blocks/carousel/types.ts +126 -126
  107. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  108. package/src/contentful/blocks/cta-callout/index.tsx +54 -54
  109. package/src/contentful/blocks/cta-callout/types.ts +22 -22
  110. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  111. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  112. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  113. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  114. package/src/contentful/blocks/image-promo-bar/types.ts +27 -27
  115. package/src/contentful/blocks/modal/Modal.stories.tsx +23 -23
  116. package/src/contentful/blocks/modal/index.tsx +12 -12
  117. package/src/contentful/blocks/modal/types.ts +1 -1
  118. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +111 -111
  119. package/src/contentful/blocks/navigation/index.tsx +366 -373
  120. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +80 -80
  121. package/src/contentful/blocks/navigation/types.ts +39 -41
  122. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  123. package/src/contentful/blocks/primary-hero/index.tsx +160 -160
  124. package/src/contentful/blocks/primary-hero/types.ts +30 -30
  125. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  126. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  127. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  128. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  129. package/src/contentful/blocks/text/index.tsx +12 -12
  130. package/src/contentful/blocks/text/types.ts +1 -1
  131. package/src/contentful/index.ts +57 -57
  132. package/src/hooks/use-body-scroll-lock.ts +34 -34
  133. package/src/hooks/use-outside-click.ts +17 -17
  134. package/src/index.ts +96 -96
  135. package/src/next/index.ts +5 -5
  136. package/src/setupTests.ts +46 -46
  137. package/src/stories/DocsTemplate.tsx +24 -24
  138. package/src/styles/globals.css +307 -307
  139. package/src/types/global.d.ts +9 -9
  140. package/src/types/micro-components.ts +80 -80
  141. 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] rounded-lg 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-xl 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-xl 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] rounded-lg 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-xl 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-xl 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
+ };