@canonical/react-ds-core-form 0.9.0-experimental.11 → 0.9.0-experimental.13

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 (232) hide show
  1. package/dist/esm/ui/Field/Field.js +11 -1
  2. package/dist/esm/ui/Field/Field.js.map +1 -1
  3. package/dist/esm/ui/Field/common/Label/Label.js +3 -3
  4. package/dist/esm/ui/Field/common/Label/Label.js.map +1 -1
  5. package/dist/esm/ui/Field/common/Label/styles.css +2 -4
  6. package/dist/esm/ui/Field/common/Wrapper/InvisibleWrapper.js +26 -0
  7. package/dist/esm/ui/Field/common/Wrapper/InvisibleWrapper.js.map +1 -0
  8. package/dist/esm/ui/Field/common/Wrapper/Wrapper.js +10 -2
  9. package/dist/esm/ui/Field/common/Wrapper/Wrapper.js.map +1 -1
  10. package/dist/esm/ui/Field/common/Wrapper/hooks/useFieldWrapper.js +2 -1
  11. package/dist/esm/ui/Field/common/Wrapper/hooks/useFieldWrapper.js.map +1 -1
  12. package/dist/esm/ui/Field/common/Wrapper/index.js +2 -0
  13. package/dist/esm/ui/Field/common/Wrapper/index.js.map +1 -1
  14. package/dist/esm/ui/Field/common/Wrapper/styles.css +10 -2
  15. package/dist/esm/ui/Field/common/Wrapper/withWrapper.js +10 -6
  16. package/dist/esm/ui/Field/common/Wrapper/withWrapper.js.map +1 -1
  17. package/dist/esm/ui/Field/hooks/index.js +1 -0
  18. package/dist/esm/ui/Field/hooks/index.js.map +1 -1
  19. package/dist/esm/ui/Field/hooks/useFieldAriaProperties.js +27 -21
  20. package/dist/esm/ui/Field/hooks/useFieldAriaProperties.js.map +1 -1
  21. package/dist/esm/ui/Field/hooks/useOptionAriaProperties.js +30 -0
  22. package/dist/esm/ui/Field/hooks/useOptionAriaProperties.js.map +1 -0
  23. package/dist/esm/ui/Field/inputs/Checkbox/Checkbox.js +3 -2
  24. package/dist/esm/ui/Field/inputs/Checkbox/Checkbox.js.map +1 -1
  25. package/dist/esm/ui/Field/inputs/Combobox/Combobox.js +21 -0
  26. package/dist/esm/ui/Field/inputs/Combobox/Combobox.js.map +1 -0
  27. package/dist/esm/ui/Field/inputs/Combobox/MultipleCombobox.js +82 -0
  28. package/dist/esm/ui/Field/inputs/Combobox/MultipleCombobox.js.map +1 -0
  29. package/dist/esm/ui/Field/inputs/Combobox/SingleCombobox.js +81 -0
  30. package/dist/esm/ui/Field/inputs/Combobox/SingleCombobox.js.map +1 -0
  31. package/dist/esm/ui/Field/inputs/Combobox/common/List/List.js +35 -0
  32. package/dist/esm/ui/Field/inputs/Combobox/common/List/List.js.map +1 -0
  33. package/dist/esm/ui/Field/inputs/Combobox/common/List/index.js +4 -0
  34. package/dist/esm/ui/Field/inputs/Combobox/common/List/index.js.map +1 -0
  35. package/dist/esm/ui/Field/inputs/Combobox/common/List/styles.css +7 -0
  36. package/dist/esm/ui/Field/inputs/Combobox/common/List/types.js +2 -0
  37. package/dist/esm/ui/Field/inputs/Combobox/common/List/types.js.map +1 -0
  38. package/dist/esm/ui/Field/inputs/Combobox/common/ResetButton/ResetButton.js +15 -0
  39. package/dist/esm/ui/Field/inputs/Combobox/common/ResetButton/ResetButton.js.map +1 -0
  40. package/dist/esm/ui/Field/inputs/Combobox/common/ResetButton/index.js +4 -0
  41. package/dist/esm/ui/Field/inputs/Combobox/common/ResetButton/index.js.map +1 -0
  42. package/dist/esm/ui/Field/inputs/Combobox/common/ResetButton/styles.css +7 -0
  43. package/dist/esm/ui/Field/inputs/Combobox/common/ResetButton/types.js +2 -0
  44. package/dist/esm/ui/Field/inputs/Combobox/common/ResetButton/types.js.map +1 -0
  45. package/dist/esm/ui/Field/inputs/Combobox/common/index.js +3 -0
  46. package/dist/esm/ui/Field/inputs/Combobox/common/index.js.map +1 -0
  47. package/dist/esm/ui/Field/inputs/Combobox/constants.js +2 -0
  48. package/dist/esm/ui/Field/inputs/Combobox/constants.js.map +1 -0
  49. package/dist/esm/ui/Field/inputs/Combobox/index.js +4 -0
  50. package/dist/esm/ui/Field/inputs/Combobox/index.js.map +1 -0
  51. package/dist/esm/ui/Field/inputs/Combobox/messages.js +5 -0
  52. package/dist/esm/ui/Field/inputs/Combobox/messages.js.map +1 -0
  53. package/dist/esm/ui/Field/inputs/Combobox/styles.css +7 -0
  54. package/dist/esm/ui/Field/inputs/Combobox/types.js +2 -0
  55. package/dist/esm/ui/Field/inputs/Combobox/types.js.map +1 -0
  56. package/dist/esm/ui/Field/inputs/Combobox/utils/convertItemToString.js +5 -0
  57. package/dist/esm/ui/Field/inputs/Combobox/utils/convertItemToString.js.map +1 -0
  58. package/dist/esm/ui/Field/inputs/Combobox/utils/convertValueToItem.js +6 -0
  59. package/dist/esm/ui/Field/inputs/Combobox/utils/convertValueToItem.js.map +1 -0
  60. package/dist/esm/ui/Field/inputs/Combobox/utils/filterItems.js +6 -0
  61. package/dist/esm/ui/Field/inputs/Combobox/utils/filterItems.js.map +1 -0
  62. package/dist/esm/ui/Field/inputs/Combobox/utils/index.js +5 -0
  63. package/dist/esm/ui/Field/inputs/Combobox/utils/index.js.map +1 -0
  64. package/dist/esm/ui/Field/inputs/Combobox/utils/mergeRefs.js +12 -0
  65. package/dist/esm/ui/Field/inputs/Combobox/utils/mergeRefs.js.map +1 -0
  66. package/dist/esm/ui/Field/inputs/Hidden/Hidden.js +14 -0
  67. package/dist/esm/ui/Field/inputs/Hidden/Hidden.js.map +1 -0
  68. package/dist/esm/ui/Field/inputs/Hidden/index.js +4 -0
  69. package/dist/esm/ui/Field/inputs/Hidden/index.js.map +1 -0
  70. package/dist/esm/ui/Field/inputs/Hidden/types.js +2 -0
  71. package/dist/esm/ui/Field/inputs/Hidden/types.js.map +1 -0
  72. package/dist/esm/ui/Field/inputs/Range/Range.js +16 -0
  73. package/dist/esm/ui/Field/inputs/Range/Range.js.map +1 -0
  74. package/dist/esm/ui/Field/inputs/Range/index.js +4 -0
  75. package/dist/esm/ui/Field/inputs/Range/index.js.map +1 -0
  76. package/dist/esm/ui/Field/inputs/Range/styles.css +7 -0
  77. package/dist/esm/ui/Field/inputs/Range/types.js +2 -0
  78. package/dist/esm/ui/Field/inputs/Range/types.js.map +1 -0
  79. package/dist/esm/ui/Field/inputs/Select/Select.js +15 -0
  80. package/dist/esm/ui/Field/inputs/Select/Select.js.map +1 -0
  81. package/dist/esm/ui/Field/inputs/Select/index.js +4 -0
  82. package/dist/esm/ui/Field/inputs/Select/index.js.map +1 -0
  83. package/dist/esm/ui/Field/inputs/Select/styles.css +7 -0
  84. package/dist/esm/ui/Field/inputs/Select/types.js +2 -0
  85. package/dist/esm/ui/Field/inputs/Select/types.js.map +1 -0
  86. package/dist/esm/ui/Field/inputs/SimpleChoices/SimpleChoices.js +28 -0
  87. package/dist/esm/ui/Field/inputs/SimpleChoices/SimpleChoices.js.map +1 -0
  88. package/dist/esm/ui/Field/inputs/SimpleChoices/index.js +4 -0
  89. package/dist/esm/ui/Field/inputs/SimpleChoices/index.js.map +1 -0
  90. package/dist/esm/ui/Field/inputs/SimpleChoices/styles.css +7 -0
  91. package/dist/esm/ui/Field/inputs/SimpleChoices/types.js +2 -0
  92. package/dist/esm/ui/Field/inputs/SimpleChoices/types.js.map +1 -0
  93. package/dist/esm/ui/Field/inputs/Text/Text.js +3 -2
  94. package/dist/esm/ui/Field/inputs/Text/Text.js.map +1 -1
  95. package/dist/esm/ui/Field/inputs/Textarea/Textarea.js +3 -2
  96. package/dist/esm/ui/Field/inputs/Textarea/Textarea.js.map +1 -1
  97. package/dist/esm/ui/Field/inputs/index.js +5 -0
  98. package/dist/esm/ui/Field/inputs/index.js.map +1 -1
  99. package/dist/esm/ui/Form/index.js +4 -0
  100. package/dist/esm/ui/Form/index.js.map +1 -0
  101. package/dist/esm/ui/Form/types.js +2 -0
  102. package/dist/esm/ui/Form/types.js.map +1 -0
  103. package/dist/esm/ui/index.js +2 -27
  104. package/dist/esm/ui/index.js.map +1 -1
  105. package/dist/esm/ui/middleware/addConditionalDisplay.js +19 -0
  106. package/dist/esm/ui/middleware/addConditionalDisplay.js.map +1 -0
  107. package/dist/esm/ui/middleware/addRESTOptions.js +44 -0
  108. package/dist/esm/ui/middleware/addRESTOptions.js.map +1 -0
  109. package/dist/esm/ui/middleware/addRESTValidation.js +38 -0
  110. package/dist/esm/ui/middleware/addRESTValidation.js.map +1 -0
  111. package/dist/esm/ui/middleware/index.js +4 -0
  112. package/dist/esm/ui/middleware/index.js.map +1 -0
  113. package/dist/types/ui/Field/Field.d.ts.map +1 -1
  114. package/dist/types/ui/Field/common/Description/Description.d.ts.map +1 -1
  115. package/dist/types/ui/Field/common/Error/Error.d.ts.map +1 -1
  116. package/dist/types/ui/Field/common/Label/Label.d.ts +1 -1
  117. package/dist/types/ui/Field/common/Label/Label.d.ts.map +1 -1
  118. package/dist/types/ui/Field/common/Label/types.d.ts +1 -1
  119. package/dist/types/ui/Field/common/Label/types.d.ts.map +1 -1
  120. package/dist/types/ui/Field/common/Wrapper/InvisibleWrapper.d.ts +13 -0
  121. package/dist/types/ui/Field/common/Wrapper/InvisibleWrapper.d.ts.map +1 -0
  122. package/dist/types/ui/Field/common/Wrapper/Wrapper.d.ts +2 -2
  123. package/dist/types/ui/Field/common/Wrapper/Wrapper.d.ts.map +1 -1
  124. package/dist/types/ui/Field/common/Wrapper/hooks/useFieldWrapper.d.ts +2 -1
  125. package/dist/types/ui/Field/common/Wrapper/hooks/useFieldWrapper.d.ts.map +1 -1
  126. package/dist/types/ui/Field/common/Wrapper/index.d.ts +2 -0
  127. package/dist/types/ui/Field/common/Wrapper/index.d.ts.map +1 -1
  128. package/dist/types/ui/Field/common/Wrapper/types.d.ts +0 -17
  129. package/dist/types/ui/Field/common/Wrapper/types.d.ts.map +1 -1
  130. package/dist/types/ui/Field/common/Wrapper/withWrapper.d.ts +3 -5
  131. package/dist/types/ui/Field/common/Wrapper/withWrapper.d.ts.map +1 -1
  132. package/dist/types/ui/Field/hooks/index.d.ts +1 -0
  133. package/dist/types/ui/Field/hooks/index.d.ts.map +1 -1
  134. package/dist/types/ui/Field/hooks/useFieldAriaProperties.d.ts +2 -1
  135. package/dist/types/ui/Field/hooks/useFieldAriaProperties.d.ts.map +1 -1
  136. package/dist/types/ui/Field/hooks/useOptionAriaProperties.d.ts +19 -0
  137. package/dist/types/ui/Field/hooks/useOptionAriaProperties.d.ts.map +1 -0
  138. package/dist/types/ui/Field/inputs/Checkbox/Checkbox.d.ts +320 -1
  139. package/dist/types/ui/Field/inputs/Checkbox/Checkbox.d.ts.map +1 -1
  140. package/dist/types/ui/Field/inputs/Checkbox/types.d.ts +4 -3
  141. package/dist/types/ui/Field/inputs/Checkbox/types.d.ts.map +1 -1
  142. package/dist/types/ui/Field/inputs/Combobox/Combobox.d.ts +36 -0
  143. package/dist/types/ui/Field/inputs/Combobox/Combobox.d.ts.map +1 -0
  144. package/dist/types/ui/Field/inputs/Combobox/MultipleCombobox.d.ts +13 -0
  145. package/dist/types/ui/Field/inputs/Combobox/MultipleCombobox.d.ts.map +1 -0
  146. package/dist/types/ui/Field/inputs/Combobox/SingleCombobox.d.ts +12 -0
  147. package/dist/types/ui/Field/inputs/Combobox/SingleCombobox.d.ts.map +1 -0
  148. package/dist/types/ui/Field/inputs/Combobox/common/List/List.d.ts +10 -0
  149. package/dist/types/ui/Field/inputs/Combobox/common/List/List.d.ts.map +1 -0
  150. package/dist/types/ui/Field/inputs/Combobox/common/List/index.d.ts +3 -0
  151. package/dist/types/ui/Field/inputs/Combobox/common/List/index.d.ts.map +1 -0
  152. package/dist/types/ui/Field/inputs/Combobox/common/List/types.d.ts +18 -0
  153. package/dist/types/ui/Field/inputs/Combobox/common/List/types.d.ts.map +1 -0
  154. package/dist/types/ui/Field/inputs/Combobox/common/ResetButton/ResetButton.d.ts +10 -0
  155. package/dist/types/ui/Field/inputs/Combobox/common/ResetButton/ResetButton.d.ts.map +1 -0
  156. package/dist/types/ui/Field/inputs/Combobox/common/ResetButton/index.d.ts +3 -0
  157. package/dist/types/ui/Field/inputs/Combobox/common/ResetButton/index.d.ts.map +1 -0
  158. package/dist/types/ui/Field/inputs/Combobox/common/ResetButton/types.d.ts +12 -0
  159. package/dist/types/ui/Field/inputs/Combobox/common/ResetButton/types.d.ts.map +1 -0
  160. package/dist/types/ui/Field/inputs/Combobox/common/index.d.ts +3 -0
  161. package/dist/types/ui/Field/inputs/Combobox/common/index.d.ts.map +1 -0
  162. package/dist/types/ui/Field/inputs/Combobox/constants.d.ts +2 -0
  163. package/dist/types/ui/Field/inputs/Combobox/constants.d.ts.map +1 -0
  164. package/dist/types/ui/Field/inputs/Combobox/index.d.ts +3 -0
  165. package/dist/types/ui/Field/inputs/Combobox/index.d.ts.map +1 -0
  166. package/dist/types/ui/Field/inputs/Combobox/messages.d.ts +6 -0
  167. package/dist/types/ui/Field/inputs/Combobox/messages.d.ts.map +1 -0
  168. package/dist/types/ui/Field/inputs/Combobox/types.d.ts +23 -0
  169. package/dist/types/ui/Field/inputs/Combobox/types.d.ts.map +1 -0
  170. package/dist/types/ui/Field/inputs/Combobox/utils/convertItemToString.d.ts +4 -0
  171. package/dist/types/ui/Field/inputs/Combobox/utils/convertItemToString.d.ts.map +1 -0
  172. package/dist/types/ui/Field/inputs/Combobox/utils/convertValueToItem.d.ts +4 -0
  173. package/dist/types/ui/Field/inputs/Combobox/utils/convertValueToItem.d.ts.map +1 -0
  174. package/dist/types/ui/Field/inputs/Combobox/utils/filterItems.d.ts +4 -0
  175. package/dist/types/ui/Field/inputs/Combobox/utils/filterItems.d.ts.map +1 -0
  176. package/dist/types/ui/Field/inputs/Combobox/utils/index.d.ts +5 -0
  177. package/dist/types/ui/Field/inputs/Combobox/utils/index.d.ts.map +1 -0
  178. package/dist/types/ui/Field/inputs/Combobox/utils/mergeRefs.d.ts +3 -0
  179. package/dist/types/ui/Field/inputs/Combobox/utils/mergeRefs.d.ts.map +1 -0
  180. package/dist/types/ui/Field/inputs/Hidden/Hidden.d.ts +323 -0
  181. package/dist/types/ui/Field/inputs/Hidden/Hidden.d.ts.map +1 -0
  182. package/dist/types/ui/Field/inputs/Hidden/index.d.ts +3 -0
  183. package/dist/types/ui/Field/inputs/Hidden/index.d.ts.map +1 -0
  184. package/dist/types/ui/Field/inputs/Hidden/types.d.ts +5 -0
  185. package/dist/types/ui/Field/inputs/Hidden/types.d.ts.map +1 -0
  186. package/dist/types/ui/Field/inputs/Range/Range.d.ts +324 -0
  187. package/dist/types/ui/Field/inputs/Range/Range.d.ts.map +1 -0
  188. package/dist/types/ui/Field/inputs/Range/index.d.ts +3 -0
  189. package/dist/types/ui/Field/inputs/Range/index.d.ts.map +1 -0
  190. package/dist/types/ui/Field/inputs/Range/types.d.ts +8 -0
  191. package/dist/types/ui/Field/inputs/Range/types.d.ts.map +1 -0
  192. package/dist/types/ui/Field/inputs/Select/Select.d.ts +303 -0
  193. package/dist/types/ui/Field/inputs/Select/Select.d.ts.map +1 -0
  194. package/dist/types/ui/Field/inputs/Select/index.d.ts +3 -0
  195. package/dist/types/ui/Field/inputs/Select/index.d.ts.map +1 -0
  196. package/dist/types/ui/Field/inputs/Select/types.d.ts +5 -0
  197. package/dist/types/ui/Field/inputs/Select/types.d.ts.map +1 -0
  198. package/dist/types/ui/Field/inputs/SimpleChoices/SimpleChoices.d.ts +28 -0
  199. package/dist/types/ui/Field/inputs/SimpleChoices/SimpleChoices.d.ts.map +1 -0
  200. package/dist/types/ui/Field/inputs/SimpleChoices/index.d.ts +3 -0
  201. package/dist/types/ui/Field/inputs/SimpleChoices/index.d.ts.map +1 -0
  202. package/dist/types/ui/Field/inputs/SimpleChoices/types.d.ts +20 -0
  203. package/dist/types/ui/Field/inputs/SimpleChoices/types.d.ts.map +1 -0
  204. package/dist/types/ui/Field/inputs/Text/Text.d.ts +327 -1
  205. package/dist/types/ui/Field/inputs/Text/Text.d.ts.map +1 -1
  206. package/dist/types/ui/Field/inputs/Text/types.d.ts +8 -4
  207. package/dist/types/ui/Field/inputs/Text/types.d.ts.map +1 -1
  208. package/dist/types/ui/Field/inputs/Textarea/Textarea.d.ts +304 -1
  209. package/dist/types/ui/Field/inputs/Textarea/Textarea.d.ts.map +1 -1
  210. package/dist/types/ui/Field/inputs/Textarea/types.d.ts +4 -3
  211. package/dist/types/ui/Field/inputs/Textarea/types.d.ts.map +1 -1
  212. package/dist/types/ui/Field/inputs/index.d.ts +5 -0
  213. package/dist/types/ui/Field/inputs/index.d.ts.map +1 -1
  214. package/dist/types/ui/Field/inputs/types.d.ts +1 -12
  215. package/dist/types/ui/Field/inputs/types.d.ts.map +1 -1
  216. package/dist/types/ui/Field/types.d.ts +59 -28
  217. package/dist/types/ui/Field/types.d.ts.map +1 -1
  218. package/dist/types/ui/Form/index.d.ts +2 -0
  219. package/dist/types/ui/Form/index.d.ts.map +1 -0
  220. package/dist/types/ui/Form/types.d.ts +8 -0
  221. package/dist/types/ui/Form/types.d.ts.map +1 -0
  222. package/dist/types/ui/index.d.ts +2 -0
  223. package/dist/types/ui/index.d.ts.map +1 -1
  224. package/dist/types/ui/middleware/addConditionalDisplay.d.ts +4 -0
  225. package/dist/types/ui/middleware/addConditionalDisplay.d.ts.map +1 -0
  226. package/dist/types/ui/middleware/addRESTOptions.d.ts +9 -0
  227. package/dist/types/ui/middleware/addRESTOptions.d.ts.map +1 -0
  228. package/dist/types/ui/middleware/addRESTValidation.d.ts +12 -0
  229. package/dist/types/ui/middleware/addRESTValidation.d.ts.map +1 -0
  230. package/dist/types/ui/middleware/index.d.ts +4 -0
  231. package/dist/types/ui/middleware/index.d.ts.map +1 -0
  232. package/package.json +9 -7
