@coopdigital/react 0.45.0 → 0.47.0

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 (207) hide show
  1. package/dist/components/AlertBanner/AlertBanner.d.ts +4 -2
  2. package/dist/components/AlertBanner/AlertBanner.js +2 -2
  3. package/dist/components/Author/Author.d.ts +4 -2
  4. package/dist/components/Author/Author.js +2 -2
  5. package/dist/components/Button/Button.d.ts +6 -4
  6. package/dist/components/Button/Button.js +4 -7
  7. package/dist/components/Card/Card.d.ts +4 -2
  8. package/dist/components/Card/Card.js +4 -4
  9. package/dist/components/Checkbox/Checkbox.d.ts +4 -2
  10. package/dist/components/Checkbox/Checkbox.js +2 -2
  11. package/dist/components/Expandable/Expandable.d.ts +4 -2
  12. package/dist/components/Expandable/Expandable.js +4 -4
  13. package/dist/components/Field/Field.d.ts +4 -2
  14. package/dist/components/Field/Field.js +7 -8
  15. package/dist/components/FieldMarkers/Error.d.ts +4 -2
  16. package/dist/components/FieldMarkers/Error.js +2 -2
  17. package/dist/components/FieldMarkers/Hint.d.ts +5 -3
  18. package/dist/components/FieldMarkers/Hint.js +2 -2
  19. package/dist/components/FieldMarkers/Label.d.ts +4 -2
  20. package/dist/components/FieldMarkers/Label.js +6 -2
  21. package/dist/components/FieldMarkers/Legend.d.ts +4 -2
  22. package/dist/components/FieldMarkers/Legend.js +2 -2
  23. package/dist/components/Fieldset/Fieldset.d.ts +4 -2
  24. package/dist/components/Fieldset/Fieldset.js +2 -4
  25. package/dist/components/Flourish/Flourish.d.ts +4 -2
  26. package/dist/components/Flourish/Flourish.js +2 -2
  27. package/dist/components/Icon/AddIcon.d.ts +1 -1
  28. package/dist/components/Icon/AddIcon.js +6 -5
  29. package/dist/components/Icon/ArrowDownIcon.d.ts +1 -1
  30. package/dist/components/Icon/ArrowDownIcon.js +6 -5
  31. package/dist/components/Icon/ArrowLeftIcon.d.ts +1 -1
  32. package/dist/components/Icon/ArrowLeftIcon.js +6 -5
  33. package/dist/components/Icon/ArrowRightIcon.d.ts +1 -1
  34. package/dist/components/Icon/ArrowRightIcon.js +6 -5
  35. package/dist/components/Icon/ArrowUpIcon.d.ts +1 -1
  36. package/dist/components/Icon/ArrowUpIcon.js +6 -5
  37. package/dist/components/Icon/AvatarAltIcon.d.ts +1 -1
  38. package/dist/components/Icon/AvatarAltIcon.js +6 -5
  39. package/dist/components/Icon/AvatarIcon.d.ts +1 -1
  40. package/dist/components/Icon/AvatarIcon.js +6 -5
  41. package/dist/components/Icon/BasketIcon.d.ts +1 -1
  42. package/dist/components/Icon/BasketIcon.js +6 -5
  43. package/dist/components/Icon/CalendarIcon.d.ts +1 -1
  44. package/dist/components/Icon/CalendarIcon.js +6 -5
  45. package/dist/components/Icon/ChevronDownIcon.d.ts +1 -1
  46. package/dist/components/Icon/ChevronDownIcon.js +6 -5
  47. package/dist/components/Icon/ChevronLeftIcon.d.ts +1 -1
  48. package/dist/components/Icon/ChevronLeftIcon.js +6 -5
  49. package/dist/components/Icon/ChevronRightIcon.d.ts +1 -1
  50. package/dist/components/Icon/ChevronRightIcon.js +6 -5
  51. package/dist/components/Icon/ChevronUpIcon.d.ts +1 -1
  52. package/dist/components/Icon/ChevronUpIcon.js +6 -5
  53. package/dist/components/Icon/ClockIcon.d.ts +1 -1
  54. package/dist/components/Icon/ClockIcon.js +6 -5
  55. package/dist/components/Icon/CloseAltIcon.d.ts +1 -1
  56. package/dist/components/Icon/CloseAltIcon.js +6 -5
  57. package/dist/components/Icon/CloseIcon.d.ts +1 -1
  58. package/dist/components/Icon/CloseIcon.js +6 -5
  59. package/dist/components/Icon/CoopCardIcon.d.ts +1 -1
  60. package/dist/components/Icon/CoopCardIcon.js +6 -5
  61. package/dist/components/Icon/CoopIcon.d.ts +1 -1
  62. package/dist/components/Icon/CoopIcon.js +6 -5
  63. package/dist/components/Icon/CoopLocationIcon.d.ts +1 -1
  64. package/dist/components/Icon/CoopLocationIcon.js +6 -5
  65. package/dist/components/Icon/DownloadIcon.d.ts +1 -1
  66. package/dist/components/Icon/DownloadIcon.js +6 -5
  67. package/dist/components/Icon/HomeIcon.d.ts +1 -1
  68. package/dist/components/Icon/HomeIcon.js +6 -5
  69. package/dist/components/Icon/InformationIcon.d.ts +1 -1
  70. package/dist/components/Icon/InformationIcon.js +6 -5
  71. package/dist/components/Icon/LoadingIcon.d.ts +1 -1
  72. package/dist/components/Icon/LoadingIcon.js +6 -5
  73. package/dist/components/Icon/LocationIcon.d.ts +1 -1
  74. package/dist/components/Icon/LocationIcon.js +6 -5
  75. package/dist/components/Icon/MailIcon.d.ts +1 -1
  76. package/dist/components/Icon/MailIcon.js +6 -5
  77. package/dist/components/Icon/MenuIcon.d.ts +1 -1
  78. package/dist/components/Icon/MenuIcon.js +6 -5
  79. package/dist/components/Icon/MessageIcon.d.ts +1 -1
  80. package/dist/components/Icon/MessageIcon.js +6 -5
  81. package/dist/components/Icon/MinusIcon.d.ts +1 -1
  82. package/dist/components/Icon/MinusIcon.js +6 -5
  83. package/dist/components/Icon/OpenNewIcon.d.ts +1 -1
  84. package/dist/components/Icon/OpenNewIcon.js +6 -5
  85. package/dist/components/Icon/PencilIcon.d.ts +1 -1
  86. package/dist/components/Icon/PencilIcon.js +6 -5
  87. package/dist/components/Icon/PhoneIcon.d.ts +1 -1
  88. package/dist/components/Icon/PhoneIcon.js +6 -5
  89. package/dist/components/Icon/QuestionIcon.d.ts +1 -1
  90. package/dist/components/Icon/QuestionIcon.js +6 -5
  91. package/dist/components/Icon/ScooterIcon.d.ts +1 -1
  92. package/dist/components/Icon/ScooterIcon.js +6 -5
  93. package/dist/components/Icon/SearchIcon.d.ts +1 -1
  94. package/dist/components/Icon/SearchIcon.js +6 -5
  95. package/dist/components/Icon/SettingsIcon.d.ts +1 -1
  96. package/dist/components/Icon/SettingsIcon.js +6 -5
  97. package/dist/components/Icon/TickAltIcon.d.ts +1 -1
  98. package/dist/components/Icon/TickAltIcon.js +6 -5
  99. package/dist/components/Icon/TickIcon.d.ts +1 -1
  100. package/dist/components/Icon/TickIcon.js +6 -5
  101. package/dist/components/Icon/VanIcon.d.ts +1 -1
  102. package/dist/components/Icon/VanIcon.js +6 -5
  103. package/dist/components/Icon/WarningIcon.d.ts +1 -1
  104. package/dist/components/Icon/WarningIcon.js +6 -5
  105. package/dist/components/Icon/WriteIcon.d.ts +1 -1
  106. package/dist/components/Icon/WriteIcon.js +6 -5
  107. package/dist/components/Image/Image.d.ts +4 -2
  108. package/dist/components/Image/Image.js +2 -2
  109. package/dist/components/Pill/Pill.d.ts +4 -2
  110. package/dist/components/Pill/Pill.js +7 -8
  111. package/dist/components/Radio/Radio.d.ts +20 -0
  112. package/dist/components/Radio/Radio.js +21 -0
  113. package/dist/components/Radio/index.d.ts +4 -0
  114. package/dist/components/{SearchBox/SearchBox.d.ts → Searchbox/Searchbox.d.ts} +10 -8
  115. package/dist/components/{SearchBox/SearchBox.js → Searchbox/Searchbox.js} +16 -11
  116. package/dist/components/Searchbox/index.d.ts +4 -0
  117. package/dist/components/Signpost/Signpost.d.ts +6 -4
  118. package/dist/components/Signpost/Signpost.js +3 -6
  119. package/dist/components/SkipNav/SkipNav.d.ts +4 -2
  120. package/dist/components/SkipNav/SkipNav.js +2 -2
  121. package/dist/components/Squircle/Squircle.d.ts +4 -2
  122. package/dist/components/Squircle/Squircle.js +2 -2
  123. package/dist/components/Tag/Tag.d.ts +5 -3
  124. package/dist/components/Tag/Tag.js +3 -6
  125. package/dist/components/TextInput/TextInput.d.ts +5 -3
  126. package/dist/components/TextInput/TextInput.js +2 -2
  127. package/dist/components/Textarea/Textarea.d.ts +4 -2
  128. package/dist/components/Textarea/Textarea.js +4 -5
  129. package/dist/{utils/slots.d.ts → hooks/useSlots.d.ts} +1 -1
  130. package/dist/{utils/slots.js → hooks/useSlots.js} +2 -2
  131. package/dist/index.d.ts +2 -2
  132. package/dist/index.js +2 -2
  133. package/package.json +3 -3
  134. package/src/components/AlertBanner/AlertBanner.tsx +6 -2
  135. package/src/components/Author/Author.tsx +5 -2
  136. package/src/components/Button/Button.tsx +10 -15
  137. package/src/components/Card/Card.tsx +7 -5
  138. package/src/components/Checkbox/Checkbox.tsx +6 -2
  139. package/src/components/Expandable/Expandable.tsx +12 -5
  140. package/src/components/Field/Field.tsx +10 -9
  141. package/src/components/FieldMarkers/Error.tsx +9 -3
  142. package/src/components/FieldMarkers/Hint.tsx +10 -4
  143. package/src/components/FieldMarkers/Label.tsx +9 -3
  144. package/src/components/FieldMarkers/Legend.tsx +9 -3
  145. package/src/components/Fieldset/Fieldset.tsx +9 -4
  146. package/src/components/Flourish/Flourish.tsx +5 -2
  147. package/src/components/Icon/AddIcon.tsx +9 -6
  148. package/src/components/Icon/ArrowDownIcon.tsx +9 -6
  149. package/src/components/Icon/ArrowLeftIcon.tsx +9 -6
  150. package/src/components/Icon/ArrowRightIcon.tsx +9 -6
  151. package/src/components/Icon/ArrowUpIcon.tsx +9 -6
  152. package/src/components/Icon/AvatarAltIcon.tsx +9 -6
  153. package/src/components/Icon/AvatarIcon.tsx +9 -6
  154. package/src/components/Icon/BasketIcon.tsx +9 -6
  155. package/src/components/Icon/CalendarIcon.tsx +9 -6
  156. package/src/components/Icon/ChevronDownIcon.tsx +9 -6
  157. package/src/components/Icon/ChevronLeftIcon.tsx +9 -6
  158. package/src/components/Icon/ChevronRightIcon.tsx +9 -6
  159. package/src/components/Icon/ChevronUpIcon.tsx +9 -6
  160. package/src/components/Icon/ClockIcon.tsx +9 -6
  161. package/src/components/Icon/CloseAltIcon.tsx +9 -6
  162. package/src/components/Icon/CloseIcon.tsx +9 -6
  163. package/src/components/Icon/CoopCardIcon.tsx +9 -6
  164. package/src/components/Icon/CoopIcon.tsx +9 -6
  165. package/src/components/Icon/CoopLocationIcon.tsx +9 -6
  166. package/src/components/Icon/DownloadIcon.tsx +9 -6
  167. package/src/components/Icon/HomeIcon.tsx +9 -6
  168. package/src/components/Icon/InformationIcon.tsx +9 -6
  169. package/src/components/Icon/LoadingIcon.tsx +9 -6
  170. package/src/components/Icon/LocationIcon.tsx +9 -6
  171. package/src/components/Icon/MailIcon.tsx +9 -6
  172. package/src/components/Icon/MenuIcon.tsx +9 -6
  173. package/src/components/Icon/MessageIcon.tsx +9 -6
  174. package/src/components/Icon/MinusIcon.tsx +9 -6
  175. package/src/components/Icon/OpenNewIcon.tsx +9 -6
  176. package/src/components/Icon/PencilIcon.tsx +9 -6
  177. package/src/components/Icon/PhoneIcon.tsx +9 -6
  178. package/src/components/Icon/QuestionIcon.tsx +9 -6
  179. package/src/components/Icon/ScooterIcon.tsx +9 -6
  180. package/src/components/Icon/SearchIcon.tsx +9 -6
  181. package/src/components/Icon/SettingsIcon.tsx +9 -6
  182. package/src/components/Icon/TickAltIcon.tsx +9 -6
  183. package/src/components/Icon/TickIcon.tsx +9 -6
  184. package/src/components/Icon/VanIcon.tsx +9 -6
  185. package/src/components/Icon/WarningIcon.tsx +9 -6
  186. package/src/components/Icon/WriteIcon.tsx +9 -6
  187. package/src/components/Image/Image.tsx +5 -2
  188. package/src/components/Pill/Pill.tsx +10 -9
  189. package/src/components/Radio/Radio.tsx +50 -0
  190. package/src/components/Radio/index.ts +5 -0
  191. package/src/components/{SearchBox/SearchBox.tsx → Searchbox/Searchbox.tsx} +33 -30
  192. package/src/components/Searchbox/index.ts +5 -0
  193. package/src/components/Signpost/Signpost.tsx +8 -8
  194. package/src/components/SkipNav/SkipNav.tsx +5 -2
  195. package/src/components/Squircle/Squircle.tsx +5 -2
  196. package/src/components/Tag/Tag.tsx +9 -8
  197. package/src/components/TextInput/TextInput.tsx +18 -3
  198. package/src/components/Textarea/Textarea.tsx +8 -6
  199. package/src/{utils/slots.ts → hooks/useSlots.ts} +1 -1
  200. package/src/index.ts +2 -2
  201. package/dist/components/RadioButton/RadioButton.d.ts +0 -18
  202. package/dist/components/RadioButton/RadioButton.js +0 -22
  203. package/dist/components/RadioButton/index.d.ts +0 -4
  204. package/dist/components/SearchBox/index.d.ts +0 -4
  205. package/src/components/RadioButton/RadioButton.tsx +0 -48
  206. package/src/components/RadioButton/index.ts +0 -5
  207. package/src/components/SearchBox/index.ts +0 -5
