@cerberus-design/react 0.15.0 → 0.16.0-next-feeb186

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 (550) hide show
  1. package/build/legacy/_tsup-dts-rollup.d.cts +1345 -319
  2. package/build/legacy/components/Accordion.cjs.map +1 -1
  3. package/build/legacy/components/AccordionItemGroup.cjs.map +1 -1
  4. package/build/legacy/components/DatePicker.client.cjs +63 -77
  5. package/build/legacy/components/DatePicker.client.cjs.map +1 -1
  6. package/build/legacy/components/FileStatus.cjs +126 -79
  7. package/build/legacy/components/FileStatus.cjs.map +1 -1
  8. package/build/legacy/components/Legend.cjs +10 -22
  9. package/build/legacy/components/Legend.cjs.map +1 -1
  10. package/build/legacy/components/button/button.cjs +154 -0
  11. package/build/legacy/components/button/button.cjs.map +1 -0
  12. package/build/legacy/components/button/index.cjs +163 -0
  13. package/build/legacy/components/button/index.cjs.map +1 -0
  14. package/build/legacy/components/button/parts.cjs +159 -0
  15. package/build/legacy/components/button/parts.cjs.map +1 -0
  16. package/build/legacy/components/checkbox/checkbox-icon.cjs +121 -0
  17. package/build/legacy/components/checkbox/checkbox-icon.cjs.map +1 -0
  18. package/build/legacy/components/checkbox/checkbox.cjs +165 -0
  19. package/build/legacy/components/checkbox/checkbox.cjs.map +1 -0
  20. package/build/legacy/components/checkbox/index.cjs +179 -0
  21. package/build/legacy/components/checkbox/index.cjs.map +1 -0
  22. package/build/legacy/components/checkbox/parts.cjs +89 -0
  23. package/build/legacy/components/checkbox/parts.cjs.map +1 -0
  24. package/build/legacy/components/checkbox/primitives.cjs +87 -0
  25. package/build/legacy/components/checkbox/primitives.cjs.map +1 -0
  26. package/build/legacy/components/cta-dialog/context.cjs +33 -0
  27. package/build/legacy/components/cta-dialog/context.cjs.map +1 -0
  28. package/build/legacy/components/cta-dialog/index.cjs +433 -0
  29. package/build/legacy/components/cta-dialog/index.cjs.map +1 -0
  30. package/build/legacy/{context/cta-modal.cjs → components/cta-dialog/provider.cjs} +175 -128
  31. package/build/legacy/components/cta-dialog/provider.cjs.map +1 -0
  32. package/build/legacy/components/cta-dialog/trigger-item.cjs +99 -0
  33. package/build/legacy/components/cta-dialog/trigger-item.cjs.map +1 -0
  34. package/build/legacy/components/cta-dialog/utils.cjs +47 -0
  35. package/build/legacy/components/cta-dialog/utils.cjs.map +1 -0
  36. package/build/legacy/components/{FieldMessage.cjs → deprecated/FieldMessage.cjs} +4 -17
  37. package/build/legacy/components/deprecated/FieldMessage.cjs.map +1 -0
  38. package/build/legacy/components/{FieldsetLabel.cjs → deprecated/FieldsetLabel.cjs} +1 -1
  39. package/build/legacy/components/deprecated/FieldsetLabel.cjs.map +1 -0
  40. package/build/legacy/components/{Textarea.cjs → deprecated/Label.cjs} +24 -36
  41. package/build/legacy/components/deprecated/Label.cjs.map +1 -0
  42. package/build/legacy/components/{Modal.cjs → deprecated/Modal.cjs} +1 -1
  43. package/build/legacy/components/deprecated/Modal.cjs.map +1 -0
  44. package/build/legacy/components/{ModalDescription.cjs → deprecated/ModalDescription.cjs} +1 -1
  45. package/build/legacy/components/deprecated/ModalDescription.cjs.map +1 -0
  46. package/build/legacy/components/{ModalHeader.cjs → deprecated/ModalHeader.cjs} +1 -1
  47. package/build/legacy/components/deprecated/ModalHeader.cjs.map +1 -0
  48. package/build/legacy/components/{ModalHeading.cjs → deprecated/ModalHeading.cjs} +1 -1
  49. package/build/legacy/components/deprecated/ModalHeading.cjs.map +1 -0
  50. package/build/legacy/components/{NavMenuLink.cjs → deprecated/NavMenuLink.cjs} +2 -2
  51. package/build/legacy/components/deprecated/NavMenuLink.cjs.map +1 -0
  52. package/build/legacy/components/{NavMenuList.cjs → deprecated/NavMenuList.cjs} +2 -2
  53. package/build/legacy/components/deprecated/NavMenuList.cjs.map +1 -0
  54. package/build/legacy/components/{NavMenuTrigger.cjs → deprecated/NavMenuTrigger.cjs} +2 -2
  55. package/build/legacy/components/deprecated/NavMenuTrigger.cjs.map +1 -0
  56. package/build/legacy/components/field/field.cjs +130 -0
  57. package/build/legacy/components/field/field.cjs.map +1 -0
  58. package/build/legacy/components/field/index.cjs +267 -0
  59. package/build/legacy/components/field/index.cjs.map +1 -0
  60. package/build/legacy/components/field/parts.cjs +188 -0
  61. package/build/legacy/components/field/parts.cjs.map +1 -0
  62. package/build/legacy/components/field/primitives.cjs +191 -0
  63. package/build/legacy/components/field/primitives.cjs.map +1 -0
  64. package/build/legacy/components/{Button.cjs → field/start-indicator.cjs} +14 -19
  65. package/build/legacy/components/field/start-indicator.cjs.map +1 -0
  66. package/build/legacy/components/field/status-indicator.cjs +78 -0
  67. package/build/legacy/components/field/status-indicator.cjs.map +1 -0
  68. package/build/legacy/components/fieldset/fieldset.cjs +116 -0
  69. package/build/legacy/components/fieldset/fieldset.cjs.map +1 -0
  70. package/build/legacy/components/fieldset/index.cjs +126 -0
  71. package/build/legacy/components/fieldset/index.cjs.map +1 -0
  72. package/build/legacy/components/fieldset/parts.cjs +80 -0
  73. package/build/legacy/components/fieldset/parts.cjs.map +1 -0
  74. package/build/legacy/components/fieldset/primitives.cjs +76 -0
  75. package/build/legacy/components/fieldset/primitives.cjs.map +1 -0
  76. package/build/legacy/components/for.cjs +37 -0
  77. package/build/legacy/components/for.cjs.map +1 -0
  78. package/build/legacy/components/radio/index.cjs +143 -0
  79. package/build/legacy/components/radio/index.cjs.map +1 -0
  80. package/build/legacy/components/radio/parts.cjs +113 -0
  81. package/build/legacy/components/radio/parts.cjs.map +1 -0
  82. package/build/legacy/components/radio/primitives.cjs +115 -0
  83. package/build/legacy/components/radio/primitives.cjs.map +1 -0
  84. package/build/legacy/components/radio/radio.cjs +82 -0
  85. package/build/legacy/components/radio/radio.cjs.map +1 -0
  86. package/build/legacy/components/select/index.cjs +265 -0
  87. package/build/legacy/components/select/index.cjs.map +1 -0
  88. package/build/legacy/components/select/option-group.cjs +60 -0
  89. package/build/legacy/components/select/option-group.cjs.map +1 -0
  90. package/build/legacy/components/select/parts.cjs +153 -0
  91. package/build/legacy/components/select/parts.cjs.map +1 -0
  92. package/build/legacy/components/select/primitives.cjs +167 -0
  93. package/build/legacy/components/select/primitives.cjs.map +1 -0
  94. package/build/legacy/components/select/select.cjs +212 -0
  95. package/build/legacy/components/select/select.cjs.map +1 -0
  96. package/build/legacy/components/switch/index.cjs +118 -0
  97. package/build/legacy/components/switch/index.cjs.map +1 -0
  98. package/build/legacy/components/switch/parts.cjs +75 -0
  99. package/build/legacy/components/switch/parts.cjs.map +1 -0
  100. package/build/legacy/components/switch/primitives.cjs +72 -0
  101. package/build/legacy/components/switch/primitives.cjs.map +1 -0
  102. package/build/legacy/components/{Fieldset.cjs → switch/switch-indicator.cjs} +17 -32
  103. package/build/legacy/components/switch/switch-indicator.cjs.map +1 -0
  104. package/build/legacy/components/switch/switch.cjs +106 -0
  105. package/build/legacy/components/switch/switch.cjs.map +1 -0
  106. package/build/legacy/components/toggle/index.cjs +45 -0
  107. package/build/legacy/components/toggle/index.cjs.map +1 -0
  108. package/build/legacy/components/toggle/parts.cjs +41 -0
  109. package/build/legacy/components/toggle/parts.cjs.map +1 -0
  110. package/build/legacy/components/toggle/primitives.cjs +35 -0
  111. package/build/legacy/components/toggle/primitives.cjs.map +1 -0
  112. package/build/legacy/config/types.cjs.map +1 -1
  113. package/build/legacy/context/confirm-modal.cjs +55 -45
  114. package/build/legacy/context/confirm-modal.cjs.map +1 -1
  115. package/build/legacy/context/field.cjs +23 -4
  116. package/build/legacy/context/field.cjs.map +1 -1
  117. package/build/legacy/context/notification-center.cjs +24 -16
  118. package/build/legacy/context/notification-center.cjs.map +1 -1
  119. package/build/legacy/context/prompt-modal.cjs +206 -194
  120. package/build/legacy/context/prompt-modal.cjs.map +1 -1
  121. package/build/legacy/hooks/useDate.cjs.map +1 -1
  122. package/build/legacy/hooks/useRootColors.cjs +0 -1
  123. package/build/legacy/hooks/useRootColors.cjs.map +1 -1
  124. package/build/legacy/hooks/useToggle.cjs.map +1 -1
  125. package/build/legacy/index.cjs +2023 -1466
  126. package/build/legacy/index.cjs.map +1 -1
  127. package/build/legacy/utils/index.cjs +22 -2
  128. package/build/legacy/utils/index.cjs.map +1 -1
  129. package/build/modern/_tsup-dts-rollup.d.ts +1345 -319
  130. package/build/modern/{chunk-PM7CWT3N.js → chunk-245SMQ45.js} +2 -2
  131. package/build/modern/chunk-245SMQ45.js.map +1 -0
  132. package/build/modern/chunk-2BIHLH4V.js +15 -0
  133. package/build/modern/chunk-2BIHLH4V.js.map +1 -0
  134. package/build/modern/chunk-2CVGNLIM.js +15 -0
  135. package/build/modern/chunk-2CVGNLIM.js.map +1 -0
  136. package/build/modern/{chunk-ISCJ542I.js → chunk-2HOUQ2DX.js} +2 -2
  137. package/build/modern/chunk-2LF3HPNA.js +1 -0
  138. package/build/modern/chunk-4LSTU6WU.js +8 -0
  139. package/build/modern/chunk-4LSTU6WU.js.map +1 -0
  140. package/build/modern/chunk-5RTNSVYU.js +88 -0
  141. package/build/modern/chunk-5RTNSVYU.js.map +1 -0
  142. package/build/modern/chunk-6I2FW4WI.js +33 -0
  143. package/build/modern/chunk-6I2FW4WI.js.map +1 -0
  144. package/build/modern/chunk-6ICNCCPD.js +47 -0
  145. package/build/modern/chunk-6ICNCCPD.js.map +1 -0
  146. package/build/modern/chunk-6KZVE4HC.js +52 -0
  147. package/build/modern/chunk-6KZVE4HC.js.map +1 -0
  148. package/build/modern/{chunk-25HMVHLT.js → chunk-7SU6FCTJ.js} +5 -5
  149. package/build/modern/chunk-7TQRTBUP.js +19 -0
  150. package/build/modern/chunk-7TQRTBUP.js.map +1 -0
  151. package/build/modern/{chunk-UZVQ4INR.js → chunk-AIJ75ENY.js} +2 -2
  152. package/build/modern/chunk-AIJ75ENY.js.map +1 -0
  153. package/build/modern/chunk-AO3GB72J.js +27 -0
  154. package/build/modern/chunk-AO3GB72J.js.map +1 -0
  155. package/build/modern/{chunk-NUMM4TNC.js → chunk-AUALRL3U.js} +2 -2
  156. package/build/modern/chunk-AUALRL3U.js.map +1 -0
  157. package/build/modern/{chunk-IGHMP4WA.js → chunk-AZRFYQO7.js} +1 -1
  158. package/build/modern/chunk-AZRFYQO7.js.map +1 -0
  159. package/build/modern/chunk-BL7G3577.js +29 -0
  160. package/build/modern/chunk-BL7G3577.js.map +1 -0
  161. package/build/modern/chunk-BPRF34DU.js +62 -0
  162. package/build/modern/chunk-BPRF34DU.js.map +1 -0
  163. package/build/modern/chunk-CAZ3EICD.js +16 -0
  164. package/build/modern/chunk-CAZ3EICD.js.map +1 -0
  165. package/build/modern/chunk-CIMY2U22.js +10 -0
  166. package/build/modern/chunk-CIMY2U22.js.map +1 -0
  167. package/build/modern/chunk-CNA2VKAH.js +43 -0
  168. package/build/modern/chunk-CNA2VKAH.js.map +1 -0
  169. package/build/modern/chunk-CYC2YUKU.js +1 -0
  170. package/build/modern/{chunk-PZAZKQMO.js → chunk-DRDNNRU3.js} +2 -2
  171. package/build/modern/chunk-DRDNNRU3.js.map +1 -0
  172. package/build/modern/{chunk-NJSETNRL.js → chunk-DXBZ3HMY.js} +2 -2
  173. package/build/modern/chunk-DXOKSZVQ.js +12 -0
  174. package/build/modern/chunk-DXOKSZVQ.js.map +1 -0
  175. package/build/modern/chunk-EL4MX2PG.js +22 -0
  176. package/build/modern/chunk-EL4MX2PG.js.map +1 -0
  177. package/build/modern/chunk-FBS7AX76.js +37 -0
  178. package/build/modern/chunk-FBS7AX76.js.map +1 -0
  179. package/build/modern/chunk-FUL2VRDU.js +25 -0
  180. package/build/modern/chunk-FUL2VRDU.js.map +1 -0
  181. package/build/modern/{chunk-BHB56M7S.js → chunk-H54FR7IP.js} +6 -6
  182. package/build/modern/chunk-H54FR7IP.js.map +1 -0
  183. package/build/modern/chunk-IASVL7CW.js +19 -0
  184. package/build/modern/chunk-IASVL7CW.js.map +1 -0
  185. package/build/modern/{chunk-REO5GUNC.js → chunk-ICTISECN.js} +1 -1
  186. package/build/modern/chunk-ICTISECN.js.map +1 -0
  187. package/build/modern/chunk-IDTAB2UJ.js +1 -0
  188. package/build/modern/chunk-IKDXADLX.js +1 -0
  189. package/build/modern/chunk-KQQPZJEI.js +21 -0
  190. package/build/modern/chunk-KQQPZJEI.js.map +1 -0
  191. package/build/modern/chunk-KWZ3CEG6.js +23 -0
  192. package/build/modern/chunk-KWZ3CEG6.js.map +1 -0
  193. package/build/modern/{chunk-JWIJHSI6.js → chunk-L7N24B6B.js} +3 -6
  194. package/build/modern/chunk-L7N24B6B.js.map +1 -0
  195. package/build/modern/chunk-LT62577B.js +23 -0
  196. package/build/modern/chunk-LT62577B.js.map +1 -0
  197. package/build/modern/chunk-LZWNHXRP.js +48 -0
  198. package/build/modern/chunk-LZWNHXRP.js.map +1 -0
  199. package/build/modern/{chunk-EDARV2EI.js → chunk-MISIUX63.js} +4 -4
  200. package/build/modern/chunk-MVO2GNUA.js +47 -0
  201. package/build/modern/chunk-MVO2GNUA.js.map +1 -0
  202. package/build/modern/{chunk-3BM6MZ4A.js → chunk-MWRO5QYD.js} +1 -1
  203. package/build/modern/chunk-MWRO5QYD.js.map +1 -0
  204. package/build/modern/{chunk-SD3OVTHT.js → chunk-O542MPR7.js} +40 -43
  205. package/build/modern/chunk-O542MPR7.js.map +1 -0
  206. package/build/modern/chunk-OGYMMATX.js +1 -0
  207. package/build/modern/chunk-OVHCXBBI.js +22 -0
  208. package/build/modern/chunk-OVHCXBBI.js.map +1 -0
  209. package/build/modern/chunk-PLHYOCY3.js +23 -0
  210. package/build/modern/chunk-PLHYOCY3.js.map +1 -0
  211. package/build/modern/{chunk-JIRW4XOJ.js → chunk-Q3I4H6EC.js} +2 -2
  212. package/build/modern/chunk-Q3I4H6EC.js.map +1 -0
  213. package/build/modern/chunk-QCBLRACK.js +133 -0
  214. package/build/modern/chunk-QCBLRACK.js.map +1 -0
  215. package/build/modern/{chunk-FGCO27TC.js → chunk-QEM3M4N3.js} +25 -34
  216. package/build/modern/chunk-QEM3M4N3.js.map +1 -0
  217. package/build/modern/{chunk-ILQW5VZT.js → chunk-RBNOEAWJ.js} +4 -7
  218. package/build/modern/chunk-RBNOEAWJ.js.map +1 -0
  219. package/build/modern/{chunk-YKKNWILF.js → chunk-RHCTPSKT.js} +2 -15
  220. package/build/modern/chunk-RHCTPSKT.js.map +1 -0
  221. package/build/modern/chunk-STLN7BMJ.js +22 -0
  222. package/build/modern/chunk-STLN7BMJ.js.map +1 -0
  223. package/build/modern/{chunk-7NN3SJ7W.js → chunk-SWX5JWZR.js} +2 -2
  224. package/build/modern/chunk-SWX5JWZR.js.map +1 -0
  225. package/build/modern/{chunk-GCQMH4QA.js → chunk-SXLPDPOZ.js} +4 -4
  226. package/build/modern/chunk-TIJAFPHQ.js +1 -0
  227. package/build/modern/chunk-TYPULJMJ.js +1 -0
  228. package/build/modern/chunk-UDY6USHW.js +1 -0
  229. package/build/modern/chunk-V4YYGGMH.js +1 -0
  230. package/build/modern/chunk-VSTOSLFS.js +100 -0
  231. package/build/modern/chunk-VSTOSLFS.js.map +1 -0
  232. package/build/modern/{chunk-ZL6ZITLA.js → chunk-WECB67DC.js} +2 -2
  233. package/build/modern/chunk-WECB67DC.js.map +1 -0
  234. package/build/modern/{chunk-BAWZBF5Q.js → chunk-WN7TJX6J.js} +2 -2
  235. package/build/modern/{chunk-RMVJK26W.js → chunk-XJQXHSH7.js} +1 -2
  236. package/build/modern/chunk-XJQXHSH7.js.map +1 -0
  237. package/build/modern/chunk-XTNGF4D6.js +41 -0
  238. package/build/modern/chunk-XTNGF4D6.js.map +1 -0
  239. package/build/modern/chunk-Y4ZEJ2EF.js +31 -0
  240. package/build/modern/chunk-Y4ZEJ2EF.js.map +1 -0
  241. package/build/modern/{chunk-WPVDQRRF.js → chunk-YOTXFCCC.js} +2 -2
  242. package/build/modern/chunk-YOTXFCCC.js.map +1 -0
  243. package/build/modern/chunk-Z3FDG263.js +53 -0
  244. package/build/modern/chunk-Z3FDG263.js.map +1 -0
  245. package/build/modern/{chunk-JAROS4Q3.js → chunk-Z4342DRO.js} +10 -10
  246. package/build/modern/chunk-Z4342DRO.js.map +1 -0
  247. package/build/modern/chunk-Z52R6ABJ.js +21 -0
  248. package/build/modern/chunk-Z52R6ABJ.js.map +1 -0
  249. package/build/modern/{chunk-O6LFWUHI.js → chunk-ZFFW5ELD.js} +10 -10
  250. package/build/modern/chunk-ZFFW5ELD.js.map +1 -0
  251. package/build/modern/components/Accordion.js +1 -1
  252. package/build/modern/components/AccordionItemGroup.js +3 -3
  253. package/build/modern/components/Admonition.client.js +3 -3
  254. package/build/modern/components/Admonition.js +4 -4
  255. package/build/modern/components/Avatar.js +2 -2
  256. package/build/modern/components/DatePicker.client.js +4 -3
  257. package/build/modern/components/FileStatus.js +11 -5
  258. package/build/modern/components/FileUploader.js +3 -3
  259. package/build/modern/components/Legend.js +1 -2
  260. package/build/modern/components/Tag.js +2 -2
  261. package/build/modern/components/button/button.js +12 -0
  262. package/build/modern/components/button/index.js +16 -0
  263. package/build/modern/components/button/parts.js +10 -0
  264. package/build/modern/components/checkbox/checkbox-icon.js +12 -0
  265. package/build/modern/components/checkbox/checkbox.js +13 -0
  266. package/build/modern/components/checkbox/index.js +30 -0
  267. package/build/modern/components/checkbox/parts.js +8 -0
  268. package/build/modern/components/checkbox/primitives.js +17 -0
  269. package/build/modern/components/cta-dialog/context.js +8 -0
  270. package/build/modern/components/cta-dialog/index.js +26 -0
  271. package/build/modern/components/cta-dialog/provider.js +22 -0
  272. package/build/modern/components/cta-dialog/provider.js.map +1 -0
  273. package/build/modern/components/cta-dialog/trigger-item.js +10 -0
  274. package/build/modern/components/cta-dialog/trigger-item.js.map +1 -0
  275. package/build/modern/components/cta-dialog/utils.js +7 -0
  276. package/build/modern/components/cta-dialog/utils.js.map +1 -0
  277. package/build/modern/components/deprecated/FieldMessage.js +8 -0
  278. package/build/modern/components/deprecated/FieldMessage.js.map +1 -0
  279. package/build/modern/components/deprecated/FieldsetLabel.js +7 -0
  280. package/build/modern/components/deprecated/FieldsetLabel.js.map +1 -0
  281. package/build/modern/components/deprecated/Label.js +17 -0
  282. package/build/modern/components/deprecated/Label.js.map +1 -0
  283. package/build/modern/components/deprecated/Modal.js +7 -0
  284. package/build/modern/components/deprecated/Modal.js.map +1 -0
  285. package/build/modern/components/deprecated/ModalDescription.js +7 -0
  286. package/build/modern/components/deprecated/ModalDescription.js.map +1 -0
  287. package/build/modern/components/deprecated/ModalHeader.js +7 -0
  288. package/build/modern/components/deprecated/ModalHeader.js.map +1 -0
  289. package/build/modern/components/deprecated/ModalHeading.js +7 -0
  290. package/build/modern/components/deprecated/ModalHeading.js.map +1 -0
  291. package/build/modern/components/deprecated/NavMenuLink.js +8 -0
  292. package/build/modern/components/deprecated/NavMenuLink.js.map +1 -0
  293. package/build/modern/components/deprecated/NavMenuList.js +12 -0
  294. package/build/modern/components/deprecated/NavMenuList.js.map +1 -0
  295. package/build/modern/components/deprecated/NavMenuTrigger.js +11 -0
  296. package/build/modern/components/deprecated/NavMenuTrigger.js.map +1 -0
  297. package/build/modern/components/field/field.js +14 -0
  298. package/build/modern/components/field/field.js.map +1 -0
  299. package/build/modern/components/field/index.js +44 -0
  300. package/build/modern/components/field/index.js.map +1 -0
  301. package/build/modern/components/field/parts.js +11 -0
  302. package/build/modern/components/field/parts.js.map +1 -0
  303. package/build/modern/components/field/primitives.js +26 -0
  304. package/build/modern/components/field/primitives.js.map +1 -0
  305. package/build/modern/components/field/start-indicator.js +7 -0
  306. package/build/modern/components/field/start-indicator.js.map +1 -0
  307. package/build/modern/components/field/status-indicator.js +9 -0
  308. package/build/modern/components/field/status-indicator.js.map +1 -0
  309. package/build/modern/components/fieldset/fieldset.js +11 -0
  310. package/build/modern/components/fieldset/fieldset.js.map +1 -0
  311. package/build/modern/components/fieldset/index.js +24 -0
  312. package/build/modern/components/fieldset/index.js.map +1 -0
  313. package/build/modern/components/fieldset/parts.js +8 -0
  314. package/build/modern/components/fieldset/parts.js.map +1 -0
  315. package/build/modern/components/fieldset/primitives.js +13 -0
  316. package/build/modern/components/fieldset/primitives.js.map +1 -0
  317. package/build/modern/components/for.js +7 -0
  318. package/build/modern/components/for.js.map +1 -0
  319. package/build/modern/components/radio/index.js +30 -0
  320. package/build/modern/components/radio/index.js.map +1 -0
  321. package/build/modern/components/radio/parts.js +8 -0
  322. package/build/modern/components/radio/parts.js.map +1 -0
  323. package/build/modern/components/radio/primitives.js +21 -0
  324. package/build/modern/components/radio/primitives.js.map +1 -0
  325. package/build/modern/components/radio/radio.js +8 -0
  326. package/build/modern/components/radio/radio.js.map +1 -0
  327. package/build/modern/components/select/index.js +57 -0
  328. package/build/modern/components/select/index.js.map +1 -0
  329. package/build/modern/components/select/option-group.js +10 -0
  330. package/build/modern/components/select/option-group.js.map +1 -0
  331. package/build/modern/components/select/parts.js +8 -0
  332. package/build/modern/components/select/parts.js.map +1 -0
  333. package/build/modern/components/select/primitives.js +37 -0
  334. package/build/modern/components/select/primitives.js.map +1 -0
  335. package/build/modern/components/select/select.js +15 -0
  336. package/build/modern/components/select/select.js.map +1 -0
  337. package/build/modern/components/switch/index.js +26 -0
  338. package/build/modern/components/switch/index.js.map +1 -0
  339. package/build/modern/components/switch/parts.js +8 -0
  340. package/build/modern/components/switch/parts.js.map +1 -0
  341. package/build/modern/components/switch/primitives.js +15 -0
  342. package/build/modern/components/switch/primitives.js.map +1 -0
  343. package/build/modern/components/switch/switch-indicator.js +9 -0
  344. package/build/modern/components/switch/switch-indicator.js.map +1 -0
  345. package/build/modern/components/switch/switch.js +11 -0
  346. package/build/modern/components/switch/switch.js.map +1 -0
  347. package/build/modern/components/toggle/index.js +14 -0
  348. package/build/modern/components/toggle/index.js.map +1 -0
  349. package/build/modern/components/toggle/parts.js +8 -0
  350. package/build/modern/components/toggle/parts.js.map +1 -0
  351. package/build/modern/components/toggle/primitives.js +9 -0
  352. package/build/modern/components/toggle/primitives.js.map +1 -0
  353. package/build/modern/context/confirm-modal.js +5 -4
  354. package/build/modern/context/field.js +34 -4
  355. package/build/modern/context/field.js.map +1 -1
  356. package/build/modern/context/notification-center.js +5 -4
  357. package/build/modern/context/prompt-modal.js +13 -7
  358. package/build/modern/hooks/useDate.js +1 -1
  359. package/build/modern/hooks/useRootColors.js +1 -1
  360. package/build/modern/hooks/useToggle.js +1 -1
  361. package/build/modern/index.js +304 -129
  362. package/build/modern/index.js.map +1 -1
  363. package/build/modern/utils/index.js +5 -3
  364. package/package.json +2 -2
  365. package/src/components/Accordion.tsx +1 -0
  366. package/src/components/DatePicker.client.tsx +3 -15
  367. package/src/components/FileStatus.tsx +4 -5
  368. package/src/components/Legend.tsx +5 -6
  369. package/src/components/button/button.tsx +77 -0
  370. package/src/components/button/index.ts +2 -0
  371. package/src/components/button/parts.ts +32 -0
  372. package/src/components/checkbox/checkbox-icon.tsx +39 -0
  373. package/src/components/checkbox/checkbox.tsx +42 -0
  374. package/src/components/checkbox/index.ts +3 -0
  375. package/src/components/checkbox/parts.ts +59 -0
  376. package/src/components/checkbox/primitives.tsx +104 -0
  377. package/src/components/cta-dialog/context.tsx +34 -0
  378. package/src/components/cta-dialog/index.ts +2 -0
  379. package/src/{context/cta-modal.tsx → components/cta-dialog/provider.tsx} +34 -68
  380. package/src/components/cta-dialog/trigger-item.tsx +53 -0
  381. package/src/components/cta-dialog/utils.ts +57 -0
  382. package/src/components/{FieldMessage.tsx → deprecated/FieldMessage.tsx} +2 -13
  383. package/src/components/deprecated/FieldsetLabel.tsx +32 -0
  384. package/src/components/deprecated/Label.tsx +24 -0
  385. package/src/components/{NavMenuLink.tsx → deprecated/NavMenuLink.tsx} +1 -1
  386. package/src/components/{NavMenuList.tsx → deprecated/NavMenuList.tsx} +3 -3
  387. package/src/components/{NavMenuTrigger.tsx → deprecated/NavMenuTrigger.tsx} +4 -4
  388. package/src/components/field/field.tsx +77 -0
  389. package/src/components/field/index.ts +5 -0
  390. package/src/components/field/parts.ts +77 -0
  391. package/src/components/field/primitives.tsx +204 -0
  392. package/src/components/field/start-indicator.tsx +23 -0
  393. package/src/components/field/status-indicator.tsx +58 -0
  394. package/src/components/fieldset/fieldset.tsx +55 -0
  395. package/src/components/fieldset/index.ts +3 -0
  396. package/src/components/fieldset/parts.ts +47 -0
  397. package/src/components/fieldset/primitives.tsx +79 -0
  398. package/src/components/for.tsx +38 -0
  399. package/src/components/radio/index.ts +3 -0
  400. package/src/components/radio/parts.ts +65 -0
  401. package/src/components/radio/primitives.tsx +123 -0
  402. package/src/components/radio/radio.tsx +35 -0
  403. package/src/components/select/index.ts +4 -0
  404. package/src/components/select/option-group.tsx +34 -0
  405. package/src/components/select/parts.ts +113 -0
  406. package/src/components/select/primitives.tsx +205 -0
  407. package/src/components/select/select.tsx +135 -0
  408. package/src/components/switch/index.ts +3 -0
  409. package/src/components/switch/parts.ts +53 -0
  410. package/src/components/switch/primitives.tsx +69 -0
  411. package/src/components/switch/switch-indicator.tsx +9 -0
  412. package/src/components/switch/switch.tsx +30 -0
  413. package/src/components/toggle/index.ts +2 -0
  414. package/src/components/toggle/parts.ts +32 -0
  415. package/src/components/toggle/primitives.tsx +17 -0
  416. package/src/config/types.ts +1 -0
  417. package/src/context/confirm-modal.tsx +1 -1
  418. package/src/context/field.tsx +6 -5
  419. package/src/context/notification-center.tsx +1 -1
  420. package/src/context/prompt-modal.tsx +16 -18
  421. package/src/hooks/useDate.ts +1 -7
  422. package/src/hooks/useRootColors.ts +0 -1
  423. package/src/hooks/useToggle.ts +1 -3
  424. package/src/index.ts +24 -24
  425. package/src/utils/index.ts +30 -0
  426. package/build/legacy/components/Button.cjs.map +0 -1
  427. package/build/legacy/components/Checkbox.cjs +0 -113
  428. package/build/legacy/components/Checkbox.cjs.map +0 -1
  429. package/build/legacy/components/FieldMessage.cjs.map +0 -1
  430. package/build/legacy/components/Fieldset.cjs.map +0 -1
  431. package/build/legacy/components/FieldsetLabel.cjs.map +0 -1
  432. package/build/legacy/components/Input.cjs +0 -95
  433. package/build/legacy/components/Input.cjs.map +0 -1
  434. package/build/legacy/components/Label.cjs +0 -93
  435. package/build/legacy/components/Label.cjs.map +0 -1
  436. package/build/legacy/components/Modal.cjs.map +0 -1
  437. package/build/legacy/components/ModalDescription.cjs.map +0 -1
  438. package/build/legacy/components/ModalHeader.cjs.map +0 -1
  439. package/build/legacy/components/ModalHeading.cjs.map +0 -1
  440. package/build/legacy/components/NavMenuLink.cjs.map +0 -1
  441. package/build/legacy/components/NavMenuList.cjs.map +0 -1
  442. package/build/legacy/components/NavMenuTrigger.cjs.map +0 -1
  443. package/build/legacy/components/Radio.cjs +0 -81
  444. package/build/legacy/components/Radio.cjs.map +0 -1
  445. package/build/legacy/components/Select.cjs +0 -120
  446. package/build/legacy/components/Select.cjs.map +0 -1
  447. package/build/legacy/components/Textarea.cjs.map +0 -1
  448. package/build/legacy/components/Toggle.cjs +0 -101
  449. package/build/legacy/components/Toggle.cjs.map +0 -1
  450. package/build/legacy/context/cta-modal.cjs.map +0 -1
  451. package/build/modern/chunk-3BM6MZ4A.js.map +0 -1
  452. package/build/modern/chunk-3ZDFQO25.js +0 -31
  453. package/build/modern/chunk-3ZDFQO25.js.map +0 -1
  454. package/build/modern/chunk-7NN3SJ7W.js.map +0 -1
  455. package/build/modern/chunk-BHB56M7S.js.map +0 -1
  456. package/build/modern/chunk-C5EHJUS5.js +0 -10
  457. package/build/modern/chunk-C5EHJUS5.js.map +0 -1
  458. package/build/modern/chunk-EXGKZGML.js +0 -28
  459. package/build/modern/chunk-EXGKZGML.js.map +0 -1
  460. package/build/modern/chunk-FGCO27TC.js.map +0 -1
  461. package/build/modern/chunk-FTPZHG6J.js +0 -46
  462. package/build/modern/chunk-FTPZHG6J.js.map +0 -1
  463. package/build/modern/chunk-IGHMP4WA.js.map +0 -1
  464. package/build/modern/chunk-ILQW5VZT.js.map +0 -1
  465. package/build/modern/chunk-JAROS4Q3.js.map +0 -1
  466. package/build/modern/chunk-JIJM6JFJ.js +0 -36
  467. package/build/modern/chunk-JIJM6JFJ.js.map +0 -1
  468. package/build/modern/chunk-JIRW4XOJ.js.map +0 -1
  469. package/build/modern/chunk-JWIJHSI6.js.map +0 -1
  470. package/build/modern/chunk-KKHL3ZO4.js +0 -69
  471. package/build/modern/chunk-KKHL3ZO4.js.map +0 -1
  472. package/build/modern/chunk-MZ3UCDUL.js +0 -43
  473. package/build/modern/chunk-MZ3UCDUL.js.map +0 -1
  474. package/build/modern/chunk-N24COMHJ.js +0 -63
  475. package/build/modern/chunk-N24COMHJ.js.map +0 -1
  476. package/build/modern/chunk-NMF2HYWO.js +0 -50
  477. package/build/modern/chunk-NMF2HYWO.js.map +0 -1
  478. package/build/modern/chunk-NUMM4TNC.js.map +0 -1
  479. package/build/modern/chunk-O6LFWUHI.js.map +0 -1
  480. package/build/modern/chunk-PM7CWT3N.js.map +0 -1
  481. package/build/modern/chunk-PZAZKQMO.js.map +0 -1
  482. package/build/modern/chunk-REO5GUNC.js.map +0 -1
  483. package/build/modern/chunk-RMVJK26W.js.map +0 -1
  484. package/build/modern/chunk-SD3OVTHT.js.map +0 -1
  485. package/build/modern/chunk-UZDVOIW5.js +0 -33
  486. package/build/modern/chunk-UZDVOIW5.js.map +0 -1
  487. package/build/modern/chunk-UZVQ4INR.js.map +0 -1
  488. package/build/modern/chunk-WPVDQRRF.js.map +0 -1
  489. package/build/modern/chunk-XQICKZH4.js +0 -59
  490. package/build/modern/chunk-XQICKZH4.js.map +0 -1
  491. package/build/modern/chunk-YKKNWILF.js.map +0 -1
  492. package/build/modern/chunk-ZL6ZITLA.js.map +0 -1
  493. package/build/modern/components/Button.js +0 -7
  494. package/build/modern/components/Checkbox.js +0 -11
  495. package/build/modern/components/FieldMessage.js +0 -9
  496. package/build/modern/components/Fieldset.js +0 -9
  497. package/build/modern/components/FieldsetLabel.js +0 -7
  498. package/build/modern/components/Input.js +0 -11
  499. package/build/modern/components/Label.js +0 -10
  500. package/build/modern/components/Modal.js +0 -7
  501. package/build/modern/components/ModalDescription.js +0 -7
  502. package/build/modern/components/ModalHeader.js +0 -7
  503. package/build/modern/components/ModalHeading.js +0 -7
  504. package/build/modern/components/NavMenuLink.js +0 -8
  505. package/build/modern/components/NavMenuList.js +0 -12
  506. package/build/modern/components/NavMenuTrigger.js +0 -11
  507. package/build/modern/components/Radio.js +0 -9
  508. package/build/modern/components/Select.js +0 -13
  509. package/build/modern/components/Textarea.js +0 -9
  510. package/build/modern/components/Toggle.js +0 -10
  511. package/build/modern/context/cta-modal.js +0 -18
  512. package/src/components/Button.tsx +0 -35
  513. package/src/components/Checkbox.tsx +0 -93
  514. package/src/components/Fieldset.tsx +0 -65
  515. package/src/components/FieldsetLabel.tsx +0 -59
  516. package/src/components/Input.tsx +0 -69
  517. package/src/components/Label.tsx +0 -69
  518. package/src/components/Radio.tsx +0 -73
  519. package/src/components/Select.tsx +0 -108
  520. package/src/components/Textarea.tsx +0 -52
  521. package/src/components/Toggle.tsx +0 -91
  522. /package/build/modern/{chunk-ISCJ542I.js.map → chunk-2HOUQ2DX.js.map} +0 -0
  523. /package/build/modern/{components/Button.js.map → chunk-2LF3HPNA.js.map} +0 -0
  524. /package/build/modern/{chunk-25HMVHLT.js.map → chunk-7SU6FCTJ.js.map} +0 -0
  525. /package/build/modern/{components/Checkbox.js.map → chunk-CYC2YUKU.js.map} +0 -0
  526. /package/build/modern/{chunk-NJSETNRL.js.map → chunk-DXBZ3HMY.js.map} +0 -0
  527. /package/build/modern/{components/FieldMessage.js.map → chunk-IDTAB2UJ.js.map} +0 -0
  528. /package/build/modern/{components/Fieldset.js.map → chunk-IKDXADLX.js.map} +0 -0
  529. /package/build/modern/{chunk-EDARV2EI.js.map → chunk-MISIUX63.js.map} +0 -0
  530. /package/build/modern/{components/FieldsetLabel.js.map → chunk-OGYMMATX.js.map} +0 -0
  531. /package/build/modern/{chunk-GCQMH4QA.js.map → chunk-SXLPDPOZ.js.map} +0 -0
  532. /package/build/modern/{components/Input.js.map → chunk-TIJAFPHQ.js.map} +0 -0
  533. /package/build/modern/{components/Label.js.map → chunk-TYPULJMJ.js.map} +0 -0
  534. /package/build/modern/{components/Modal.js.map → chunk-UDY6USHW.js.map} +0 -0
  535. /package/build/modern/{components/ModalDescription.js.map → chunk-V4YYGGMH.js.map} +0 -0
  536. /package/build/modern/{chunk-BAWZBF5Q.js.map → chunk-WN7TJX6J.js.map} +0 -0
  537. /package/build/modern/components/{ModalHeader.js.map → button/button.js.map} +0 -0
  538. /package/build/modern/components/{ModalHeading.js.map → button/index.js.map} +0 -0
  539. /package/build/modern/components/{NavMenuLink.js.map → button/parts.js.map} +0 -0
  540. /package/build/modern/components/{NavMenuList.js.map → checkbox/checkbox-icon.js.map} +0 -0
  541. /package/build/modern/components/{NavMenuTrigger.js.map → checkbox/checkbox.js.map} +0 -0
  542. /package/build/modern/components/{Radio.js.map → checkbox/index.js.map} +0 -0
  543. /package/build/modern/components/{Select.js.map → checkbox/parts.js.map} +0 -0
  544. /package/build/modern/components/{Textarea.js.map → checkbox/primitives.js.map} +0 -0
  545. /package/build/modern/components/{Toggle.js.map → cta-dialog/context.js.map} +0 -0
  546. /package/build/modern/{context/cta-modal.js.map → components/cta-dialog/index.js.map} +0 -0
  547. /package/src/components/{Modal.tsx → deprecated/Modal.tsx} +0 -0
  548. /package/src/components/{ModalDescription.tsx → deprecated/ModalDescription.tsx} +0 -0
  549. /package/src/components/{ModalHeader.tsx → deprecated/ModalHeader.tsx} +0 -0
  550. /package/src/components/{ModalHeading.tsx → deprecated/ModalHeading.tsx} +0 -0
