@windstream/react-shared-components 0.1.20 → 0.1.21

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 (160) hide show
  1. package/README.md +635 -635
  2. package/dist/contentful/index.esm.js +3 -3
  3. package/dist/contentful/index.esm.js.map +1 -1
  4. package/dist/contentful/index.js +1 -1
  5. package/dist/contentful/index.js.map +1 -1
  6. package/dist/core.d.ts +1 -1
  7. package/dist/index.d.ts +1 -1
  8. package/dist/index.esm.js +6 -6
  9. package/dist/index.esm.js.map +1 -1
  10. package/dist/index.js +6 -6
  11. package/dist/index.js.map +1 -1
  12. package/package.json +182 -182
  13. package/src/components/accordion/Accordion.stories.tsx +230 -230
  14. package/src/components/accordion/types.ts +11 -11
  15. package/src/components/alert-card/AlertCard.stories.tsx +171 -171
  16. package/src/components/alert-card/index.tsx +41 -41
  17. package/src/components/alert-card/types.ts +13 -13
  18. package/src/components/brand-button/BrandButton.stories.tsx +223 -223
  19. package/src/components/brand-button/helpers.ts +35 -35
  20. package/src/components/brand-button/index.tsx +115 -115
  21. package/src/components/brand-button/types.ts +37 -37
  22. package/src/components/button/Button.stories.tsx +108 -108
  23. package/src/components/button/index.tsx +27 -27
  24. package/src/components/button/types.ts +14 -14
  25. package/src/components/call-button/CallButton.stories.tsx +324 -324
  26. package/src/components/call-button/index.tsx +86 -86
  27. package/src/components/call-button/types.ts +11 -11
  28. package/src/components/checkbox/Checkbox.stories.tsx +247 -247
  29. package/src/components/checkbox/index.tsx +197 -197
  30. package/src/components/checkbox/types.ts +27 -27
  31. package/src/components/checklist/Checklist.stories.tsx +150 -150
  32. package/src/components/checklist/index.tsx +59 -59
  33. package/src/components/checklist/types.ts +16 -16
  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/index.tsx +14 -2
  48. package/src/components/link/types.ts +25 -25
  49. package/src/components/list/List.stories.tsx +272 -272
  50. package/src/components/list/index.tsx +88 -88
  51. package/src/components/list/list-item/index.tsx +38 -38
  52. package/src/components/list/list-item/types.ts +13 -13
  53. package/src/components/list/types.ts +29 -29
  54. package/src/components/material-icon/MaterialIcon.stories.tsx +322 -322
  55. package/src/components/material-icon/constants.ts +98 -98
  56. package/src/components/material-icon/index.tsx +47 -47
  57. package/src/components/material-icon/types.ts +31 -31
  58. package/src/components/modal/Modal.stories.tsx +171 -171
  59. package/src/components/modal/index.tsx +164 -164
  60. package/src/components/modal/types.ts +24 -24
  61. package/src/components/next-image/index.tsx +54 -54
  62. package/src/components/next-image/types.ts +1 -1
  63. package/src/components/pagination/index.tsx +100 -100
  64. package/src/components/pagination/types.ts +6 -6
  65. package/src/components/radio-button/RadioButton.stories.tsx +307 -307
  66. package/src/components/radio-button/index.tsx +75 -75
  67. package/src/components/radio-button/types.ts +21 -21
  68. package/src/components/see-more/SeeMore.stories.tsx +181 -181
  69. package/src/components/see-more/index.tsx +44 -44
  70. package/src/components/see-more/types.ts +4 -4
  71. package/src/components/select/Select.stories.tsx +411 -411
  72. package/src/components/select/index.tsx +155 -155
  73. package/src/components/select/types.ts +36 -36
  74. package/src/components/select-plan-button/SelectPlanButton.stories.tsx +184 -184
  75. package/src/components/select-plan-button/index.tsx +57 -57
  76. package/src/components/select-plan-button/types.ts +14 -14
  77. package/src/components/skeleton/Skeleton.stories.tsx +179 -179
  78. package/src/components/skeleton/index.tsx +61 -61
  79. package/src/components/skeleton/types.ts +4 -4
  80. package/src/components/spinner/Spinner.stories.tsx +335 -335
  81. package/src/components/spinner/index.tsx +44 -44
  82. package/src/components/spinner/types.ts +5 -5
  83. package/src/components/text/Text.stories.tsx +321 -321
  84. package/src/components/text/index.tsx +25 -25
  85. package/src/components/text/types.ts +45 -45
  86. package/src/components/tooltip/Tooltip.stories.tsx +219 -219
  87. package/src/components/tooltip/index.tsx +74 -74
  88. package/src/components/tooltip/types.ts +7 -7
  89. package/src/components/view-cart-button/ViewCartButton.stories.tsx +252 -252
  90. package/src/components/view-cart-button/index.tsx +42 -42
  91. package/src/components/view-cart-button/types.ts +5 -5
  92. package/src/contentful/blocks/address-input-banner/index.tsx +52 -52
  93. package/src/contentful/blocks/address-input-banner/types.ts +14 -14
  94. package/src/contentful/blocks/blogs-grid/index.tsx +129 -129
  95. package/src/contentful/blocks/blogs-grid/types.ts +26 -26
  96. package/src/contentful/blocks/button/Button.stories.tsx +40 -40
  97. package/src/contentful/blocks/button/index.tsx +121 -121
  98. package/src/contentful/blocks/button/types.ts +36 -36
  99. package/src/contentful/blocks/callout/Callout.stories.tsx +23 -23
  100. package/src/contentful/blocks/callout/index.tsx +86 -86
  101. package/src/contentful/blocks/callout/types.ts +15 -15
  102. package/src/contentful/blocks/cards/Cards.stories.tsx +23 -23
  103. package/src/contentful/blocks/cards/blog-card/index.tsx +104 -104
  104. package/src/contentful/blocks/cards/blog-card/types.ts +15 -15
  105. package/src/contentful/blocks/cards/index.tsx +13 -13
  106. package/src/contentful/blocks/cards/product-card/index.tsx +208 -208
  107. package/src/contentful/blocks/cards/product-card/types.ts +28 -28
  108. package/src/contentful/blocks/cards/testimonial-card/index.tsx +88 -88
  109. package/src/contentful/blocks/cards/testimonial-card/types.tsx +12 -12
  110. package/src/contentful/blocks/cards/types.ts +1 -1
  111. package/src/contentful/blocks/carousel/Carousel.stories.tsx +23 -23
  112. package/src/contentful/blocks/carousel/helper.tsx +356 -356
  113. package/src/contentful/blocks/carousel/index.tsx +73 -73
  114. package/src/contentful/blocks/carousel/types.ts +143 -143
  115. package/src/contentful/blocks/cta-callout/CtaCallout.stories.tsx +46 -46
  116. package/src/contentful/blocks/cta-callout/index.tsx +60 -60
  117. package/src/contentful/blocks/cta-callout/types.ts +26 -26
  118. package/src/contentful/blocks/dynamic-tabs/index.tsx +204 -204
  119. package/src/contentful/blocks/dynamic-tabs/types.ts +21 -21
  120. package/src/contentful/blocks/find-kinetic/index.tsx +130 -130
  121. package/src/contentful/blocks/floating-banner/FloatingBanner.stories.tsx +34 -34
  122. package/src/contentful/blocks/floating-banner/index.tsx +97 -97
  123. package/src/contentful/blocks/floating-banner/types.ts +22 -22
  124. package/src/contentful/blocks/footer/Footer.stories.tsx +30 -30
  125. package/src/contentful/blocks/image-promo-bar/ImagePromoBar.stories.tsx +23 -23
  126. package/src/contentful/blocks/image-promo-bar/helper.tsx +28 -28
  127. package/src/contentful/blocks/image-promo-bar/types.ts +44 -44
  128. package/src/contentful/blocks/image-promo-bar/vimeo-embed.tsx +93 -93
  129. package/src/contentful/blocks/image-promo-bar/youtube-embed.tsx +46 -46
  130. package/src/contentful/blocks/modal/constants.ts +53 -53
  131. package/src/contentful/blocks/modal/index.tsx +91 -91
  132. package/src/contentful/blocks/modal/types.ts +12 -12
  133. package/src/contentful/blocks/navigation/desktop-link-groups.tsx/index.tsx +113 -113
  134. package/src/contentful/blocks/navigation/index.tsx +394 -394
  135. package/src/contentful/blocks/navigation/mobile-link-groups.tsx/index.tsx +82 -82
  136. package/src/contentful/blocks/navigation/types.ts +41 -41
  137. package/src/contentful/blocks/primary-hero/PrimaryHero.stories.tsx +23 -23
  138. package/src/contentful/blocks/primary-hero/index.tsx +234 -234
  139. package/src/contentful/blocks/primary-hero/types.ts +35 -35
  140. package/src/contentful/blocks/search-block/index.tsx +90 -90
  141. package/src/contentful/blocks/shape-background-wrapper/ShapeBackgroundWrapper.stories.tsx +26 -26
  142. package/src/contentful/blocks/shape-background-wrapper/index.tsx +124 -124
  143. package/src/contentful/blocks/shape-background-wrapper/types.ts +36 -36
  144. package/src/contentful/blocks/text/Text.stories.tsx +23 -23
  145. package/src/contentful/blocks/text/index.tsx +12 -12
  146. package/src/contentful/blocks/text/types.ts +1 -1
  147. package/src/contentful/index.ts +75 -75
  148. package/src/hooks/use-body-scroll-lock.ts +34 -34
  149. package/src/hooks/use-outside-click.ts +17 -17
  150. package/src/index.ts +96 -96
  151. package/src/next/index.ts +5 -5
  152. package/src/setupTests.ts +46 -46
  153. package/src/stories/DocsTemplate.tsx +24 -24
  154. package/src/styles/globals.css +343 -343
  155. package/src/types/global.d.ts +9 -9
  156. package/src/types/micro-components.ts +99 -99
  157. package/src/types/utm.ts +49 -49
  158. package/src/utils/cookie.ts +58 -58
  159. package/src/utils/index.ts +65 -65
  160. package/src/utils/utm.ts +221 -221
@@ -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
+ };