@@ -1,5 +1,5 @@
1
1
  import clsx from "clsx"
2
- import { HTMLAttributes } from "react"
2
+ import { HTMLAttributes, Ref } from "react"
3
3
 
4
4
  export interface LegendProps extends HTMLAttributes<HTMLLegendElement> {
5
5
  /** **(Optional)** Main legend for the fieldset. Accepts any valid JSX or string. */
@@ -8,9 +8,11 @@ export interface LegendProps extends HTMLAttributes<HTMLLegendElement> {
8
8
  className?: string
9
9
  /** **(Optional)** Specify whether the legend should be visible to humans or screen readers. */
10
10
  isVisible?: boolean
11
+ /** **(Optional)** Specify a custom React ref for this component. */
12
+ ref?: Ref<HTMLLegendElement>
11
13
  }
12
14
 
13
- export const Legend = ({ children, className, isVisible = true, ...props }: LegendProps) => {
15
+ export const Legend = ({ children, className, isVisible = true, ref, ...props }: LegendProps) => {
14
16
  const componentProps = {
15
17
  "aria-hidden": true,
16
18
  className: clsx("coop-field-label", !isVisible && "sr-only", className),
@@ -20,7 +22,11 @@ export const Legend = ({ children, className, isVisible = true, ...props }: Lege
20
22
  return (
21
23
  <>
22
24
  <legend className="sr-only">{children}</legend>
23
- {isVisible && <div {...componentProps}>{children}</div>}
25
+ {isVisible && (
26
+ <div {...componentProps} ref={ref}>
27
+ {children}
28
+ </div>
29
+ )}
24
30
  </>
25
31
  )
26
32
  }
@@ -1,5 +1,5 @@
1
1
  import clsx from "clsx"
2
- import { type FieldsetHTMLAttributes, type JSX } from "react"
2
+ import { type FieldsetHTMLAttributes, type JSX, Ref } from "react"
3
3
 
4
4
  import { StandardSizes } from "../../../src/types"
5
5
  import { Error as BaseError, type ErrorProps } from "../FieldMarkers/Error"
@@ -19,6 +19,8 @@ export interface FieldsetProps extends FieldsetHTMLAttributes<HTMLFieldSetElemen
19
19
  error?: boolean
20
20
  /** **(Optional)** Specify whether the Fieldset should show the left-hand error bar if it is in an error state. */
21
21
  hideErrorBar?: boolean
22
+ /** **(Optional)** Specify a custom React ref for this component. */
23
+ ref?: Ref<HTMLFieldSetElement>
22
24
  /** **(Optional)** Specify the size of the Fieldset and all its descendents. */
23
25
  size?: StandardSizes
24
26
  }
@@ -28,6 +30,7 @@ const Root = ({
28
30
  disabled,
29
31
  error = false,
30
32
  hideErrorBar = false,
33
+ ref,
31
34
  size = "md",
32
35
  ...props
33
36
  }: FieldsetProps): JSX.Element => {
@@ -35,15 +38,17 @@ const Root = ({
35
38
  "aria-disabled": disabled,
36
39
  className: clsx("coop-fieldset", className),
37
40
  "data-error": error || undefined,
38
- //"data-variant": variant !== "default" ? variant : undefined,
39
41
  "data-hide-error": hideErrorBar || undefined,
40
- // "data-orientation": orientation !== "vertical" ? orientation : undefined,
41
42
  "data-size": size.length && size !== "md" ? size : undefined,
42
43
  disabled,
43
44
  ...props,
44
45
  }
45
46
 
46
- return <fieldset {...componentProps}>{children}</fieldset>
47
+ return (
48
+ <fieldset {...componentProps} ref={ref}>
49
+ {children}
50
+ </fieldset>
51
+ )
47
52
  }
48
53
 
49
54
  interface FieldsetFieldsProps {
@@ -1,4 +1,4 @@
1
- import type { JSX, ReactNode, SVGProps } from "react"
1
+ import type { JSX, ReactNode, Ref, SVGProps } from "react"
2
2
 
3
3
  import clsx from "clsx"
4
4
 
@@ -11,12 +11,15 @@ export interface FlourishProps extends SVGProps<SVGSVGElement> {
11
11
  className?: string
12
12
  /** **(Optional)** Specify the Flourish color. */
13
13
  fill?: Darks | Lights | Tints | OfferRed | BrandBlue | White | Black
14
+ /** **(Optional)** Specify a custom React ref for this component. */
15
+ ref?: Ref<SVGSVGElement>
14
16
  }
15
17
 
16
18
  export const Flourish = ({
17
19
  children,
18
20
  className,
19
21
  fill = "brand-blue",
22
+ ref,
20
23
  ...props
21
24
  }: FlourishProps): JSX.Element => {
22
25
  const componentProps = {
@@ -28,7 +31,7 @@ export const Flourish = ({
28
31
  return (
29
32
  <span style={{ position: "relative" }}>
30
33
  {children}
31
- <svg {...componentProps} viewBox="0 0 276 10">
34
+ <svg {...componentProps} ref={ref} viewBox="0 0 276 10">
32
35
  <path d="M275.9 8.6c.1-1.6.2-1.8-.4-2.9.3-1-.3-1.2-1.8-1.1v-.3c.6-.4.2-.2 1.4-.1-.9-2.3-5.6-1.8-8.5-2.3C259 .5 246.3.7 237.4.5L185 .4l-33-.2-26.1-.2-67.4 1.2-44.3.5C10.7 2.1 1.5.4 0 3.3l1 .2L0 4v.5C8.2 7.9 26.6 7.2 35.6 7c5 0 13.5 1.6 16.5-.6C53.4 8 59.5 8 62 7.7l45 .1 42.8.3 30.7.3 44.2.6 27.8-.5 23 .8c.1-.8-.3-.5.5-.7ZM219 2.8v-.2l.8-.2h.4l.3.4H219Zm30-.1h1.2c-.8.4-.5.3-1.2 0Zm6.2.6.2-.4h.3l-.5.4Z" />
33
36
  </svg>
34
37
  </span>
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const AddIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const AddIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "add",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path
23
26
  d="M24.7 16.72a1 1 0 0 1-.7.28H8a1 1 0 1 1 0-2h16a1 1 0 0 1 1 1 1 1 0 0 1-.3.72"
24
27
  fill={fill ?? "currentColor"}
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const ArrowDownIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const ArrowDownIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "arrow-down",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path d="M15 28.66V3a1 1 0 0 1 2 0v25.66a1 1 0 0 1-2 0" fill={fill ?? "currentColor"} />
23
26
  <path
24
27
  d="M3 17a1 1 0 0 1 .29-.71 1 1 0 0 1 1.42 0L16 27.58l11.29-11.29a1 1 0 0 1 1.42 0 1 1 0 0 1 0 1.41l-12 12a1 1 0 0 1-1.41 0l-12-12A1 1 0 0 1 3 17"
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const ArrowLeftIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const ArrowLeftIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "arrow-left",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path d="M3.34 17H29a1 1 0 0 0 0-2H3.34a1 1 0 0 0 0 2" fill={fill ?? "currentColor"} />
23
26
  <path
24
27
  d="M15 29a1 1 0 0 0 .71-.29 1 1 0 0 0 0-1.42L5.12 16.71a1 1 0 0 1 0-1.42L15.71 4.71a1 1 0 0 0 0-1.42 1 1 0 0 0-1.41 0l-12 12a1 1 0 0 0 0 1.42l12 12a1 1 0 0 0 .7.29"
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const ArrowRightIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const ArrowRightIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "arrow-right",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path d="M28.7 15H3a1 1 0 0 0 0 2h25.7a1 1 0 0 0 0-2" fill={fill ?? "currentColor"} />
23
26
  <path
24
27
  d="M17 3a1 1 0 0 0-.7.3 1 1 0 0 0 0 1.4l10.6 10.6a1 1 0 0 1 0 1.4L16.3 27.3a1 1 0 0 0 0 1.4 1 1 0 0 0 1.4 0l12-12a1 1 0 0 0 0-1.4l-12-12A1 1 0 0 0 17 3"
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const ArrowUpIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const ArrowUpIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "arrow-up",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path d="M17 3.34V29a1 1 0 0 1-2 0V3.34a1 1 0 0 1 2 0" fill={fill ?? "currentColor"} />
23
26
  <path
24
27
  d="M29 15a1 1 0 0 1-.29.71 1 1 0 0 1-1.42 0L16 4.42 4.71 15.71a1 1 0 0 1-1.42 0 1 1 0 0 1 0-1.41l12-12a1 1 0 0 1 1.41 0l12 12a1 1 0 0 1 .3.7"
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const AvatarAltIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const AvatarAltIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "avatar-alt",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path
23
26
  d="M16 32a16 16 0 1 1 16-16 16 16 0 0 1-16 16m0-30a14 14 0 1 0 14 14A14 14 0 0 0 16 2"
24
27
  fill={fill ?? "currentColor"}
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const AvatarIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const AvatarIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "avatar",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path
23
26
  d="M16 31a18.24 18.24 0 0 1-12.64-5.1A1.19 1.19 0 0 1 3 24.86a12.31 12.31 0 0 1 12-10h2a12.31 12.31 0 0 1 12 10 1.19 1.19 0 0 1-.34 1.06A18.24 18.24 0 0 1 16 31M5.42 24.68a15.9 15.9 0 0 0 21.16 0A10 10 0 0 0 17 17.17h-2a10 10 0 0 0-9.58 7.51"
24
27
  fill={fill ?? "currentColor"}
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const BasketIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const BasketIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "basket",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path
23
26
  d="M16.07 26a1 1 0 0 0 1-1v-4.08a1 1 0 1 0-2 0V25a1 1 0 0 0 1 1M21.5 26h.17a1 1 0 0 0 1-.85l.68-4.07a1 1 0 0 0-.82-1.18 1 1 0 0 0-1.16.84l-.67 4.07a1 1 0 0 0 .8 1.19M10.43 26h.17a1 1 0 0 0 .82-1.18l-.68-4.07a1 1 0 0 0-1.15-.84 1 1 0 0 0-.82 1.18l.67 4.07a1 1 0 0 0 .99.84"
24
27
  fill={fill ?? "currentColor"}
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const CalendarIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const CalendarIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "calendar",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path
23
26
  d="M31 2h-4V1a1 1 0 0 0-2 0v1H7V1a1 1 0 0 0-2 0v1H1a1 1 0 0 0-1 1v28a1 1 0 0 0 1 1h30a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1m-1 28H2V10h28Zm0-22H2V4h3v1a1 1 0 0 0 2 0V4h18v1a1 1 0 0 0 2 0V4h3Z"
24
27
  fill={fill ?? "currentColor"}
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const ChevronDownIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const ChevronDownIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "chevron-down",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path
23
26
  d="M31 9a1 1 0 0 0-.29-.71 1 1 0 0 0-1.42 0L16 21.59 2.71 8.3a1 1 0 0 0-1.42 0 1 1 0 0 0 0 1.41l14 14a1 1 0 0 0 1.41 0l14-14A1 1 0 0 0 31 9"
24
27
  fill={fill ?? "currentColor"}
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const ChevronLeftIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const ChevronLeftIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "chevron-left",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path
23
26
  d="M22.5 30a1 1 0 0 0 .71-.29 1 1 0 0 0 0-1.42L10.91 16 23.2 3.71a1 1 0 0 0 0-1.41 1 1 0 0 0-1.41 0l-13 13a1 1 0 0 0 0 1.41l13 13a1 1 0 0 0 .71.29"
24
27
  fill={fill ?? "currentColor"}
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const ChevronRightIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const ChevronRightIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "chevron-right",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path
23
26
  d="M9.49 2a1 1 0 0 0-.71 1.71L21.07 16 8.79 28.3a1 1 0 1 0 1.41 1.41l13-13a1 1 0 0 0 0-1.42l-13-13A1 1 0 0 0 9.49 2"
24
27
  fill={fill ?? "currentColor"}
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const ChevronUpIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const ChevronUpIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "chevron-up",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path
23
26
  d="M1 23a1 1 0 0 0 .29.71 1 1 0 0 0 1.42 0L16 10.41 29.29 23.7a1 1 0 0 0 1.42 0 1 1 0 0 0 0-1.41l-14-14a1 1 0 0 0-1.41 0l-14 14A1 1 0 0 0 1 23"
24
27
  fill={fill ?? "currentColor"}
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const ClockIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const ClockIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "clock",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path
23
26
  d="M23 21.05a.93.93 0 0 1-.5-.14L15 16.58v-9.5a1 1 0 0 1 1-1 1 1 0 0 1 1 1v8.35l6.47 3.77a1 1 0 0 1 .36 1.36 1 1 0 0 1-.83.49"
24
27
  fill={fill ?? "currentColor"}
@@ -1,24 +1,27 @@
1
1
  import clsx from "clsx"
2
- import { type SVGProps, useId } from "react"
2
+ import { type SVGProps } from "react"
3
+
4
+ import { useId } from "../../hooks/useId"
3
5
 
4
6
  interface IconProps extends SVGProps<SVGSVGElement> {
5
7
  alt?: string
6
8
  }
7
9
 
8
- export const CloseAltIcon = ({ alt, className, fill, ...props }: IconProps) => {
9
- const id = useId()
10
+ export const CloseAltIcon = ({ alt, className, fill, id, ref, ...props }: IconProps) => {
11
+ const uid = useId(id)
10
12
  const componentProps = {
11
- "aria-labelledby": alt ? id : undefined,
13
+ "aria-labelledby": alt ? uid + "-title" : undefined,
12
14
  className: clsx("coop-icon", className),
13
15
  "data-icon": "close-alt",
14
16
  fill: fill ?? "none",
17
+ id: uid,
15
18
  role: alt ? "img" : undefined,
16
19
  viewBox: "0 0 32 32",
17
20
  ...props,
18
21
  }
19
22
  return (
20
- <svg {...componentProps}>
21
- {alt ? <title id={id}>{alt}</title> : null}
23
+ <svg {...componentProps} ref={ref}>
24
+ {alt ? <title id={uid + "-title"}>{alt}</title> : null}
22
25
  <path
23
26
  d="M21.55 22.51a1 1 0 0 1-.7-.3l-11-11a1 1 0 0 1 1.41-1.41l11 11a1 1 0 0 1 0 1.41 1 1 0 0 1-.71.3"
24
27
  fill={fill ?? "currentColor"}