@@ -1,66 +1,39 @@
1
1
  'use client'
2
2
 
3
3
  import {
4
- createContext,
5
4
  useCallback,
6
5
  useContext,
7
6
  useMemo,
8
7
  useState,
9
8
  type MouseEvent,
10
- type MouseEventHandler,
11
9
  type PropsWithChildren,
12
10
  type ReactNode,
13
11
  } from 'react'
14
- import { Button } from '../components/Button'
15
- import { Show } from '../components/Show'
16
- import { Avatar } from '../components/Avatar'
17
- import { useCerberusContext } from './cerberus'
18
- import { HStack } from '@cerberus/styled-system/jsx'
19
- import { css } from '@cerberus/styled-system/css'
20
- import { VStack } from '@cerberus/styled-system/jsx'
12
+ import { HStack, VStack } from '@cerberus/styled-system/jsx'
13
+ import { useCerberusContext } from '../../context/cerberus'
14
+ import { Show } from '../Show'
15
+ import { For } from '../for'
16
+ import { Avatar } from '../Avatar'
21
17
  import {
22
18
  Dialog,
23
19
  DialogDescription,
24
20
  DialogHeading,
25
21
  DialogProvider,
26
- } from '../components/Dialog'
27
- import { DialogCloseIconTrigger } from '../components/Dialog.client'
22
+ } from '../Dialog'
23
+ import { DialogCloseIconTrigger } from '../Dialog.client'
24
+ import type { CTAButtonAction, CTAModalActionReturn } from './utils'
25
+ import {
26
+ CTAModalContext,
27
+ type CTAModalValue,
28
+ type ShowCTAModalOptions,
29
+ } from './context'
30
+ import { TriggerItem } from './trigger-item'
28
31
 