@@ -0,0 +1,44 @@
1
+ import { createElement, useEffect, useState } from "react";
2
+ function addRESTFieldOptions(url, options = {}) {
3
+ const { method = "GET", headers = {}, transformData = (data) => data, } = options;
4
+ return (WrappedComponent) => {
5
+ return function ExtendedComponent(props) {
6
+ const [optionsData, setOptionsData] = useState([]);
7
+ const [loading, setLoading] = useState(true);
8
+ const [error, setError] = useState(null);
9
+ useEffect(() => {
10
+ fetch(url, {
11
+ method,
12
+ headers,
13
+ })
14
+ .then((response) => {
15
+ if (!response.ok) {
16
+ throw new Error("Failed to fetch options");
17
+ }
18
+ return response.json();
19
+ })
20
+ .then((data) => {
21
+ const transformed = transformData(data);
22
+ setOptionsData(transformed);
23
+ setLoading(false);
24
+ })
25
+ .catch((err) => {
26
+ setError(err.message);
27
+ setLoading(false);
28
+ });
29
+ }, [url]);
30
+ if (loading) {
31
+ return createElement("div", null, "Loading options...");
32
+ }
33
+ if (error) {
34
+ return createElement("div", null, `Error: ${error}`);
35
+ }
36
+ return createElement(WrappedComponent, {
37
+ ...props,
38
+ options: optionsData,
39
+ });
40
+ };
41
+ };
42
+ }
43
+ export default addRESTFieldOptions;
44
+ //# sourceMappingURL=addRESTOptions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"addRESTOptions.js","sourceRoot":"","sources":["../../../../src/ui/middleware/addRESTOptions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAU3D,SAAS,mBAAmB,CAC1B,GAAW,EACX,UAA+B,EAAE;IAGjC,MAAM,EACJ,MAAM,GAAG,KAAK,EACd,OAAO,GAAG,EAAE,EACZ,aAAa,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,GAC/B,GAAG,OAAO,CAAC;IAEZ,OAAO,CAAC,gBAAgB,EAAE,EAAE;QAC1B,OAAO,SAAS,iBAAiB,CAAC,KAAK;YACrC,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAW,EAAE,CAAC,CAAC;YAC7D,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC7C,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAgB,IAAI,CAAC,CAAC;YAExD,SAAS,CAAC,GAAG,EAAE;gBACb,KAAK,CAAC,GAAG,EAAE;oBACT,MAAM;oBACN,OAAO;iBACR,CAAC;qBACC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE;oBACjB,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;wBACjB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;oBAC7C,CAAC;oBACD,OAAO,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACzB,CAAC,CAAC;qBACD,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;oBACb,MAAM,WAAW,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;oBACxC,cAAc,CAAC,WAAW,CAAC,CAAC;oBAC5B,UAAU,CAAC,KAAK,CAAC,CAAC;gBACpB,CAAC,CAAC;qBACD,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;oBACb,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACtB,UAAU,CAAC,KAAK,CAAC,CAAC;gBACpB,CAAC,CAAC,CAAC;YACP,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;YAEV,IAAI,OAAO,EAAE,CAAC;gBACZ,OAAO,aAAa,CAAC,KAAK,EAAE,IAAI,EAAE,oBAAoB,CAAC,CAAC;YAC1D,CAAC;YACD,IAAI,KAAK,EAAE,CAAC;gBACV,OAAO,aAAa,CAAC,KAAK,EAAE,IAAI,EAAE,UAAU,KAAK,EAAE,CAAC,CAAC;YACvD,CAAC;YACD,OAAO,aAAa,CAAC,gBAAgB,EAAE;gBACrC,GAAG,KAAK;gBACR,OAAO,EAAE,WAAW;aACrB,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAED,eAAe,mBAAmB,CAAC"}
@@ -0,0 +1,38 @@
1
+ import { debounce } from "@canonical/utils";
2
+ import { createElement, useCallback, useEffect } from "react";
3
+ import { useFormContext } from "react-hook-form";
4
+ function addRESTFieldValidation(url, options = {}) {
5
+ const { method = "POST", headers = { "Content-Type": "application/json" }, bodyFormatter = (value) => ({ value }), errorExtractor = async () => "Validation failed", minLength = 3, debounceWait = 300, } = options;
6
+ return (WrappedComponent) => {
7
+ return function ExtendedComponent(props) {
8
+ const { name } = props;
9
+ const { setError, clearErrors, watch } = useFormContext();
10
+ const value = watch(name);
11
+ const debouncedFetch = useCallback(debounce(async (val) => {
12
+ const response = await fetch(url, {
13
+ method,
14
+ headers,
15
+ body: JSON.stringify(bodyFormatter(val)),
16
+ });
17
+ if (!response.ok) {
18
+ const errorMessage = await errorExtractor(response);
19
+ setError(name, { type: "manual", message: errorMessage });
20
+ }
21
+ else {
22
+ clearErrors(name);
23
+ }
24
+ }, debounceWait), []);
25
+ useEffect(() => {
26
+ if (value && value.length >= minLength) {
27
+ debouncedFetch(value);
28
+ }
29
+ else {
30
+ clearErrors(name);
31
+ }
32
+ }, [value, debouncedFetch, name, clearErrors]);
33
+ return createElement(WrappedComponent, props);
34
+ };
35
+ };
36
+ }
37
+ export default addRESTFieldValidation;
38
+ //# sourceMappingURL=addRESTValidation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"addRESTValidation.js","sourceRoot":"","sources":["../../../../src/ui/middleware/addRESTValidation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAajD,SAAS,sBAAsB,CAC7B,GAAW,EACX,UAA6B,EAAE;IAG/B,MAAM,EACJ,MAAM,GAAG,MAAM,EACf,OAAO,GAAG,EAAE,cAAc,EAAE,kBAAkB,EAAE,EAChD,aAAa,GAAG,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EACtC,cAAc,GAAG,KAAK,IAAI,EAAE,CAAC,mBAAmB,EAChD,SAAS,GAAG,CAAC,EACb,YAAY,GAAG,GAAG,GACnB,GAAG,OAAO,CAAC;IAEZ,OAAO,CAAC,gBAAgB,EAAE,EAAE;QAC1B,OAAO,SAAS,iBAAiB,CAAC,KAAK;YACrC,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC;YACvB,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,EAAE,GAAG,cAAc,EAAE,CAAC;YAC1D,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;YAE1B,MAAM,cAAc,GAAG,WAAW,CAChC,QAAQ,CAAC,KAAK,EAAE,GAAW,EAAE,EAAE;gBAC7B,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE;oBAChC,MAAM;oBACN,OAAO;oBACP,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;iBACzC,CAAC,CAAC;gBACH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;oBACjB,MAAM,YAAY,GAAG,MAAM,cAAc,CAAC,QAAQ,CAAC,CAAC;oBACpD,QAAQ,CAAC,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC;gBAC5D,CAAC;qBAAM,CAAC;oBACN,WAAW,CAAC,IAAI,CAAC,CAAC;gBACpB,CAAC;YACH,CAAC,EAAE,YAAY,CAAC,EAChB,EAAE,CACH,CAAC;YAEF,SAAS,CAAC,GAAG,EAAE;gBACb,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,IAAI,SAAS,EAAE,CAAC;oBACvC,cAAc,CAAC,KAAK,CAAC,CAAC;gBACxB,CAAC;qBAAM,CAAC;oBACN,WAAW,CAAC,IAAI,CAAC,CAAC;gBACpB,CAAC;YACH,CAAC,EAAE,CAAC,KAAK,EAAE,cAAc,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC;YAE/C,OAAO,aAAa,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;QAChD,CAAC,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAED,eAAe,sBAAsB,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { default as addRESTOptions } from "./addRESTOptions.js";
2
+ export { default as addRESTValidation } from "./addRESTValidation.js";
3
+ export { default as addConditionalDisplay } from "./addConditionalDisplay.js";
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/ui/middleware/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAChE,OAAO,EAAE,OAAO,IAAI,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AACtE,OAAO,EAAE,OAAO,IAAI,qBAAqB,EAAE,MAAM,4BAA4B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"Field.d.ts","sourceRoot":"","sources":["../../../../src/ui/Field/Field.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAE7C;;;GAGG;AACH,QAAA,MAAM,KAAK,6CAIR,UAAU,KAAG,KAAK,CAAC,YAYrB,CAAC;AAEF,eAAe,KAAK,CAAC"}
1
+ {"version":3,"file":"Field.d.ts","sourceRoot":"","sources":["../../../../src/ui/Field/Field.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAW/B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAE7C;;;GAGG;AACH,QAAA,MAAM,KAAK,GAAI,0CAIZ,UAAU,KAAG,KAAK,CAAC,YAsBrB,CAAC;AAEF,eAAe,KAAK,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"Description.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Description/Description.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AACnD,OAAO,cAAc,CAAC;AAItB;;;GAGG;AACH,QAAA,MAAM,WAAW,wCAKd,gBAAgB,KAAG,KAAK,CAAC,YAU3B,CAAC;AAEF,eAAe,WAAW,CAAC"}
1
+ {"version":3,"file":"Description.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Description/Description.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AACnD,OAAO,cAAc,CAAC;AAItB;;;GAGG;AACH,QAAA,MAAM,WAAW,GAAI,qCAKlB,gBAAgB,KAAG,KAAK,CAAC,YAU3B,CAAC;AAEF,eAAe,WAAW,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"Error.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Error/Error.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAC7C,OAAO,cAAc,CAAC;AAItB;;;GAGG;AACH,QAAA,MAAM,UAAU,wCAKb,UAAU,KAAG,KAAK,CAAC,YAWrB,CAAC;AAEF,eAAe,UAAU,CAAC"}
1
+ {"version":3,"file":"Error.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Error/Error.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAC7C,OAAO,cAAc,CAAC;AAItB;;;GAGG;AACH,QAAA,MAAM,UAAU,GAAI,qCAKjB,UAAU,KAAG,KAAK,CAAC,YAWrB,CAAC;AAEF,eAAe,UAAU,CAAC"}
@@ -5,6 +5,6 @@ import "./styles.css";
5
5
  * description of the Label component
6
6
  * @returns {React.ReactElement} - Rendered Label
7
7
  */
8
- declare const Label: ({ id, children, className, style, name, isOptional, messages, namePrefix, tag: Element, }: LabelProps) => React.ReactElement;
8
+ declare const Label: ({ id, children, className, style, name, isOptional, messages, htmlFor, tag: Element, }: LabelProps) => React.ReactElement;
9
9
  export default Label;
10
10
  //# sourceMappingURL=Label.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Label.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Label/Label.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAC7C,OAAO,cAAc,CAAC;AAStB;;;GAGG;AACH,QAAA,MAAM,KAAK,8FAUR,UAAU,KAAG,KAAK,CAAC,YAYrB,CAAC;AAEF,eAAe,KAAK,CAAC"}
1
+ {"version":3,"file":"Label.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Label/Label.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAC7C,OAAO,cAAc,CAAC;AAStB;;;GAGG;AACH,QAAA,MAAM,KAAK,GAAI,wFAUZ,UAAU,KAAG,KAAK,CAAC,YAYrB,CAAC;AAEF,eAAe,KAAK,CAAC"}
@@ -9,7 +9,7 @@ export interface LabelProps {
9
9
  children?: React.ReactNode;
10
10
  style?: React.CSSProperties;
11
11
  name: string;
12
- namePrefix?: string;
12
+ htmlFor?: string;
13
13
  isOptional?: boolean;
14
14
  messages?: LabelMessages;
15
15
  tag?: keyof JSX.IntrinsicElements;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Label/types.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAEjC,MAAM,WAAW,aAAa;IAE5B,QAAQ,EAAE,MAAM,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,UAAU;IAEzB,EAAE,CAAC,EAAE,MAAM,CAAC;IAEZ,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAE3B,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IAE5B,IAAI,EAAE,MAAM,CAAC;IAEb,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,UAAU,CAAC,EAAE,OAAO,CAAC;IAErB,QAAQ,CAAC,EAAE,aAAa,CAAC;IAEzB,GAAG,CAAC,EAAE,MAAM,GAAG,CAAC,iBAAiB,CAAC;CACnC"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Label/types.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAEjC,MAAM,WAAW,aAAa;IAE5B,QAAQ,EAAE,MAAM,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,UAAU;IAEzB,EAAE,CAAC,EAAE,MAAM,CAAC;IAEZ,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAE3B,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IAE5B,IAAI,EAAE,MAAM,CAAC;IAEb,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,UAAU,CAAC,EAAE,OAAO,CAAC;IAErB,QAAQ,CAAC,EAAE,aAAa,CAAC;IAEzB,GAAG,CAAC,EAAE,MAAM,GAAG,CAAC,iBAAiB,CAAC;CACnC"}
@@ -0,0 +1,13 @@
1
+ import type React from "react";
2
+ import type { BaseInputProps, WrapperProps } from "../../types.js";
3
+ /**
4
+ * InvisibleWrapper component for hidden form inputs.
5
+ * It wraps the specified input component and handles form registration
6
+ * without rendering visible elements like labels or error messages.
7
+ *
8
+ * @param {WrapperProps<ComponentProps>} props - Component props including the Component to wrap and form-related props.
9
+ * @returns {React.ReactElement} - Rendered wrapped component.
10
+ */
11
+ declare const InvisibleWrapper: <ComponentProps extends BaseInputProps>({ name, Component, registerProps: userRegisterProps, nestedRegisterProps, unregisterOnUnmount, ...otherProps }: WrapperProps<ComponentProps>) => React.ReactElement;
12
+ export default InvisibleWrapper;
13
+ //# sourceMappingURL=InvisibleWrapper.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InvisibleWrapper.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Wrapper/InvisibleWrapper.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAGnE;;;;;;;GAOG;AACH,QAAA,MAAM,gBAAgB,GAAI,cAAc,SAAS,cAAc,EAAE,gHAO9D,YAAY,CAAC,cAAc,CAAC,KAAG,KAAK,CAAC,YAevC,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
@@ -1,10 +1,10 @@
1
1
  import type React from "react";
2
- import type { WrapperProps } from "./types.js";
2
+ import type { BaseInputProps, WrapperProps } from "../../types.js";
3
3
  import "./styles.css";
4
4
  /**
5
5
  * description of the Wrapper component
6
6
  * @returns {React.ReactElement} - Rendered Wrapper
7
7
  */
8
- declare const Wrapper: ({ id, children, className, style, name, Component, description, label, isOptional, registerProps: userRegisterProps, nestedRegisterProps, unregisterOnUnmount, mockLabel, ...otherProps }: WrapperProps) => React.ReactElement;
8
+ declare const Wrapper: <ComponentProps extends BaseInputProps>({ id, className, style, name, Component, description, label, isOptional, registerProps: userRegisterProps, nestedRegisterProps, unregisterOnUnmount, mockLabel, ...otherProps }: WrapperProps<ComponentProps>) => React.ReactElement;
9
9
  export default Wrapper;
10
10
  //# sourceMappingURL=Wrapper.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Wrapper.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Wrapper/Wrapper.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,cAAc,CAAC;AAMtB;;;GAGG;AACH,QAAA,MAAM,OAAO,8LAiBV,YAAY,KAAG,KAAK,CAAC,YAyCvB,CAAC;AAEF,eAAe,OAAO,CAAC"}
1
+ {"version":3,"file":"Wrapper.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Wrapper/Wrapper.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACnE,OAAO,cAAc,CAAC;AAMtB;;;GAGG;AACH,QAAA,MAAM,OAAO,GAAI,cAAc,SAAS,cAAc,EAAE,iLAgBrD,YAAY,CAAC,cAAc,CAAC,KAAG,KAAK,CAAC,YAgDvC,CAAC;AAEF,eAAe,OAAO,CAAC"}
@@ -19,11 +19,12 @@ declare const useFieldWrapper: (name: string, options?: UseFieldWrapperOptions)
19
19
  id: string;
20
20
  "aria-labelledby": string;
21
21
  "aria-describedby": string;
22
- "aria-errormessage": string;
22
+ "aria-errormessage": string | undefined;
23
23
  "aria-invalid": boolean;
24
24
  };
25
25
  label: {
26
26
  id: string;
27
+ htmlFor: string;
27
28
  };
28
29
  description: {
29
30
  id: string;
@@ -1 +1 @@
1
- {"version":3,"file":"useFieldWrapper.d.ts","sourceRoot":"","sources":["../../../../../../../src/ui/Field/common/Wrapper/hooks/useFieldWrapper.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,eAAe,EAAkB,MAAM,iBAAiB,CAAC;AAKvE,KAAK,sBAAsB,GAAG;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,iBAAiB,CAAC,EAAE,eAAe,CAAC;IACpC,mBAAmB,CAAC,EAAE,eAAe,CAAC;IACtC,mBAAmB,CAAC,EAAE,OAAO,CAAC;CAC/B,CAAC;AAEF;;;;GAIG;AACH,QAAA,MAAM,eAAe,SACb,MAAM,YACH,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA8ChC,CAAC;AACF,eAAe,eAAe,CAAC"}
1
+ {"version":3,"file":"useFieldWrapper.d.ts","sourceRoot":"","sources":["../../../../../../../src/ui/Field/common/Wrapper/hooks/useFieldWrapper.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,eAAe,EAAkB,MAAM,iBAAiB,CAAC;AAKvE,KAAK,sBAAsB,GAAG;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,iBAAiB,CAAC,EAAE,eAAe,CAAC;IACpC,mBAAmB,CAAC,EAAE,eAAe,CAAC;IACtC,mBAAmB,CAAC,EAAE,OAAO,CAAC;CAC/B,CAAC;AAEF;;;;GAIG;AACH,QAAA,MAAM,eAAe,GACnB,MAAM,MAAM,EACZ,UAAS,sBAA2B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+CrC,CAAC;AACF,eAAe,eAAe,CAAC"}
@@ -1,3 +1,5 @@
1
1
  export { default as Wrapper } from "./Wrapper.js";
2
+ export { default as InvisibleWrapper } from "./InvisibleWrapper.js";
3
+ export { default as withWrapper } from "./withWrapper.js";
2
4
  export * from "./types.js";
3
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Wrapper/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,cAAc,CAAC;AAClD,cAAc,YAAY,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Wrapper/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,cAAc,CAAC;AAClD,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACpE,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC1D,cAAc,YAAY,CAAC"}
@@ -1,19 +1,2 @@
1
- import type React from "react";
2
- import type { BaseInputProps } from "../../inputs/index.ts";
3
- import type { BaseFieldProps, BaseWrapperProps } from "../../types.js";
4
- type BaseComponentProps = BaseInputProps & BaseWrapperProps;
5
- export type WrapperProps<ComponentProps extends BaseComponentProps = BaseFieldProps> = BaseFieldProps & {
6
- id?: string;
7
- className?: string;
8
- children?: React.ReactNode;
9
- style?: React.CSSProperties;
10
- description?: string;
11
- label?: string;
12
- isOptional?: boolean;
13
- nestedRegisterProps?: Record<string, unknown>;
14
- unregisterOnUnmount?: boolean;
15
- mockLabel?: boolean;
16
- Component: React.ComponentType<ComponentProps>;
17
- };
18
1
  export {};
19
2
  //# sourceMappingURL=types.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Wrapper/types.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAEvE,KAAK,kBAAkB,GAAG,cAAc,GAAG,gBAAgB,CAAC;AAE5D,MAAM,MAAM,YAAY,CACtB,cAAc,SAAS,kBAAkB,GAAG,cAAc,IACxD,cAAc,GAAG;IAEnB,EAAE,CAAC,EAAE,MAAM,CAAC;IAEZ,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAE3B,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IAG5B,WAAW,CAAC,EAAE,MAAM,CAAC;IAGrB,KAAK,CAAC,EAAE,MAAM,CAAC;IAGf,UAAU,CAAC,EAAE,OAAO,CAAC;IAGrB,mBAAmB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAG9C,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAG9B,SAAS,CAAC,EAAE,OAAO,CAAC;IAGpB,SAAS,EAAE,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC;CAChD,CAAC"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Wrapper/types.ts"],"names":[],"mappings":""}
@@ -1,8 +1,6 @@
1
1
  import * as React from "react";
2
- import type { InputProps } from "../../inputs/index.js";
3
- import type { BaseFieldProps } from "../../types.js";
4
- import DefaultWrapper from "./Wrapper.js";
5
- import type { WrapperProps } from "./types.js";
6
- declare const withWrapper: (Component: React.ComponentType<InputProps>, options?: WrapperProps, Wrapper?: typeof DefaultWrapper) => ({ middleware, WrapperComponent, ...props }: BaseFieldProps) => React.ReactElement;
2
+ import type { BaseInputProps, BaseWrapperProps, WrappedComponentProps, WrapperProps } from "../../types.js";
3
+ type WrappedComponentPropsInternal<ComponentProps extends BaseInputProps> = Omit<WrappedComponentProps<ComponentProps>, "Component">;
4
+ declare const withWrapper: <ComponentProps extends BaseInputProps, ComponentWrapperProps extends BaseWrapperProps<ComponentProps> = WrapperProps<ComponentProps>>(Component: React.ComponentType<ComponentProps>, options?: Partial<ComponentWrapperProps>, Wrapper?: React.ComponentType<WrapperProps<ComponentProps>>) => ({ middleware, WrapperComponent, ...props }: WrappedComponentPropsInternal<ComponentProps>) => React.ReactElement;
7
5
  export default withWrapper;
8
6
  //# sourceMappingURL=withWrapper.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"withWrapper.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Wrapper/withWrapper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,KAAK,EAAE,cAAc,EAA4B,MAAM,gBAAgB,CAAC;AAC/E,OAAO,cAAc,MAAM,cAAc,CAAC;AAC1C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAK/C,QAAA,MAAM,WAAW,cACJ,KAAK,CAAC,aAAa,CAAC,UAAU,CAAC,YAChC,YAAY,YACb,OAAO,cAAc,kDAQ3B,cAAc,KAAG,KAAK,CAAC,YAsB3B,CAAC;AAEF,eAAe,WAAW,CAAC"}
1
+ {"version":3,"file":"withWrapper.d.ts","sourceRoot":"","sources":["../../../../../../src/ui/Field/common/Wrapper/withWrapper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,OAAO,KAAK,EACV,cAAc,EACd,gBAAgB,EAChB,qBAAqB,EACrB,YAAY,EACb,MAAM,gBAAgB,CAAC;AAGxB,KAAK,6BAA6B,CAAC,cAAc,SAAS,cAAc,IACtE,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,EAAE,WAAW,CAAC,CAAC;AAE3D,QAAA,MAAM,WAAW,GACf,cAAc,SAAS,cAAc,EACrC,qBAAqB,SACnB,gBAAgB,CAAC,cAAc,CAAC,GAAG,YAAY,CAAC,cAAc,CAAC,EAEjE,WAAW,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC,EAC9C,UAAU,OAAO,CAAC,qBAAqB,CAAC,EACxC,UAAS,KAAK,CAAC,aAAa,CAAC,YAAY,CAAC,cAAc,CAAC,CAAkB,kDAUxE,6BAA6B,CAAC,cAAc,CAAC,KAAG,KAAK,CAAC,YAiC1D,CAAC;AAEF,eAAe,WAAW,CAAC"}
@@ -1,3 +1,4 @@
1
1
  export { default as useFieldError } from "./useFieldError.js";
2
2
  export { default as useFieldAriaProperties } from "./useFieldAriaProperties.js";
3
+ export { default as useOptionAriaProperties } from "./useOptionAriaProperties.js";
3
4
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Field/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,6BAA6B,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Field/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AAChF,OAAO,EAAE,OAAO,IAAI,uBAAuB,EAAE,MAAM,8BAA8B,CAAC"}
@@ -9,11 +9,12 @@ declare const useFieldAriaProps: (name: string, isError: boolean) => {
9
9
  id: string;
10
10
  "aria-labelledby": string;
11
11
  "aria-describedby": string;
12
- "aria-errormessage": string;
12
+ "aria-errormessage": string | undefined;
13
13
  "aria-invalid": boolean;
14
14
  };
15
15
  label: {
16
16
  id: string;
17
+ htmlFor: string;
17
18
  };
18
19
  description: {
19
20
  id: string;
@@ -1 +1 @@
1
- {"version":3,"file":"useFieldAriaProperties.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Field/hooks/useFieldAriaProperties.ts"],"names":[],"mappings":"AAEA;;;;;GAKG;AACH,QAAA,MAAM,iBAAiB,SAAU,MAAM,WAAW,OAAO;;;;;;;;;;;;;;;;;CAuBpC,CAAC;AAEtB,eAAe,iBAAiB,CAAC"}
1
+ {"version":3,"file":"useFieldAriaProperties.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Field/hooks/useFieldAriaProperties.ts"],"names":[],"mappings":"AAEA;;;;;GAKG;AACH,QAAA,MAAM,iBAAiB,GAAI,MAAM,MAAM,EAAE,SAAS,OAAO;;;;;;;;;;;;;;;;;;CA4BxD,CAAC;AAEF,eAAe,iBAAiB,CAAC"}
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Generates ARIA properties for a specific option in a field.
3
+ * @param {string} name - The base name of the input field.
4
+ * @param {string} optionValue - The value of the specific option.
5
+ * @returns An object containing ARIA attributes for the option.
6
+ */
7
+ declare const useOptionAriaProps: (name: string, optionValue: string) => {
8
+ input: {
9
+ id: string;
10
+ "aria-labelledby": string;
11
+ "aria-describedby": string;
12
+ };
13
+ label: {
14
+ id: string;
15
+ htmlFor: string;
16
+ };
17
+ };
18
+ export default useOptionAriaProps;
19
+ //# sourceMappingURL=useOptionAriaProperties.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useOptionAriaProperties.d.ts","sourceRoot":"","sources":["../../../../../src/ui/Field/hooks/useOptionAriaProperties.ts"],"names":[],"mappings":"AAGA;;;;;GAKG;AACH,QAAA,MAAM,kBAAkB,GAAI,MAAM,MAAM,EAAE,aAAa,MAAM;;;;;;;;;;CAsB5D,CAAC;AAEF,eAAe,kBAAkB,CAAC"}