29
32
  /**
30
- * This module provides a context and hook for the cta modal.
31
- * @module
33
+ * This module provides the provider and hook for the cta modal.
34
+ * @module 'react/cta-modal/provider'
32
35
  */
33
36
 
34
- export interface ShowCTAModalOptions {
35
- /**
36
- * The heading of the cta modal.
37
- */
38
- heading: string
39
- /**
40
- * The description of the cta modal.
41
- */
42
- description?: string
43
- /**
44
- * The icon used for the modal Avatar.
45
- */
46
- icon?: ReactNode
47
- /**
48
- * The actions for the cta modal. Max of 2 actions.
49
- */
50
- actions: {
51
- text: string
52
- onClick: MouseEventHandler<HTMLButtonElement>
53
- }[]
54
- }
55
-
56
- export interface CTAModalValue {
57
- show: (options: ShowCTAModalOptions) => void
58
- }
59
-
60
- const CTAModalContext = createContext<CTAModalValue | null>(null)
61
-
62
- export type CTAModalProviderProps = PropsWithChildren<unknown>
63
-
64
37
  /**
65
38
  * Provides a CTA modal to the app.
66
39
  * @see https://cerberus.digitalu.design/react/cta-modal
@@ -93,7 +66,7 @@ export type CTAModalProviderProps = PropsWithChildren<unknown>
93
66
  * }, [cta])
94
67
  * ```
95
68
  */
96
- export function CTAModal(props: PropsWithChildren<CTAModalProviderProps>) {
69
+ export function CTAModal(props: PropsWithChildren<object>) {
97
70
  const [open, setOpen] = useState<boolean>(false)
98
71
  const [content, setContent] = useState<ShowCTAModalOptions | null>(null)
99
72
  const confirmIcon = content?.icon
@@ -103,12 +76,6 @@ export function CTAModal(props: PropsWithChildren<CTAModalProviderProps>) {
103
76
 
104
77
  const handleShow = useCallback(
105
78
  (options: ShowCTAModalOptions) => {
106
- const maxActions = 2
107
- if (options.actions.length > maxActions) {
108
- throw new Error(
109
- `CTA Modal only supports a maximum of ${maxActions} actions.`,
110
- )
111
- }
112
79
  setContent({ ...options })
113
80
  setOpen(true)
114
81
  },
@@ -117,10 +84,10 @@ export function CTAModal(props: PropsWithChildren<CTAModalProviderProps>) {
117
84
 
118
85
  const handleActionClick = useCallback(
119
86
  (event: MouseEvent<HTMLButtonElement>) => {
120
- const index = event.currentTarget.getAttribute('data-index')
121
- const action = content?.actions[Number(index)]
122
- const { onClick } = action || {}
123
- onClick?.(event)
87
+ const index = Number(event.currentTarget.getAttribute('data-index'))
88
+ const contentActions = content?.actions as CTAModalActionReturn
89
+ const action = contentActions._actions[index] as CTAButtonAction
90
+ action?.handleClick?.(event)
124
91
  setOpen(false)
125
92
  },
126
93
  [content, setOpen],
@@ -163,22 +130,21 @@ export function CTAModal(props: PropsWithChildren<CTAModalProviderProps>) {
163
130
  </VStack>
164
131
 
165
132
  <HStack gap="md" w="full">
166
- <Show when={Boolean(content?.actions?.length)}>
167
- {content?.actions?.map((action, index) => (
168
- <Button
169
- data-index={index}
170
- className={css({
171
- w: '1/2',
172
- })}
133
+ <For each={content?.actions._actions}>
134
+ {(action, index) => (
135
+ <Show
173
136
  key={index}
174
- onClick={handleActionClick}
175
- shape="rounded"
176
- usage="outlined"
137
+ when={content?.actions?.type === 'btnAction'}
138
+ fallback={
139
+ <TriggerItem asChild>{action as ReactNode}</TriggerItem>
140
+ }
177
141
  >
178
- {action.text}
179
- </Button>
180
- ))}
181
- </Show>
142
+ <TriggerItem data-index={index} onClick={handleActionClick}>
143
+ {(action as CTAButtonAction)?.text}
144
+ </TriggerItem>
145
+ </Show>
146
+ )}
147
+ </For>
182
148
  </HStack>
183
149
  </VStack>
184
150
  </Dialog>
@@ -0,0 +1,53 @@
1
+ import { css, cx } from '@cerberus/styled-system/css'
2
+ import { Button, type ButtonProps } from '../button/button'
3
+ import { ark } from '@ark-ui/react/factory'
4
+ import { button } from '@cerberus/styled-system/recipes'
5
+
6
+ /**
7
+ * This module provides the trigger item for the cta modal.
8
+ * @module 'react/cta-modal/trigger-item'
9
+ */
10
+
11
+ export interface TriggerItemProps extends ButtonProps {
12
+ asChild?: boolean
13
+ }
14
+
15
+ /**
16
+ * Trigger item for the cta modal which renders content based on the actions.
17
+ * type.
18
+ */
19
+ export function TriggerItem(props: TriggerItemProps) {
20
+ const { asChild, children, ...buttonProps } = props
21
+
22
+ if (asChild) {
23
+ return (
24
+ <ark.div
25
+ className={cx(
26
+ button({
27
+ shape: 'rounded',
28
+ usage: 'ghost',
29
+ }),
30
+ css({
31
+ w: '1/2',
32
+ }),
33
+ )}
34
+ asChild
35
+ >
36
+ {children}
37
+ </ark.div>
38
+ )
39
+ }
40
+
41
+ return (
42
+ <Button
43
+ {...buttonProps}
44
+ className={css({
45
+ w: '1/2',
46
+ })}
47
+ shape="rounded"
48
+ usage="outlined"
49
+ >
50
+ {children}
51
+ </Button>
52
+ )
53
+ }
@@ -0,0 +1,57 @@
1
+ import type { MouseEventHandler, ReactNode } from 'react'
2
+
3
+ /**
4
+ * This module provide utility functions for the cta modal.
5
+ * @module 'react/cta-modal/utils'
6
+ */
7
+
8
+ export type CTAButtonAction = {
9
+ /**
10
+ * The text of the button.
11
+ */
12
+ text: string
13
+ /**
14
+ * The onClick handler for the button.
15
+ */
16
+ handleClick: MouseEventHandler<HTMLButtonElement>
17
+ }
18
+
19
+ export type CTAModalAction = (CTAButtonAction | ReactNode)[]
20
+
21
+ export interface CTAModalActionReturn {
22
+ /**
23
+ * The type of the action content.
24
+ */
25
+ type: 'reactNode' | 'btnAction'
26
+ /**
27
+ * The actions for the cta modal. Max of 2 actions.
28
+ */
29
+ _actions: CTAModalAction
30
+ }
31
+
32
+ /**
33
+ * Creates the action data to pass to the cta modal `show` method.
34
+ */
35
+ export function createCTAModalActions(
36
+ providedActions: CTAModalAction,
37
+ ): CTAModalActionReturn {
38
+ if (providedActions.length !== 2) {
39
+ throw new Error('CTAModal must include 2 actions')
40
+ }
41
+
42
+ if (
43
+ providedActions.every(
44
+ (action) => (action as unknown as CTAButtonAction)?.handleClick,
45
+ )
46
+ ) {
47
+ return {
48
+ type: 'btnAction',
49
+ _actions: providedActions as CTAButtonAction[],
50
+ }
51
+ }
52
+
53
+ return {
54
+ type: 'reactNode',
55
+ _actions: providedActions as ReactNode[],
56
+ }
57
+ }
@@ -6,7 +6,7 @@ import {
6
6
  fieldMessage,
7
7
  type FieldMessageVariantProps,
8
8
  } from '@cerberus/styled-system/recipes'
9
- import { useFieldContext } from '../context/field'
9
+ import { useFieldContext } from '@ark-ui/react/field'
10
10
 
11
11
  /**
12
12
  * This module contains the FieldMessage component.
@@ -25,18 +25,7 @@ export interface FieldMessageBaseProps
25
25
  export type FieldMessageProps = FieldMessageBaseProps & FieldMessageVariantProps
26
26
 
27
27
  /**
28
- * A component that provides feedback about the field.
29
- * @see https://cerberus.digitalu.design/react/field-message
30
- * @example
31
- * ```tsx
32
- * <Field>
33
- * <Label htmlFor="first_name">First Name</Label>
34
- * <Input aria-describedBy="help:first_name" id="first_name" type="text" />
35
- * <FieldMessage id="help:first_name">
36
- * This will only be used in your account information.
37
- * </FieldMessage>
38
- * </Field>
39
- * ```
28
+ * @deprecated use FieldHelperText, FieldErrorText, or FieldParts instead
40
29
  */
41
30
  export function FieldMessage(props: FieldMessageProps) {
42
31
  const { invalid } = useFieldContext()
@@ -0,0 +1,32 @@
1
+ import { cx } from '@cerberus/styled-system/css'
2
+ import { label, type LabelVariantProps } from '@cerberus/styled-system/recipes'
3
+ import type { LabelProps } from './Label'
4
+
5
+ /**
6
+ * This module contains the FieldsetLabel component.
7
+ * @module FieldsetLabel
8
+ */
9
+
10
+ export type FieldsetLabelProps = LabelProps &
11
+ LabelVariantProps & {
12
+ htmlFor?: string
13
+ }
14
+
15
+ /**
16
+ * @deprecated
17
+ */
18
+ export function FieldsetLabel(props: FieldsetLabelProps) {
19
+ const { size, usage, ...nativeProps } = props
20
+ return (
21
+ <label
22
+ {...nativeProps}
23
+ className={cx(
24
+ nativeProps.className,
25
+ label({
26
+ size,
27
+ usage,
28
+ }),
29
+ )}
30
+ />
31
+ )
32
+ }
@@ -0,0 +1,24 @@
1
+ import type { HTMLAttributes, PropsWithChildren } from 'react'
2
+ import { label, type LabelVariantProps } from '@cerberus/styled-system/recipes'
3
+ import { cx } from '@cerberus/styled-system/css'
4
+ import { FieldLabel } from '../field'
5
+
6
+ /**
7
+ * This module contains the Label component.
8
+ * @module
9
+ */
10
+ export type LabelBaseProps = HTMLAttributes<HTMLLabelElement>
11
+ export type LabelProps = LabelBaseProps & LabelVariantProps
12
+
13
+ /**
14
+ * @deprecated Use FieldLabel or FieldParts.Label instead.
15
+ */
16
+ export function Label(props: PropsWithChildren<LabelProps>) {
17
+ const { size, ...nativeProps } = props
18
+ return (
19
+ <FieldLabel
20
+ {...nativeProps}
21
+ className={cx(label({ size }), props.className)}
22
+ />
23
+ )
24
+ }
@@ -1,6 +1,6 @@
1
1
  import type { AnchorHTMLAttributes, ElementType } from 'react'
2
2
  import { css, cx } from '@cerberus/styled-system/css'
3
- import { Show } from './Show'
3
+ import { Show } from '../Show'
4
4
 
5
5
  /**
6
6
  * This module contains the NavMenuLink component.
@@ -3,9 +3,9 @@
3
3
  import { useMemo, type HTMLAttributes } from 'react'
4
4
  import { cx } from '@cerberus/styled-system/css'
5
5
  import { vstack } from '@cerberus/styled-system/patterns'
6
- import { useNavMenuContext } from '../context/navMenu'
7
- import type { Positions } from '../types'
8
- import { Show } from './Show'
6
+ import { useNavMenuContext } from '../../context/navMenu'
7
+ import type { Positions } from '../../types'
8
+ import { Show } from '../Show'
9
9
 
10
10
  /**
11
11
  * This module contains the NavMenuList component.
@@ -11,10 +11,10 @@ import { button } from '@cerberus/styled-system/recipes'
11
11
  import {
12
12
  createNavTriggerProps,
13
13
  type NavTriggerAriaValues,
14
- } from '../aria-helpers/nav-menu.aria'
15
- import { useNavMenuContext } from '../context/navMenu'
16
- import type { ButtonProps } from './Button'
17
- import { Show } from './Show'
14
+ } from '../../aria-helpers/nav-menu.aria'
15
+ import { useNavMenuContext } from '../../context/navMenu'
16
+ import type { ButtonProps } from '../button/button'
17
+ import { Show } from '../Show'
18
18
 
19
19
  /**
20
20
  * This module contains the NavMenuTrigger component.
@@ -0,0 +1,77 @@
1
+ import { type FieldRootProps } from '@ark-ui/react/field'
2
+ import { splitProps } from '../../utils/index'
3
+ import {
4
+ FieldErrorText,
5
+ FieldHelperText,
6
+ FieldLabel,
7
+ FieldRoot,
8
+ } from './primitives'
9
+ import { HStack } from '@cerberus/styled-system/jsx'
10
+ import { Show } from '../Show'
11
+
12
+ export interface FieldProps extends FieldRootProps {
13
+ /**
14
+ * The label of the field.
15
+ */
16
+ label?: string
17
+ /**
18
+ * The helper text of the field.
19
+ */
20
+ helperText?: string
21
+ /**
22
+ * A helper text positioned at the end of the field. Good for Textarea fields.
23
+ */
24
+ secondaryHelperText?: string
25
+ /**
26
+ * The error text of the field. Shown when the field is invalid.
27
+ */
28
+ errorText?: string
29
+ }
30
+
31
+ /**
32
+ * The Field component is the context provider for all FieldParts and displays
33
+ * the label, helperText, and ErrorText.
34
+ * @description [Field Docs](https://cerberus.digitalu.design/react/field)
35
+ * @example
36
+ * ```tsx
37
+ * <Field
38
+ * ids={{
39
+ * control: 'firstName',
40
+ * }}
41
+ * label="Label"
42
+ * helperText="This is what people will see on your profile."
43
+ * errorText="A first name is required to create an account."
44
+ * required
45
+ * >
46
+ * <Input name="firstName" type="text" />
47
+ * </Field>
48
+ * ```
49
+ */
50
+ export function Field(props: FieldProps) {
51
+ const [statusProps, fieldProps, rootProps] = splitProps(
52
+ props,
53
+ ['disabled', 'required', 'readOnly', 'invalid'],
54
+ ['label', 'helperText', 'secondaryHelperText', 'errorText', 'children'],
55
+ )
56
+
57
+ return (
58
+ <FieldRoot {...statusProps} {...rootProps}>
59
+ <Show when={Boolean(fieldProps.label)}>
60
+ <FieldLabel>{fieldProps.label}</FieldLabel>
61
+ </Show>
62
+
63
+ {fieldProps.children}
64
+
65
+ <Show when={Boolean(fieldProps.helperText && !statusProps.invalid)}>
66
+ <HStack justifyContent="space-between" w="full">
67
+ <FieldHelperText>{fieldProps.helperText}</FieldHelperText>
68
+ <Show when={Boolean(fieldProps.secondaryHelperText)}>
69
+ <FieldHelperText>{fieldProps.secondaryHelperText}</FieldHelperText>
70
+ </Show>
71
+ </HStack>
72
+ </Show>
73
+
74
+ <FieldErrorText>{fieldProps.errorText}</FieldErrorText>
75
+ </FieldRoot>
76
+ )
77
+ }
@@ -0,0 +1,5 @@
1
+ export * from './field'
2
+ export * from './primitives'
3
+ export * from './start-indicator'
4
+ export * from './status-indicator'
5
+ export * from './parts'
@@ -0,0 +1,77 @@
1
+ import type { ElementType } from 'react'
2
+ import {
3
+ FieldErrorText,
4
+ FieldHelperText,
5
+ FieldInput,
6
+ FieldLabel,
7
+ FieldRequiredIndicator,
8
+ FieldRoot,
9
+ FieldTextarea,
10
+ } from './primitives'
11
+ import { FieldStatusIndicator } from './status-indicator'
12
+ import { FieldStartIndicator } from './start-indicator'
13
+
14
+ /**
15
+ * This module contains the parts of the Field component.
16
+ * @module 'field/parts'
17
+ */
18
+
19
+ interface FieldPartsValue {
20
+ /**
21
+ * The container of the field.
22
+ */
23
+ Root: ElementType
24
+ /**
25
+ * The label of the field.
26
+ */
27
+ Label: ElementType
28
+ /**
29
+ * The input of the field.
30
+ */
31
+ Input: ElementType
32
+ /**
33
+ * The textarea of the field.
34
+ */
35
+ Textarea: ElementType
36
+ /**
37
+ * The text that displays when the field is valid.
38
+ */
39
+ HelperText: ElementType
40
+ /**
41
+ * The text that displays when the field is invalid.
42
+ */
43
+ ErrorText: ElementType
44
+ /**
45
+ * The indicator that appears at the start of the field.
46
+ */
47
+ StartIndicator: ElementType
48
+ /**
49
+ * The status indicator of the field.
50
+ */
51
+ StatusIndicator: ElementType
52
+ /**
53
+ * The indicator that appears at the end of the field.
54
+ */
55
+ RequiredIndicator: ElementType
56
+ }
57
+
58
+ /**
59
+ * An Object containing the parts of the Field component. For users that
60
+ * prefer Object component syntax.
61
+ *
62
+ * @remarks
63
+ *
64
+ * When using object component syntax, you import the FieldParts object and
65
+ * the entire family of components vs. only what you use.
66
+ */
67
+ export const FieldParts: FieldPartsValue = {
68
+ Root: FieldRoot,
69
+ Label: FieldLabel,
70
+ Input: FieldInput,
71
+ Textarea: FieldTextarea,
72
+ HelperText: FieldHelperText,
73
+ ErrorText: FieldErrorText,
74
+ StartIndicator: FieldStartIndicator,
75
+ StatusIndicator: FieldStatusIndicator,
76
+ RequiredIndicator: FieldRequiredIndicator,
77
+ }