boreal-ui 0.0.78 → 0.0.80

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 (213) hide show
  1. package/dist/core/{Breadcrumbs-B7hp9_u1.cjs → Breadcrumbs-B-I-UmIg.cjs} +1 -2
  2. package/dist/core/{Breadcrumbs-B7hp9_u1.cjs.map → Breadcrumbs-B-I-UmIg.cjs.map} +1 -1
  3. package/dist/core/{Breadcrumbs-kbOyaea6.js → Breadcrumbs-BwDAukNi.js} +1 -2
  4. package/dist/core/{Breadcrumbs-kbOyaea6.js.map → Breadcrumbs-BwDAukNi.js.map} +1 -1
  5. package/dist/core/Breadcrumbs.cjs.js +1 -1
  6. package/dist/core/Breadcrumbs.js +1 -1
  7. package/dist/core/{Card-C3kfPs8j.cjs → Card-B2gCUSuQ.cjs} +1 -2
  8. package/dist/core/{Card-C3kfPs8j.cjs.map → Card-B2gCUSuQ.cjs.map} +1 -1
  9. package/dist/core/{Card-CZY1qzwZ.js → Card-CnvOGnWI.js} +1 -2
  10. package/dist/core/{Card-CZY1qzwZ.js.map → Card-CnvOGnWI.js.map} +1 -1
  11. package/dist/core/Card.cjs.js +1 -1
  12. package/dist/core/Card.js +1 -1
  13. package/dist/core/{CommandPalette-BtpQ9cio.cjs → CommandPalette-BKd-BCUk.cjs} +2 -2
  14. package/dist/core/{CommandPalette-BtpQ9cio.cjs.map → CommandPalette-BKd-BCUk.cjs.map} +1 -1
  15. package/dist/core/{CommandPalette-0uVG4iR2.js → CommandPalette-C5XB2s4L.js} +2 -2
  16. package/dist/core/{CommandPalette-0uVG4iR2.js.map → CommandPalette-C5XB2s4L.js.map} +1 -1
  17. package/dist/core/CommandPalette.cjs.js +1 -1
  18. package/dist/core/CommandPalette.js +1 -1
  19. package/dist/core/{Dropdown-B7-_OH9p.cjs → Dropdown-DflOD92W.cjs} +1 -2
  20. package/dist/core/{Dropdown-B7-_OH9p.cjs.map → Dropdown-DflOD92W.cjs.map} +1 -1
  21. package/dist/core/{Dropdown-BEPGhf-i.js → Dropdown-fr7AR3nt.js} +1 -2
  22. package/dist/core/{Dropdown-BEPGhf-i.js.map → Dropdown-fr7AR3nt.js.map} +1 -1
  23. package/dist/core/Dropdown.cjs.js +1 -1
  24. package/dist/core/Dropdown.js +1 -1
  25. package/dist/core/{EmptyState-Du2xqi6G.cjs → EmptyState-BSVIrZHm.cjs} +1 -2
  26. package/dist/core/{EmptyState-Du2xqi6G.cjs.map → EmptyState-BSVIrZHm.cjs.map} +1 -1
  27. package/dist/core/{EmptyState-CM7nlKER.js → EmptyState-ClFhpjyo.js} +1 -2
  28. package/dist/core/{EmptyState-CM7nlKER.js.map → EmptyState-ClFhpjyo.js.map} +1 -1
  29. package/dist/core/EmptyState.cjs.js +1 -1
  30. package/dist/core/EmptyState.js +1 -1
  31. package/dist/core/{Footer-60sTURxB.cjs → Footer-CDcKfT68.cjs} +37 -37
  32. package/dist/core/Footer-CDcKfT68.cjs.map +1 -0
  33. package/dist/core/{Footer-Q_60pe6o.js → Footer-DaEqi5su.js} +38 -38
  34. package/dist/core/Footer-DaEqi5su.js.map +1 -0
  35. package/dist/core/Footer.cjs.js +1 -1
  36. package/dist/core/Footer.js +1 -1
  37. package/dist/core/{NotificationCenter-DA-WGPP9.js → NotificationCenter-B8e8mMb_.js} +1 -2
  38. package/dist/core/{NotificationCenter-DA-WGPP9.js.map → NotificationCenter-B8e8mMb_.js.map} +1 -1
  39. package/dist/core/{NotificationCenter-CsKJTZhk.cjs → NotificationCenter-Dg_F-nLl.cjs} +1 -2
  40. package/dist/core/{NotificationCenter-CsKJTZhk.cjs.map → NotificationCenter-Dg_F-nLl.cjs.map} +1 -1
  41. package/dist/core/NotificationCenter.cjs.js +1 -1
  42. package/dist/core/NotificationCenter.js +1 -1
  43. package/dist/core/{Pager-B4hyIUdo.js → Pager-BH8hdkMS.js} +1 -2
  44. package/dist/core/{Pager-B4hyIUdo.js.map → Pager-BH8hdkMS.js.map} +1 -1
  45. package/dist/core/{Pager-wl7_umU4.cjs → Pager-BXAAjmIk.cjs} +1 -2
  46. package/dist/core/{Pager-wl7_umU4.cjs.map → Pager-BXAAjmIk.cjs.map} +1 -1
  47. package/dist/core/Pager.cjs.js +1 -1
  48. package/dist/core/Pager.js +1 -1
  49. package/dist/core/{Stepper-CQRJID19.cjs → Stepper-BImUKM9h.cjs} +1 -2
  50. package/dist/core/{Stepper-CQRJID19.cjs.map → Stepper-BImUKM9h.cjs.map} +1 -1
  51. package/dist/core/{Stepper-CLfy0_gZ.js → Stepper-DRCnDvvv.js} +1 -2
  52. package/dist/core/{Stepper-CLfy0_gZ.js.map → Stepper-DRCnDvvv.js.map} +1 -1
  53. package/dist/core/Stepper.cjs.js +1 -1
  54. package/dist/core/Stepper.js +1 -1
  55. package/dist/core/{TagInput-YieWARAt.js → TagInput-BO0Br1nf.js} +2 -2
  56. package/dist/core/{TagInput-YieWARAt.js.map → TagInput-BO0Br1nf.js.map} +1 -1
  57. package/dist/core/{TagInput-pWRdhaP3.cjs → TagInput-CpJ--Wzp.cjs} +2 -2
  58. package/dist/core/{TagInput-pWRdhaP3.cjs.map → TagInput-CpJ--Wzp.cjs.map} +1 -1
  59. package/dist/core/TagInput.cjs.js +1 -1
  60. package/dist/core/TagInput.js +1 -1
  61. package/dist/core/{TextInput-Bc2YpcvM.js → TextInput-CXyzklAm.js} +1 -2
  62. package/dist/core/{TextInput-Bc2YpcvM.js.map → TextInput-CXyzklAm.js.map} +1 -1
  63. package/dist/core/{TextInput-DbAsQxjr.cjs → TextInput-xBrLtn_h.cjs} +1 -2
  64. package/dist/core/{TextInput-DbAsQxjr.cjs.map → TextInput-xBrLtn_h.cjs.map} +1 -1
  65. package/dist/core/TextInput.cjs.js +1 -1
  66. package/dist/core/TextInput.js +1 -1
  67. package/dist/core/boreal-ui.css +1137 -1137
  68. package/dist/core/index.cjs.js +11 -12
  69. package/dist/core/index.cjs.js.map +1 -1
  70. package/dist/core/index.js +11 -12
  71. package/dist/core/index.js.map +1 -1
  72. package/dist/next/{Breadcrumbs-eetAtAHU.js → Breadcrumbs-BEDmdhgu.js} +2 -3
  73. package/dist/next/{Breadcrumbs-eetAtAHU.js.map → Breadcrumbs-BEDmdhgu.js.map} +1 -1
  74. package/dist/next/{Breadcrumbs-33eZmvpJ.cjs → Breadcrumbs-CMOeEih6.cjs} +2 -3
  75. package/dist/next/{Breadcrumbs-33eZmvpJ.cjs.map → Breadcrumbs-CMOeEih6.cjs.map} +1 -1
  76. package/dist/next/Breadcrumbs.cjs.js +1 -1
  77. package/dist/next/Breadcrumbs.js +1 -1
  78. package/dist/next/{Card-CO--D_GK.js → Card-C4l2NTBd.js} +2 -3
  79. package/dist/next/{Card-CO--D_GK.js.map → Card-C4l2NTBd.js.map} +1 -1
  80. package/dist/next/{Card-o8DszZPj.cjs → Card-DcQ0V83P.cjs} +2 -3
  81. package/dist/next/{Card-o8DszZPj.cjs.map → Card-DcQ0V83P.cjs.map} +1 -1
  82. package/dist/next/Card.cjs.js +1 -1
  83. package/dist/next/Card.js +1 -1
  84. package/dist/next/CheckBox.cjs.js +1 -1
  85. package/dist/next/CheckBox.js +1 -1
  86. package/dist/next/{Checkbox-KIXViPTB.js → Checkbox-D6Msnkyl.js} +75 -75
  87. package/dist/next/{Checkbox-KIXViPTB.js.map → Checkbox-D6Msnkyl.js.map} +1 -1
  88. package/dist/next/{Checkbox-UqOL3aqk.cjs → Checkbox-IK6dY7ED.cjs} +74 -74
  89. package/dist/next/{Checkbox-UqOL3aqk.cjs.map → Checkbox-IK6dY7ED.cjs.map} +1 -1
  90. package/dist/next/{Chip-D-QH1huh.js → Chip-BweeZwb7.js} +84 -85
  91. package/dist/next/{Chip-D-QH1huh.js.map → Chip-BweeZwb7.js.map} +1 -1
  92. package/dist/next/{Chip-BQv3NoJL.cjs → Chip-DNyF7UUP.cjs} +85 -86
  93. package/dist/next/{Chip-BQv3NoJL.cjs.map → Chip-DNyF7UUP.cjs.map} +1 -1
  94. package/dist/next/Chip.cjs.js +1 -1
  95. package/dist/next/Chip.js +1 -1
  96. package/dist/next/{CircularProgress-BG83Q-uO.cjs → CircularProgress-0bh-uYuv.cjs} +58 -58
  97. package/dist/next/{CircularProgress-BG83Q-uO.cjs.map → CircularProgress-0bh-uYuv.cjs.map} +1 -1
  98. package/dist/next/{CircularProgress-Bfanw-2S.js → CircularProgress-BHOMzVmz.js} +59 -59
  99. package/dist/next/{CircularProgress-Bfanw-2S.js.map → CircularProgress-BHOMzVmz.js.map} +1 -1
  100. package/dist/next/CircularProgress.cjs.js +1 -1
  101. package/dist/next/CircularProgress.js +1 -1
  102. package/dist/next/{ColorPicker-BJfyM0Ay.js → ColorPicker-BhDo-h8k.js} +50 -50
  103. package/dist/next/{ColorPicker-BJfyM0Ay.js.map → ColorPicker-BhDo-h8k.js.map} +1 -1
  104. package/dist/next/{ColorPicker-DmubVH4p.cjs → ColorPicker-DlyqseYs.cjs} +49 -49
  105. package/dist/next/{ColorPicker-DmubVH4p.cjs.map → ColorPicker-DlyqseYs.cjs.map} +1 -1
  106. package/dist/next/ColorPicker.cjs.js +1 -1
  107. package/dist/next/ColorPicker.js +1 -1
  108. package/dist/next/{CommandPalette-CNaU5jTY.js → CommandPalette-BAgsEdVA.js} +67 -68
  109. package/dist/next/{CommandPalette-CNaU5jTY.js.map → CommandPalette-BAgsEdVA.js.map} +1 -1
  110. package/dist/next/{CommandPalette-_Lpb0UOI.cjs → CommandPalette-CNs6UpbZ.cjs} +68 -69
  111. package/dist/next/{CommandPalette-_Lpb0UOI.cjs.map → CommandPalette-CNs6UpbZ.cjs.map} +1 -1
  112. package/dist/next/CommandPalette.cjs.js +1 -1
  113. package/dist/next/CommandPalette.js +1 -1
  114. package/dist/next/{DateTimePicker-WVVLqcd9.js → DateTimePicker-D2thRuf1.js} +65 -65
  115. package/dist/next/{DateTimePicker-WVVLqcd9.js.map → DateTimePicker-D2thRuf1.js.map} +1 -1
  116. package/dist/next/{DateTimePicker-CU-b9irX.cjs → DateTimePicker-Dp0y3k4y.cjs} +65 -65
  117. package/dist/next/{DateTimePicker-CU-b9irX.cjs.map → DateTimePicker-Dp0y3k4y.cjs.map} +1 -1
  118. package/dist/next/DateTimePicker.cjs.js +1 -1
  119. package/dist/next/DateTimePicker.js +1 -1
  120. package/dist/next/{Divider-BXSDTRTU.js → Divider-C41EKGIw.js} +30 -30
  121. package/dist/next/{Divider-BXSDTRTU.js.map → Divider-C41EKGIw.js.map} +1 -1
  122. package/dist/next/{Divider-BGxUapmt.cjs → Divider-CVOkAhn6.cjs} +29 -29
  123. package/dist/next/{Divider-BGxUapmt.cjs.map → Divider-CVOkAhn6.cjs.map} +1 -1
  124. package/dist/next/Divider.cjs.js +1 -1
  125. package/dist/next/Divider.js +1 -1
  126. package/dist/next/{Dropdown-CUYItZDk.cjs → Dropdown-BYmta_HY.cjs} +42 -43
  127. package/dist/next/{Dropdown-CUYItZDk.cjs.map → Dropdown-BYmta_HY.cjs.map} +1 -1
  128. package/dist/next/{Dropdown-B7vrHg0z.js → Dropdown-DavPqfaS.js} +41 -42
  129. package/dist/next/{Dropdown-B7vrHg0z.js.map → Dropdown-DavPqfaS.js.map} +1 -1
  130. package/dist/next/Dropdown.cjs.js +1 -1
  131. package/dist/next/Dropdown.js +1 -1
  132. package/dist/next/{EmptyState-MT9_qwrB.js → EmptyState-CiTGvH-L.js} +72 -73
  133. package/dist/next/{EmptyState-MT9_qwrB.js.map → EmptyState-CiTGvH-L.js.map} +1 -1
  134. package/dist/next/{EmptyState-sh7Vn6eC.cjs → EmptyState-kAjC_DXY.cjs} +73 -74
  135. package/dist/next/{EmptyState-sh7Vn6eC.cjs.map → EmptyState-kAjC_DXY.cjs.map} +1 -1
  136. package/dist/next/EmptyState.cjs.js +1 -1
  137. package/dist/next/EmptyState.js +1 -1
  138. package/dist/next/{FileUpload-Bvj5JEBv.js → FileUpload-HiZuJjoA.js} +82 -83
  139. package/dist/next/{FileUpload-Bvj5JEBv.js.map → FileUpload-HiZuJjoA.js.map} +1 -1
  140. package/dist/next/{FileUpload-CD_i5Md2.cjs → FileUpload-qzSlXJzW.cjs} +82 -83
  141. package/dist/next/{FileUpload-CD_i5Md2.cjs.map → FileUpload-qzSlXJzW.cjs.map} +1 -1
  142. package/dist/next/FileUpload.cjs.js +1 -1
  143. package/dist/next/FileUpload.js +1 -1
  144. package/dist/next/{Footer-Bdu_9H3p.js → Footer-BVic2clD.js} +103 -103
  145. package/dist/next/Footer-BVic2clD.js.map +1 -0
  146. package/dist/next/{Footer-DJjzgwpc.cjs → Footer-lEKbmF3y.cjs} +103 -103
  147. package/dist/next/Footer-lEKbmF3y.cjs.map +1 -0
  148. package/dist/next/Footer.cjs.js +1 -1
  149. package/dist/next/Footer.js +1 -1
  150. package/dist/next/{MessagePopup-DLodDCIa.js → MessagePopup-BAvnVw84.js} +2 -3
  151. package/dist/next/{MessagePopup-DLodDCIa.js.map → MessagePopup-BAvnVw84.js.map} +1 -1
  152. package/dist/next/{MessagePopup-CizqwWmH.cjs → MessagePopup-CixIzgoc.cjs} +2 -3
  153. package/dist/next/{MessagePopup-CizqwWmH.cjs.map → MessagePopup-CixIzgoc.cjs.map} +1 -1
  154. package/dist/next/MessagePopup.cjs.js +1 -1
  155. package/dist/next/MessagePopup.js +1 -1
  156. package/dist/next/{Modal-BajWiIo7.js → Modal-5Reb9Rx-.js} +2 -3
  157. package/dist/next/{Modal-BajWiIo7.js.map → Modal-5Reb9Rx-.js.map} +1 -1
  158. package/dist/next/{Modal-j59Cj0t1.cjs → Modal-DfVyL8yk.cjs} +2 -3
  159. package/dist/next/{Modal-j59Cj0t1.cjs.map → Modal-DfVyL8yk.cjs.map} +1 -1
  160. package/dist/next/Modal.cjs.js +1 -1
  161. package/dist/next/Modal.js +1 -1
  162. package/dist/next/{NotificationCenter-obd1jF2n.cjs → NotificationCenter-BcEB_4HS.cjs} +2 -3
  163. package/dist/next/{NotificationCenter-obd1jF2n.cjs.map → NotificationCenter-BcEB_4HS.cjs.map} +1 -1
  164. package/dist/next/{NotificationCenter-BDd4Zr8Y.js → NotificationCenter-DvoC0SI9.js} +2 -3
  165. package/dist/next/{NotificationCenter-BDd4Zr8Y.js.map → NotificationCenter-DvoC0SI9.js.map} +1 -1
  166. package/dist/next/NotificationCenter.cjs.js +1 -1
  167. package/dist/next/NotificationCenter.js +1 -1
  168. package/dist/next/{Pager-8dIVqCGz.cjs → Pager-BZLZA8KD.cjs} +2 -3
  169. package/dist/next/{Pager-8dIVqCGz.cjs.map → Pager-BZLZA8KD.cjs.map} +1 -1
  170. package/dist/next/{Pager-C7n5x44P.js → Pager-D11plHRn.js} +2 -3
  171. package/dist/next/{Pager-C7n5x44P.js.map → Pager-D11plHRn.js.map} +1 -1
  172. package/dist/next/Pager.cjs.js +1 -1
  173. package/dist/next/Pager.js +1 -1
  174. package/dist/next/{Stepper-em6Gl32O.js → Stepper-B2X72Iir.js} +2 -3
  175. package/dist/next/{Stepper-em6Gl32O.js.map → Stepper-B2X72Iir.js.map} +1 -1
  176. package/dist/next/{Stepper-CpgJBKz7.cjs → Stepper-fE7prDWu.cjs} +2 -3
  177. package/dist/next/{Stepper-CpgJBKz7.cjs.map → Stepper-fE7prDWu.cjs.map} +1 -1
  178. package/dist/next/Stepper.cjs.js +1 -1
  179. package/dist/next/Stepper.js +1 -1
  180. package/dist/next/{TagInput-DVmBv7Mn.cjs → TagInput-BycAVBEu.cjs} +3 -4
  181. package/dist/next/{TagInput-DVmBv7Mn.cjs.map → TagInput-BycAVBEu.cjs.map} +1 -1
  182. package/dist/next/{TagInput-8nVGDluu.js → TagInput-CabR-drk.js} +3 -4
  183. package/dist/next/{TagInput-8nVGDluu.js.map → TagInput-CabR-drk.js.map} +1 -1
  184. package/dist/next/TagInput.cjs.js +1 -1
  185. package/dist/next/TagInput.js +1 -1
  186. package/dist/next/{TextInput-CKM34-yu.js → TextInput-B4s9TMoa.js} +2 -3
  187. package/dist/next/{TextInput-CKM34-yu.js.map → TextInput-B4s9TMoa.js.map} +1 -1
  188. package/dist/next/{TextInput-BRl37zMW.cjs → TextInput-SqTFFVZ8.cjs} +2 -3
  189. package/dist/next/{TextInput-BRl37zMW.cjs.map → TextInput-SqTFFVZ8.cjs.map} +1 -1
  190. package/dist/next/TextInput.cjs.js +1 -1
  191. package/dist/next/TextInput.js +1 -1
  192. package/dist/next/globals.cjs.js +2 -0
  193. package/dist/next/globals.cjs.js.map +1 -0
  194. package/dist/next/globals.js +2 -0
  195. package/dist/next/globals.js.map +1 -0
  196. package/dist/next/index.cjs.js +22 -22
  197. package/dist/next/index.js +22 -22
  198. package/dist/tsconfig.build.tsbuildinfo +1 -1
  199. package/dist/types/components/Card/core/Card.d.ts.map +1 -1
  200. package/dist/types/components/Card/next/Card.d.ts.map +1 -1
  201. package/dist/types/components/FileUpload/next/FileUpload.d.ts.map +1 -1
  202. package/dist/types/components/Footer/next/Footer.d.ts.map +1 -1
  203. package/dist/types/components/MessagePopup/next/MessagePopup.d.ts.map +1 -1
  204. package/dist/types/components/NotificationCenter/core/NotificationCenter.d.ts.map +1 -1
  205. package/dist/types/components/NotificationCenter/next/NotificationCenter.d.ts.map +1 -1
  206. package/dist/types/components/Pager/core/Pager.d.ts.map +1 -1
  207. package/dist/types/components/Pager/next/Pager.d.ts.map +1 -1
  208. package/dist/types/components/TagInput/next/TagInput.d.ts.map +1 -1
  209. package/package.json +1 -1
  210. package/dist/core/Footer-60sTURxB.cjs.map +0 -1
  211. package/dist/core/Footer-Q_60pe6o.js.map +0 -1
  212. package/dist/next/Footer-Bdu_9H3p.js.map +0 -1
  213. package/dist/next/Footer-DJjzgwpc.cjs.map +0 -1
@@ -3,7 +3,55 @@ import { useMemo } from "react";
3
3
  import { c as combineClassNames } from "./classNames-AS8QjFq7.js";
4
4
  import { c as capitalize } from "./capitalize-C0TSQSPh.js";
5
5
  import { c as getDefaultSize, b as getDefaultShadow } from "./boreal-style-config-DsaRlxmw.js";
6
- import './ColorPicker.css';const ColorPickerBase = ({
6
+ import './ColorPicker.css';const color_picker = "_color_picker_fynon_85";
7
+ const legend = "_legend_fynon_115";
8
+ const grid = "_grid_fynon_134";
9
+ const selected = "_selected_fynon_150";
10
+ const swatch = "_swatch_fynon_156";
11
+ const round = "_round_fynon_173";
12
+ const square = "_square_fynon_176";
13
+ const pill = "_pill_fynon_179";
14
+ const xs = "_xs_fynon_183";
15
+ const small = "_small_fynon_199";
16
+ const medium = "_medium_fynon_215";
17
+ const large = "_large_fynon_231";
18
+ const xl = "_xl_fynon_247";
19
+ const radio_input = "_radio_input_fynon_264";
20
+ const preview = "_preview_fynon_268";
21
+ const custom_input = "_custom_input_fynon_276";
22
+ const circle = "_circle_fynon_291";
23
+ const rounded = "_rounded_fynon_299";
24
+ const shadowNone = "_shadowNone_fynon_303";
25
+ const shadowLight = "_shadowLight_fynon_307";
26
+ const shadowMedium = "_shadowMedium_fynon_311";
27
+ const shadowStrong = "_shadowStrong_fynon_315";
28
+ const shadowIntense = "_shadowIntense_fynon_319";
29
+ const styles = {
30
+ color_picker,
31
+ legend,
32
+ grid,
33
+ selected,
34
+ swatch,
35
+ round,
36
+ square,
37
+ pill,
38
+ xs,
39
+ small,
40
+ medium,
41
+ large,
42
+ xl,
43
+ radio_input,
44
+ preview,
45
+ custom_input,
46
+ circle,
47
+ rounded,
48
+ shadowNone,
49
+ shadowLight,
50
+ shadowMedium,
51
+ shadowStrong,
52
+ shadowIntense
53
+ };
54
+ const ColorPickerBase = ({
7
55
  label = "Choose a color",
8
56
  colors,
9
57
  selected: selected2,
@@ -156,57 +204,9 @@ import './ColorPicker.css';const ColorPickerBase = ({
156
204
  );
157
205
  };
158
206
  ColorPickerBase.displayName = "ColorPickerBase";
159
- const color_picker = "_color_picker_fynon_85";
160
- const legend = "_legend_fynon_115";
161
- const grid = "_grid_fynon_134";
162
- const selected = "_selected_fynon_150";
163
- const swatch = "_swatch_fynon_156";
164
- const round = "_round_fynon_173";
165
- const square = "_square_fynon_176";
166
- const pill = "_pill_fynon_179";
167
- const xs = "_xs_fynon_183";
168
- const small = "_small_fynon_199";
169
- const medium = "_medium_fynon_215";
170
- const large = "_large_fynon_231";
171
- const xl = "_xl_fynon_247";
172
- const radio_input = "_radio_input_fynon_264";
173
- const preview = "_preview_fynon_268";
174
- const custom_input = "_custom_input_fynon_276";
175
- const circle = "_circle_fynon_291";
176
- const rounded = "_rounded_fynon_299";
177
- const shadowNone = "_shadowNone_fynon_303";
178
- const shadowLight = "_shadowLight_fynon_307";
179
- const shadowMedium = "_shadowMedium_fynon_311";
180
- const shadowStrong = "_shadowStrong_fynon_315";
181
- const shadowIntense = "_shadowIntense_fynon_319";
182
- const styles = {
183
- color_picker,
184
- legend,
185
- grid,
186
- selected,
187
- swatch,
188
- round,
189
- square,
190
- pill,
191
- xs,
192
- small,
193
- medium,
194
- large,
195
- xl,
196
- radio_input,
197
- preview,
198
- custom_input,
199
- circle,
200
- rounded,
201
- shadowNone,
202
- shadowLight,
203
- shadowMedium,
204
- shadowStrong,
205
- shadowIntense
206
- };
207
207
  const ColorPicker = (props) => /* @__PURE__ */ jsx(ColorPickerBase, { ...props, classMap: styles });
208
208
  ColorPicker.displayName = "ColorPicker";
209
209
  export {
210
210
  ColorPicker as C
211
211
  };
212
- //# sourceMappingURL=ColorPicker-BJfyM0Ay.js.map
212
+ //# sourceMappingURL=ColorPicker-BhDo-h8k.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ColorPicker-BJfyM0Ay.js","sources":["../../src/components/ColorPicker/ColorPickerBase.tsx","../../src/components/ColorPicker/next/ColorPicker.tsx"],"sourcesContent":["import React, { useMemo } from \"react\";\r\nimport { combineClassNames } from \"../../utils/classNames\";\r\nimport type { ColorPickerBaseProps } from \"./ColorPicker.types\";\r\nimport { capitalize } from \"../../utils/capitalize\";\r\nimport {\r\n getDefaultShadow,\r\n getDefaultSize,\r\n} from \"../../config/boreal-style-config\";\r\n\r\nconst ColorPickerBase: React.FC<ColorPickerBaseProps> = ({\r\n label = \"Choose a color\",\r\n colors,\r\n selected,\r\n onChange,\r\n name = \"color-picker\",\r\n disabled = false,\r\n size = getDefaultSize(),\r\n shadow = getDefaultShadow(),\r\n shape = \"round\",\r\n allowCustom = false,\r\n required = false,\r\n invalid = false,\r\n helperText,\r\n errorText,\r\n customInputAriaLabel = \"Custom color picker\",\r\n hideLabel = false,\r\n className = \"\",\r\n classMap,\r\n \"aria-label\": ariaLabel,\r\n \"aria-labelledby\": ariaLabelledBy,\r\n \"aria-describedby\": ariaDescribedBy,\r\n \"data-testid\": testId = \"color-picker\",\r\n}) => {\r\n const legendId = `${testId}-legend`;\r\n const helperTextId = helperText ? `${testId}-helper-text` : undefined;\r\n const errorTextId = errorText ? `${testId}-error-text` : undefined;\r\n\r\n const describedBy =\r\n [ariaDescribedBy, helperTextId, invalid ? errorTextId : undefined]\r\n .filter(Boolean)\r\n .join(\" \") || undefined;\r\n\r\n const computedAriaLabelledBy =\r\n ariaLabelledBy ?? (!ariaLabel ? legendId : undefined);\r\n\r\n const labelClass = useMemo(\r\n () =>\r\n combineClassNames(\r\n classMap.swatch,\r\n classMap[size],\r\n classMap[shape],\r\n disabled && classMap.disabled,\r\n ),\r\n [classMap, size, shape, disabled],\r\n );\r\n\r\n return (\r\n <fieldset\r\n className={combineClassNames(\r\n classMap.color_picker,\r\n invalid && classMap.invalid,\r\n disabled && classMap.disabled,\r\n className,\r\n )}\r\n disabled={disabled}\r\n data-testid={testId}\r\n aria-label={ariaLabel}\r\n aria-labelledby={computedAriaLabelledBy}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n >\r\n <legend\r\n id={legendId}\r\n className={combineClassNames(classMap.legend, hideLabel && \"sr_only\")}\r\n >\r\n {label}\r\n </legend>\r\n\r\n <div className={classMap.color_picker_grid} role=\"radiogroup\">\r\n {colors.map((color, i) => {\r\n const id = `${testId}-color-${i}`;\r\n const optionLabelId = `${id}-label`;\r\n const isSelected = selected === color.value;\r\n const optionDisabled = disabled || color.disabled;\r\n\r\n return (\r\n <label\r\n key={`${color.value}-${i}`}\r\n className={combineClassNames(\r\n labelClass,\r\n optionDisabled && classMap.disabled,\r\n )}\r\n htmlFor={id}\r\n title={color.label}\r\n data-testid={`${testId}-option-${color.value}`}\r\n >\r\n <input\r\n type=\"radio\"\r\n name={name}\r\n id={id}\r\n value={color.value}\r\n checked={isSelected}\r\n onChange={() => onChange(color.value)}\r\n className={classMap.radio_input}\r\n disabled={optionDisabled}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n aria-required={required || undefined}\r\n aria-labelledby={optionLabelId}\r\n />\r\n\r\n <span id={optionLabelId} className={\"sr_only\"}>\r\n {color.label}\r\n </span>\r\n\r\n <span\r\n className={combineClassNames(\r\n classMap.preview,\r\n classMap[shape],\r\n isSelected && classMap.selected,\r\n optionDisabled && classMap.disabled,\r\n shadow && classMap[`shadow${capitalize(shadow)}`],\r\n )}\r\n style={{ backgroundColor: color.value }}\r\n aria-hidden=\"true\"\r\n />\r\n </label>\r\n );\r\n })}\r\n </div>\r\n\r\n {helperText && (\r\n <div\r\n id={helperTextId}\r\n className={classMap.helper_text}\r\n data-testid={`${testId}-helper-text`}\r\n >\r\n {helperText}\r\n </div>\r\n )}\r\n\r\n {invalid && errorText && (\r\n <div\r\n id={errorTextId}\r\n className={classMap.error_text}\r\n data-testid={`${testId}-error-text`}\r\n aria-live=\"polite\"\r\n >\r\n {errorText}\r\n </div>\r\n )}\r\n\r\n {allowCustom && (\r\n <input\r\n type=\"color\"\r\n className={classMap.custom_input}\r\n value={selected}\r\n onChange={(e) => onChange(e.target.value)}\r\n aria-label={customInputAriaLabel}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n data-testid={`${testId}-custom-input`}\r\n disabled={disabled}\r\n />\r\n )}\r\n </fieldset>\r\n );\r\n};\r\n\r\nColorPickerBase.displayName = \"ColorPickerBase\";\r\nexport default ColorPickerBase;\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\nimport ColorPickerBase from \"../ColorPickerBase\";\r\nimport styles from \"./ColorPicker.module.scss\";\r\nimport { ColorPickerProps } from \"../ColorPicker.types\";\r\n\r\nconst ColorPicker: React.FC<ColorPickerProps> = (props) => (\r\n <ColorPickerBase {...props} classMap={styles} />\r\n);\r\nColorPicker.displayName = \"ColorPicker\";\r\nexport default ColorPicker;\r\n"],"names":["selected"],"mappings":"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"}
1
+ {"version":3,"file":"ColorPicker-BhDo-h8k.js","sources":["../../src/components/ColorPicker/ColorPickerBase.tsx","../../src/components/ColorPicker/next/ColorPicker.tsx"],"sourcesContent":["import React, { useMemo } from \"react\";\r\nimport { combineClassNames } from \"../../utils/classNames\";\r\nimport type { ColorPickerBaseProps } from \"./ColorPicker.types\";\r\nimport { capitalize } from \"../../utils/capitalize\";\r\nimport {\r\n getDefaultShadow,\r\n getDefaultSize,\r\n} from \"../../config/boreal-style-config\";\r\n\r\nconst ColorPickerBase: React.FC<ColorPickerBaseProps> = ({\r\n label = \"Choose a color\",\r\n colors,\r\n selected,\r\n onChange,\r\n name = \"color-picker\",\r\n disabled = false,\r\n size = getDefaultSize(),\r\n shadow = getDefaultShadow(),\r\n shape = \"round\",\r\n allowCustom = false,\r\n required = false,\r\n invalid = false,\r\n helperText,\r\n errorText,\r\n customInputAriaLabel = \"Custom color picker\",\r\n hideLabel = false,\r\n className = \"\",\r\n classMap,\r\n \"aria-label\": ariaLabel,\r\n \"aria-labelledby\": ariaLabelledBy,\r\n \"aria-describedby\": ariaDescribedBy,\r\n \"data-testid\": testId = \"color-picker\",\r\n}) => {\r\n const legendId = `${testId}-legend`;\r\n const helperTextId = helperText ? `${testId}-helper-text` : undefined;\r\n const errorTextId = errorText ? `${testId}-error-text` : undefined;\r\n\r\n const describedBy =\r\n [ariaDescribedBy, helperTextId, invalid ? errorTextId : undefined]\r\n .filter(Boolean)\r\n .join(\" \") || undefined;\r\n\r\n const computedAriaLabelledBy =\r\n ariaLabelledBy ?? (!ariaLabel ? legendId : undefined);\r\n\r\n const labelClass = useMemo(\r\n () =>\r\n combineClassNames(\r\n classMap.swatch,\r\n classMap[size],\r\n classMap[shape],\r\n disabled && classMap.disabled,\r\n ),\r\n [classMap, size, shape, disabled],\r\n );\r\n\r\n return (\r\n <fieldset\r\n className={combineClassNames(\r\n classMap.color_picker,\r\n invalid && classMap.invalid,\r\n disabled && classMap.disabled,\r\n className,\r\n )}\r\n disabled={disabled}\r\n data-testid={testId}\r\n aria-label={ariaLabel}\r\n aria-labelledby={computedAriaLabelledBy}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n >\r\n <legend\r\n id={legendId}\r\n className={combineClassNames(classMap.legend, hideLabel && \"sr_only\")}\r\n >\r\n {label}\r\n </legend>\r\n\r\n <div className={classMap.color_picker_grid} role=\"radiogroup\">\r\n {colors.map((color, i) => {\r\n const id = `${testId}-color-${i}`;\r\n const optionLabelId = `${id}-label`;\r\n const isSelected = selected === color.value;\r\n const optionDisabled = disabled || color.disabled;\r\n\r\n return (\r\n <label\r\n key={`${color.value}-${i}`}\r\n className={combineClassNames(\r\n labelClass,\r\n optionDisabled && classMap.disabled,\r\n )}\r\n htmlFor={id}\r\n title={color.label}\r\n data-testid={`${testId}-option-${color.value}`}\r\n >\r\n <input\r\n type=\"radio\"\r\n name={name}\r\n id={id}\r\n value={color.value}\r\n checked={isSelected}\r\n onChange={() => onChange(color.value)}\r\n className={classMap.radio_input}\r\n disabled={optionDisabled}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n aria-required={required || undefined}\r\n aria-labelledby={optionLabelId}\r\n />\r\n\r\n <span id={optionLabelId} className={\"sr_only\"}>\r\n {color.label}\r\n </span>\r\n\r\n <span\r\n className={combineClassNames(\r\n classMap.preview,\r\n classMap[shape],\r\n isSelected && classMap.selected,\r\n optionDisabled && classMap.disabled,\r\n shadow && classMap[`shadow${capitalize(shadow)}`],\r\n )}\r\n style={{ backgroundColor: color.value }}\r\n aria-hidden=\"true\"\r\n />\r\n </label>\r\n );\r\n })}\r\n </div>\r\n\r\n {helperText && (\r\n <div\r\n id={helperTextId}\r\n className={classMap.helper_text}\r\n data-testid={`${testId}-helper-text`}\r\n >\r\n {helperText}\r\n </div>\r\n )}\r\n\r\n {invalid && errorText && (\r\n <div\r\n id={errorTextId}\r\n className={classMap.error_text}\r\n data-testid={`${testId}-error-text`}\r\n aria-live=\"polite\"\r\n >\r\n {errorText}\r\n </div>\r\n )}\r\n\r\n {allowCustom && (\r\n <input\r\n type=\"color\"\r\n className={classMap.custom_input}\r\n value={selected}\r\n onChange={(e) => onChange(e.target.value)}\r\n aria-label={customInputAriaLabel}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n data-testid={`${testId}-custom-input`}\r\n disabled={disabled}\r\n />\r\n )}\r\n </fieldset>\r\n );\r\n};\r\n\r\nColorPickerBase.displayName = \"ColorPickerBase\";\r\nexport default ColorPickerBase;\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\nimport ColorPickerBase from \"../ColorPickerBase\";\r\nimport styles from \"./ColorPicker.module.scss\";\r\nimport { ColorPickerProps } from \"../ColorPicker.types\";\r\n\r\nconst ColorPicker: React.FC<ColorPickerProps> = (props) => (\r\n <ColorPickerBase {...props} classMap={styles} />\r\n);\r\nColorPicker.displayName = \"ColorPicker\";\r\nexport default ColorPicker;\r\n"],"names":["selected"],"mappings":"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"}
@@ -4,6 +4,54 @@ const React = require("react");
4
4
  const classNames = require("./classNames-BcWMx052.cjs");
5
5
  const capitalize = require("./capitalize-DoV-nOmN.cjs");
6
6
  const borealStyleConfig = require("./boreal-style-config-C1UIwOFN.cjs");
7
+ const color_picker = "_color_picker_fynon_85";
8
+ const legend = "_legend_fynon_115";
9
+ const grid = "_grid_fynon_134";
10
+ const selected = "_selected_fynon_150";
11
+ const swatch = "_swatch_fynon_156";
12
+ const round = "_round_fynon_173";
13
+ const square = "_square_fynon_176";
14
+ const pill = "_pill_fynon_179";
15
+ const xs = "_xs_fynon_183";
16
+ const small = "_small_fynon_199";
17
+ const medium = "_medium_fynon_215";
18
+ const large = "_large_fynon_231";
19
+ const xl = "_xl_fynon_247";
20
+ const radio_input = "_radio_input_fynon_264";
21
+ const preview = "_preview_fynon_268";
22
+ const custom_input = "_custom_input_fynon_276";
23
+ const circle = "_circle_fynon_291";
24
+ const rounded = "_rounded_fynon_299";
25
+ const shadowNone = "_shadowNone_fynon_303";
26
+ const shadowLight = "_shadowLight_fynon_307";
27
+ const shadowMedium = "_shadowMedium_fynon_311";
28
+ const shadowStrong = "_shadowStrong_fynon_315";
29
+ const shadowIntense = "_shadowIntense_fynon_319";
30
+ const styles = {
31
+ color_picker,
32
+ legend,
33
+ grid,
34
+ selected,
35
+ swatch,
36
+ round,
37
+ square,
38
+ pill,
39
+ xs,
40
+ small,
41
+ medium,
42
+ large,
43
+ xl,
44
+ radio_input,
45
+ preview,
46
+ custom_input,
47
+ circle,
48
+ rounded,
49
+ shadowNone,
50
+ shadowLight,
51
+ shadowMedium,
52
+ shadowStrong,
53
+ shadowIntense
54
+ };
7
55
  const ColorPickerBase = ({
8
56
  label = "Choose a color",
9
57
  colors,
@@ -157,55 +205,7 @@ const ColorPickerBase = ({
157
205
  );
158
206
  };
159
207
  ColorPickerBase.displayName = "ColorPickerBase";
160
- const color_picker = "_color_picker_fynon_85";
161
- const legend = "_legend_fynon_115";
162
- const grid = "_grid_fynon_134";
163
- const selected = "_selected_fynon_150";
164
- const swatch = "_swatch_fynon_156";
165
- const round = "_round_fynon_173";
166
- const square = "_square_fynon_176";
167
- const pill = "_pill_fynon_179";
168
- const xs = "_xs_fynon_183";
169
- const small = "_small_fynon_199";
170
- const medium = "_medium_fynon_215";
171
- const large = "_large_fynon_231";
172
- const xl = "_xl_fynon_247";
173
- const radio_input = "_radio_input_fynon_264";
174
- const preview = "_preview_fynon_268";
175
- const custom_input = "_custom_input_fynon_276";
176
- const circle = "_circle_fynon_291";
177
- const rounded = "_rounded_fynon_299";
178
- const shadowNone = "_shadowNone_fynon_303";
179
- const shadowLight = "_shadowLight_fynon_307";
180
- const shadowMedium = "_shadowMedium_fynon_311";
181
- const shadowStrong = "_shadowStrong_fynon_315";
182
- const shadowIntense = "_shadowIntense_fynon_319";
183
- const styles = {
184
- color_picker,
185
- legend,
186
- grid,
187
- selected,
188
- swatch,
189
- round,
190
- square,
191
- pill,
192
- xs,
193
- small,
194
- medium,
195
- large,
196
- xl,
197
- radio_input,
198
- preview,
199
- custom_input,
200
- circle,
201
- rounded,
202
- shadowNone,
203
- shadowLight,
204
- shadowMedium,
205
- shadowStrong,
206
- shadowIntense
207
- };
208
208
  const ColorPicker = (props) => /* @__PURE__ */ require$$2.jsx(ColorPickerBase, { ...props, classMap: styles });
209
209
  ColorPicker.displayName = "ColorPicker";
210
210
  exports.ColorPicker = ColorPicker;
211
- //# sourceMappingURL=ColorPicker-DmubVH4p.cjs.map
211
+ //# sourceMappingURL=ColorPicker-DlyqseYs.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"ColorPicker-DmubVH4p.cjs","sources":["../../src/components/ColorPicker/ColorPickerBase.tsx","../../src/components/ColorPicker/next/ColorPicker.tsx"],"sourcesContent":["import React, { useMemo } from \"react\";\r\nimport { combineClassNames } from \"../../utils/classNames\";\r\nimport type { ColorPickerBaseProps } from \"./ColorPicker.types\";\r\nimport { capitalize } from \"../../utils/capitalize\";\r\nimport {\r\n getDefaultShadow,\r\n getDefaultSize,\r\n} from \"../../config/boreal-style-config\";\r\n\r\nconst ColorPickerBase: React.FC<ColorPickerBaseProps> = ({\r\n label = \"Choose a color\",\r\n colors,\r\n selected,\r\n onChange,\r\n name = \"color-picker\",\r\n disabled = false,\r\n size = getDefaultSize(),\r\n shadow = getDefaultShadow(),\r\n shape = \"round\",\r\n allowCustom = false,\r\n required = false,\r\n invalid = false,\r\n helperText,\r\n errorText,\r\n customInputAriaLabel = \"Custom color picker\",\r\n hideLabel = false,\r\n className = \"\",\r\n classMap,\r\n \"aria-label\": ariaLabel,\r\n \"aria-labelledby\": ariaLabelledBy,\r\n \"aria-describedby\": ariaDescribedBy,\r\n \"data-testid\": testId = \"color-picker\",\r\n}) => {\r\n const legendId = `${testId}-legend`;\r\n const helperTextId = helperText ? `${testId}-helper-text` : undefined;\r\n const errorTextId = errorText ? `${testId}-error-text` : undefined;\r\n\r\n const describedBy =\r\n [ariaDescribedBy, helperTextId, invalid ? errorTextId : undefined]\r\n .filter(Boolean)\r\n .join(\" \") || undefined;\r\n\r\n const computedAriaLabelledBy =\r\n ariaLabelledBy ?? (!ariaLabel ? legendId : undefined);\r\n\r\n const labelClass = useMemo(\r\n () =>\r\n combineClassNames(\r\n classMap.swatch,\r\n classMap[size],\r\n classMap[shape],\r\n disabled && classMap.disabled,\r\n ),\r\n [classMap, size, shape, disabled],\r\n );\r\n\r\n return (\r\n <fieldset\r\n className={combineClassNames(\r\n classMap.color_picker,\r\n invalid && classMap.invalid,\r\n disabled && classMap.disabled,\r\n className,\r\n )}\r\n disabled={disabled}\r\n data-testid={testId}\r\n aria-label={ariaLabel}\r\n aria-labelledby={computedAriaLabelledBy}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n >\r\n <legend\r\n id={legendId}\r\n className={combineClassNames(classMap.legend, hideLabel && \"sr_only\")}\r\n >\r\n {label}\r\n </legend>\r\n\r\n <div className={classMap.color_picker_grid} role=\"radiogroup\">\r\n {colors.map((color, i) => {\r\n const id = `${testId}-color-${i}`;\r\n const optionLabelId = `${id}-label`;\r\n const isSelected = selected === color.value;\r\n const optionDisabled = disabled || color.disabled;\r\n\r\n return (\r\n <label\r\n key={`${color.value}-${i}`}\r\n className={combineClassNames(\r\n labelClass,\r\n optionDisabled && classMap.disabled,\r\n )}\r\n htmlFor={id}\r\n title={color.label}\r\n data-testid={`${testId}-option-${color.value}`}\r\n >\r\n <input\r\n type=\"radio\"\r\n name={name}\r\n id={id}\r\n value={color.value}\r\n checked={isSelected}\r\n onChange={() => onChange(color.value)}\r\n className={classMap.radio_input}\r\n disabled={optionDisabled}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n aria-required={required || undefined}\r\n aria-labelledby={optionLabelId}\r\n />\r\n\r\n <span id={optionLabelId} className={\"sr_only\"}>\r\n {color.label}\r\n </span>\r\n\r\n <span\r\n className={combineClassNames(\r\n classMap.preview,\r\n classMap[shape],\r\n isSelected && classMap.selected,\r\n optionDisabled && classMap.disabled,\r\n shadow && classMap[`shadow${capitalize(shadow)}`],\r\n )}\r\n style={{ backgroundColor: color.value }}\r\n aria-hidden=\"true\"\r\n />\r\n </label>\r\n );\r\n })}\r\n </div>\r\n\r\n {helperText && (\r\n <div\r\n id={helperTextId}\r\n className={classMap.helper_text}\r\n data-testid={`${testId}-helper-text`}\r\n >\r\n {helperText}\r\n </div>\r\n )}\r\n\r\n {invalid && errorText && (\r\n <div\r\n id={errorTextId}\r\n className={classMap.error_text}\r\n data-testid={`${testId}-error-text`}\r\n aria-live=\"polite\"\r\n >\r\n {errorText}\r\n </div>\r\n )}\r\n\r\n {allowCustom && (\r\n <input\r\n type=\"color\"\r\n className={classMap.custom_input}\r\n value={selected}\r\n onChange={(e) => onChange(e.target.value)}\r\n aria-label={customInputAriaLabel}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n data-testid={`${testId}-custom-input`}\r\n disabled={disabled}\r\n />\r\n )}\r\n </fieldset>\r\n );\r\n};\r\n\r\nColorPickerBase.displayName = \"ColorPickerBase\";\r\nexport default ColorPickerBase;\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\nimport ColorPickerBase from \"../ColorPickerBase\";\r\nimport styles from \"./ColorPicker.module.scss\";\r\nimport { ColorPickerProps } from \"../ColorPicker.types\";\r\n\r\nconst ColorPicker: React.FC<ColorPickerProps> = (props) => (\r\n <ColorPickerBase {...props} classMap={styles} />\r\n);\r\nColorPicker.displayName = \"ColorPicker\";\r\nexport default ColorPicker;\r\n"],"names":["selected","getDefaultSize","getDefaultShadow","useMemo","combineClassNames","jsxs","jsx","capitalize"],"mappings":"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"}
1
+ {"version":3,"file":"ColorPicker-DlyqseYs.cjs","sources":["../../src/components/ColorPicker/ColorPickerBase.tsx","../../src/components/ColorPicker/next/ColorPicker.tsx"],"sourcesContent":["import React, { useMemo } from \"react\";\r\nimport { combineClassNames } from \"../../utils/classNames\";\r\nimport type { ColorPickerBaseProps } from \"./ColorPicker.types\";\r\nimport { capitalize } from \"../../utils/capitalize\";\r\nimport {\r\n getDefaultShadow,\r\n getDefaultSize,\r\n} from \"../../config/boreal-style-config\";\r\n\r\nconst ColorPickerBase: React.FC<ColorPickerBaseProps> = ({\r\n label = \"Choose a color\",\r\n colors,\r\n selected,\r\n onChange,\r\n name = \"color-picker\",\r\n disabled = false,\r\n size = getDefaultSize(),\r\n shadow = getDefaultShadow(),\r\n shape = \"round\",\r\n allowCustom = false,\r\n required = false,\r\n invalid = false,\r\n helperText,\r\n errorText,\r\n customInputAriaLabel = \"Custom color picker\",\r\n hideLabel = false,\r\n className = \"\",\r\n classMap,\r\n \"aria-label\": ariaLabel,\r\n \"aria-labelledby\": ariaLabelledBy,\r\n \"aria-describedby\": ariaDescribedBy,\r\n \"data-testid\": testId = \"color-picker\",\r\n}) => {\r\n const legendId = `${testId}-legend`;\r\n const helperTextId = helperText ? `${testId}-helper-text` : undefined;\r\n const errorTextId = errorText ? `${testId}-error-text` : undefined;\r\n\r\n const describedBy =\r\n [ariaDescribedBy, helperTextId, invalid ? errorTextId : undefined]\r\n .filter(Boolean)\r\n .join(\" \") || undefined;\r\n\r\n const computedAriaLabelledBy =\r\n ariaLabelledBy ?? (!ariaLabel ? legendId : undefined);\r\n\r\n const labelClass = useMemo(\r\n () =>\r\n combineClassNames(\r\n classMap.swatch,\r\n classMap[size],\r\n classMap[shape],\r\n disabled && classMap.disabled,\r\n ),\r\n [classMap, size, shape, disabled],\r\n );\r\n\r\n return (\r\n <fieldset\r\n className={combineClassNames(\r\n classMap.color_picker,\r\n invalid && classMap.invalid,\r\n disabled && classMap.disabled,\r\n className,\r\n )}\r\n disabled={disabled}\r\n data-testid={testId}\r\n aria-label={ariaLabel}\r\n aria-labelledby={computedAriaLabelledBy}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n >\r\n <legend\r\n id={legendId}\r\n className={combineClassNames(classMap.legend, hideLabel && \"sr_only\")}\r\n >\r\n {label}\r\n </legend>\r\n\r\n <div className={classMap.color_picker_grid} role=\"radiogroup\">\r\n {colors.map((color, i) => {\r\n const id = `${testId}-color-${i}`;\r\n const optionLabelId = `${id}-label`;\r\n const isSelected = selected === color.value;\r\n const optionDisabled = disabled || color.disabled;\r\n\r\n return (\r\n <label\r\n key={`${color.value}-${i}`}\r\n className={combineClassNames(\r\n labelClass,\r\n optionDisabled && classMap.disabled,\r\n )}\r\n htmlFor={id}\r\n title={color.label}\r\n data-testid={`${testId}-option-${color.value}`}\r\n >\r\n <input\r\n type=\"radio\"\r\n name={name}\r\n id={id}\r\n value={color.value}\r\n checked={isSelected}\r\n onChange={() => onChange(color.value)}\r\n className={classMap.radio_input}\r\n disabled={optionDisabled}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n aria-required={required || undefined}\r\n aria-labelledby={optionLabelId}\r\n />\r\n\r\n <span id={optionLabelId} className={\"sr_only\"}>\r\n {color.label}\r\n </span>\r\n\r\n <span\r\n className={combineClassNames(\r\n classMap.preview,\r\n classMap[shape],\r\n isSelected && classMap.selected,\r\n optionDisabled && classMap.disabled,\r\n shadow && classMap[`shadow${capitalize(shadow)}`],\r\n )}\r\n style={{ backgroundColor: color.value }}\r\n aria-hidden=\"true\"\r\n />\r\n </label>\r\n );\r\n })}\r\n </div>\r\n\r\n {helperText && (\r\n <div\r\n id={helperTextId}\r\n className={classMap.helper_text}\r\n data-testid={`${testId}-helper-text`}\r\n >\r\n {helperText}\r\n </div>\r\n )}\r\n\r\n {invalid && errorText && (\r\n <div\r\n id={errorTextId}\r\n className={classMap.error_text}\r\n data-testid={`${testId}-error-text`}\r\n aria-live=\"polite\"\r\n >\r\n {errorText}\r\n </div>\r\n )}\r\n\r\n {allowCustom && (\r\n <input\r\n type=\"color\"\r\n className={classMap.custom_input}\r\n value={selected}\r\n onChange={(e) => onChange(e.target.value)}\r\n aria-label={customInputAriaLabel}\r\n aria-describedby={describedBy}\r\n aria-invalid={invalid || undefined}\r\n data-testid={`${testId}-custom-input`}\r\n disabled={disabled}\r\n />\r\n )}\r\n </fieldset>\r\n );\r\n};\r\n\r\nColorPickerBase.displayName = \"ColorPickerBase\";\r\nexport default ColorPickerBase;\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\nimport ColorPickerBase from \"../ColorPickerBase\";\r\nimport styles from \"./ColorPicker.module.scss\";\r\nimport { ColorPickerProps } from \"../ColorPicker.types\";\r\n\r\nconst ColorPicker: React.FC<ColorPickerProps> = (props) => (\r\n <ColorPickerBase {...props} classMap={styles} />\r\n);\r\nColorPicker.displayName = \"ColorPicker\";\r\nexport default ColorPicker;\r\n"],"names":["selected","getDefaultSize","getDefaultShadow","useMemo","combineClassNames","jsxs","jsx","capitalize"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
1
  "use strict";
2
- const ColorPicker = require("./ColorPicker-DmubVH4p.cjs");
2
+ const ColorPicker = require("./ColorPicker-DlyqseYs.cjs");
3
3
  module.exports = ColorPicker.ColorPicker;
4
4
  //# sourceMappingURL=ColorPicker.cjs.js.map
@@ -1,4 +1,4 @@
1
- import { C } from "./ColorPicker-BJfyM0Ay.js";
1
+ import { C } from "./ColorPicker-BhDo-h8k.js";
2
2
  export {
3
3
  C as default
4
4
  };
@@ -4,8 +4,72 @@ import ReactDOM from "react-dom";
4
4
  import { c as combineClassNames } from "./classNames-AS8QjFq7.js";
5
5
  import { c as capitalize } from "./capitalize-C0TSQSPh.js";
6
6
  import { d as getDefaultTheme, a as getDefaultRounding, b as getDefaultShadow } from "./boreal-style-config-DsaRlxmw.js";
7
- import './globals.css';import './CommandPalette.css';/* empty css */
8
- import { T as TextInput } from "./TextInput-CKM34-yu.js";
7
+ import { T as TextInput } from "./TextInput-B4s9TMoa.js";
8
+ import './CommandPalette.css';const overlay = "_overlay_qhoec_204";
9
+ const command_palette = "_command_palette_qhoec_225";
10
+ const roundNone = "_roundNone_qhoec_261";
11
+ const item = "_item_qhoec_265";
12
+ const roundSmall = "_roundSmall_qhoec_269";
13
+ const roundMedium = "_roundMedium_qhoec_277";
14
+ const roundLarge = "_roundLarge_qhoec_285";
15
+ const roundFull = "_roundFull_qhoec_293";
16
+ const shadowNone = "_shadowNone_qhoec_301";
17
+ const shadowLight = "_shadowLight_qhoec_305";
18
+ const shadowMedium = "_shadowMedium_qhoec_309";
19
+ const shadowStrong = "_shadowStrong_qhoec_313";
20
+ const shadowIntense = "_shadowIntense_qhoec_317";
21
+ const input = "_input_qhoec_321";
22
+ const list = "_list_qhoec_349";
23
+ const icon = "_icon_qhoec_415";
24
+ const empty = "_empty_qhoec_419";
25
+ const active = "_active_qhoec_441";
26
+ const primary = "_primary_qhoec_446";
27
+ const secondary = "_secondary_qhoec_464";
28
+ const tertiary = "_tertiary_qhoec_482";
29
+ const quaternary = "_quaternary_qhoec_500";
30
+ const clear = "_clear_qhoec_518";
31
+ const success = "_success_qhoec_536";
32
+ const error = "_error_qhoec_554";
33
+ const warning = "_warning_qhoec_572";
34
+ const spin = "_spin_qhoec_1";
35
+ const pulse = "_pulse_qhoec_1";
36
+ const styles = {
37
+ overlay,
38
+ command_palette,
39
+ roundNone,
40
+ item,
41
+ roundSmall,
42
+ roundMedium,
43
+ roundLarge,
44
+ roundFull,
45
+ shadowNone,
46
+ shadowLight,
47
+ shadowMedium,
48
+ shadowStrong,
49
+ shadowIntense,
50
+ input,
51
+ list,
52
+ icon,
53
+ empty,
54
+ active,
55
+ primary,
56
+ secondary,
57
+ tertiary,
58
+ quaternary,
59
+ clear,
60
+ success,
61
+ error,
62
+ warning,
63
+ "fade-in": "_fade-in_qhoec_1",
64
+ "slide-up": "_slide-up_qhoec_1",
65
+ "spin-3d": "_spin-3d_qhoec_1",
66
+ spin,
67
+ pulse,
68
+ "fade-in-up": "_fade-in-up_qhoec_1",
69
+ "progress-grow": "_progress-grow_qhoec_1",
70
+ "indeterminate-move": "_indeterminate-move_qhoec_1",
71
+ "skeleton-loading": "_skeleton-loading_qhoec_1"
72
+ };
9
73
  const CommandPaletteBase = ({
10
74
  commands,
11
75
  placeholder = "Search...",
@@ -406,71 +470,6 @@ const CommandPaletteBase = ({
406
470
  );
407
471
  };
408
472
  CommandPaletteBase.displayName = "CommandPaletteBase";
409
- const overlay = "_overlay_qhoec_204";
410
- const command_palette = "_command_palette_qhoec_225";
411
- const roundNone = "_roundNone_qhoec_261";
412
- const item = "_item_qhoec_265";
413
- const roundSmall = "_roundSmall_qhoec_269";
414
- const roundMedium = "_roundMedium_qhoec_277";
415
- const roundLarge = "_roundLarge_qhoec_285";
416
- const roundFull = "_roundFull_qhoec_293";
417
- const shadowNone = "_shadowNone_qhoec_301";
418
- const shadowLight = "_shadowLight_qhoec_305";
419
- const shadowMedium = "_shadowMedium_qhoec_309";
420
- const shadowStrong = "_shadowStrong_qhoec_313";
421
- const shadowIntense = "_shadowIntense_qhoec_317";
422
- const input = "_input_qhoec_321";
423
- const list = "_list_qhoec_349";
424
- const icon = "_icon_qhoec_415";
425
- const empty = "_empty_qhoec_419";
426
- const active = "_active_qhoec_441";
427
- const primary = "_primary_qhoec_446";
428
- const secondary = "_secondary_qhoec_464";
429
- const tertiary = "_tertiary_qhoec_482";
430
- const quaternary = "_quaternary_qhoec_500";
431
- const clear = "_clear_qhoec_518";
432
- const success = "_success_qhoec_536";
433
- const error = "_error_qhoec_554";
434
- const warning = "_warning_qhoec_572";
435
- const spin = "_spin_qhoec_1";
436
- const pulse = "_pulse_qhoec_1";
437
- const styles = {
438
- overlay,
439
- command_palette,
440
- roundNone,
441
- item,
442
- roundSmall,
443
- roundMedium,
444
- roundLarge,
445
- roundFull,
446
- shadowNone,
447
- shadowLight,
448
- shadowMedium,
449
- shadowStrong,
450
- shadowIntense,
451
- input,
452
- list,
453
- icon,
454
- empty,
455
- active,
456
- primary,
457
- secondary,
458
- tertiary,
459
- quaternary,
460
- clear,
461
- success,
462
- error,
463
- warning,
464
- "fade-in": "_fade-in_qhoec_1",
465
- "slide-up": "_slide-up_qhoec_1",
466
- "spin-3d": "_spin-3d_qhoec_1",
467
- spin,
468
- pulse,
469
- "fade-in-up": "_fade-in-up_qhoec_1",
470
- "progress-grow": "_progress-grow_qhoec_1",
471
- "indeterminate-move": "_indeterminate-move_qhoec_1",
472
- "skeleton-loading": "_skeleton-loading_qhoec_1"
473
- };
474
473
  const CommandPalette = (props) => /* @__PURE__ */ jsx(
475
474
  CommandPaletteBase,
476
475
  {
@@ -483,4 +482,4 @@ CommandPalette.displayName = "CommandPalette";
483
482
  export {
484
483
  CommandPalette as C
485
484
  };
486
- //# sourceMappingURL=CommandPalette-CNaU5jTY.js.map
485
+ //# sourceMappingURL=CommandPalette-BAgsEdVA.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"CommandPalette-CNaU5jTY.js","sources":["../../src/components/CommandPalette/CommandPaletteBase.tsx","../../src/components/CommandPalette/next/CommandPalette.tsx"],"sourcesContent":["import React, {\r\n useEffect,\r\n useId,\r\n useRef,\r\n useState,\r\n useCallback,\r\n KeyboardEvent,\r\n} from \"react\";\r\nimport ReactDOM from \"react-dom\";\r\nimport { combineClassNames } from \"../../utils/classNames\";\r\nimport type {\r\n CommandPaletteBaseProps,\r\n CommandItem,\r\n} from \"./CommandPalette.types\";\r\nimport { capitalize } from \"../../utils/capitalize\";\r\nimport {\r\n getDefaultRounding,\r\n getDefaultShadow,\r\n getDefaultTheme,\r\n} from \"../../config/boreal-style-config\";\r\n\r\nconst CommandPaletteBase: React.FC<CommandPaletteBaseProps> = ({\r\n commands,\r\n placeholder = \"Search...\",\r\n isOpen,\r\n onClose,\r\n asyncSearch,\r\n debounceMs = 300,\r\n theme = getDefaultTheme(),\r\n rounding = getDefaultRounding(),\r\n shadow = getDefaultShadow(),\r\n state = \"\",\r\n classMap,\r\n TextInputComponent,\r\n inputAriaLabel,\r\n inputAriaLabelledBy,\r\n inputAriaDescribedBy,\r\n inputLabel,\r\n inputId,\r\n listboxId,\r\n paletteId,\r\n listAriaLabel = \"Command suggestions\",\r\n emptyMessage = \"No matching results\",\r\n resultsAnnouncement = \"results available\",\r\n modal = true,\r\n trapFocus = false,\r\n restoreFocusOnClose = true,\r\n \"aria-label\": ariaLabel,\r\n \"aria-labelledby\": ariaLabelledBy,\r\n \"aria-describedby\": ariaDescribedBy,\r\n \"aria-controls\": ariaControls,\r\n \"aria-expanded\": ariaExpanded,\r\n \"aria-activedescendant\": ariaActiveDescendant,\r\n \"data-testid\": testId = \"command-palette\",\r\n className,\r\n ...rest\r\n}) => {\r\n const reactId = useId();\r\n const resolvedPaletteId = paletteId ?? `${testId}-${reactId}-dialog`;\r\n const resolvedInputId = inputId ?? `${testId}-${reactId}-input`;\r\n const resolvedListboxId = listboxId ?? `${testId}-${reactId}-listbox`;\r\n const resolvedLabelId = `${resolvedInputId}-label`;\r\n const resolvedStatusId = `${resolvedPaletteId}-status`;\r\n\r\n const [query, setQuery] = useState(\"\");\r\n const [activeIndex, setActiveIndex] = useState<number>(-1);\r\n const inputRef = useRef<HTMLInputElement>(null);\r\n const containerRef = useRef<HTMLDivElement>(null);\r\n const [mounted, setMounted] = useState(false);\r\n const [portalElement, setPortalElement] = useState<HTMLElement | null>(null);\r\n const [asyncResults, setAsyncResults] = useState<CommandItem[]>([]);\r\n const [isLoading, setIsLoading] = useState(false);\r\n const debounceRef = useRef<ReturnType<typeof setTimeout> | null>(null);\r\n const prevFocusRef = useRef<HTMLElement | null>(null);\r\n\r\n const filtered = asyncSearch\r\n ? asyncResults\r\n : commands.filter((cmd) => {\r\n const q = query.toLowerCase();\r\n if (!q) return true;\r\n\r\n const labelMatch = cmd.label.toLowerCase().includes(q);\r\n const keywordMatch = cmd.keywords?.some((keyword) =>\r\n keyword.toLowerCase().includes(q),\r\n );\r\n\r\n return labelMatch || Boolean(keywordMatch);\r\n });\r\n\r\n useEffect(() => {\r\n if (filtered.length === 0) {\r\n setActiveIndex(-1);\r\n } else if (\r\n activeIndex < 0 ||\r\n activeIndex >= filtered.length ||\r\n filtered[activeIndex]?.disabled\r\n ) {\r\n const firstEnabledIndex = filtered.findIndex((item) => !item.disabled);\r\n setActiveIndex(firstEnabledIndex);\r\n }\r\n }, [filtered, activeIndex]);\r\n\r\n useEffect(() => {\r\n if (!asyncSearch) return;\r\n\r\n if (debounceRef.current) clearTimeout(debounceRef.current);\r\n\r\n const q = query.trim();\r\n if (!q) {\r\n setAsyncResults([]);\r\n setIsLoading(false);\r\n return;\r\n }\r\n\r\n setIsLoading(true);\r\n debounceRef.current = setTimeout(() => {\r\n asyncSearch(q)\r\n .then((results) => {\r\n setAsyncResults(results);\r\n setIsLoading(false);\r\n })\r\n .catch(() => {\r\n setAsyncResults([]);\r\n setIsLoading(false);\r\n });\r\n }, debounceMs);\r\n\r\n return () => {\r\n if (debounceRef.current) clearTimeout(debounceRef.current);\r\n };\r\n }, [query, asyncSearch, debounceMs]);\r\n\r\n useEffect(() => {\r\n if (!isOpen) return;\r\n\r\n setMounted(true);\r\n prevFocusRef.current = document.activeElement as HTMLElement | null;\r\n\r\n const portal =\r\n document.getElementById(\"widget-portal\") ||\r\n (() => {\r\n const el = document.createElement(\"div\");\r\n el.id = \"widget-portal\";\r\n document.body.appendChild(el);\r\n return el;\r\n })();\r\n\r\n setPortalElement(portal);\r\n document.body.classList.add(\"noScroll\");\r\n\r\n return () => {\r\n document.body.classList.remove(\"noScroll\");\r\n setQuery(\"\");\r\n setActiveIndex(-1);\r\n setMounted(false);\r\n\r\n if (restoreFocusOnClose) {\r\n prevFocusRef.current?.focus?.();\r\n }\r\n };\r\n }, [isOpen, restoreFocusOnClose]);\r\n\r\n useEffect(() => {\r\n if (isOpen && mounted && portalElement && inputRef.current) {\r\n inputRef.current.focus();\r\n }\r\n }, [isOpen, mounted, portalElement]);\r\n\r\n const getItemId = useCallback(\r\n (cmd: CommandItem, index: number) =>\r\n cmd.id\r\n ? `${resolvedListboxId}-option-${cmd.id}`\r\n : `${resolvedListboxId}-option-${index}`,\r\n [resolvedListboxId],\r\n );\r\n\r\n const getNextEnabledIndex = useCallback(\r\n (startIndex: number, direction: 1 | -1) => {\r\n if (filtered.length === 0) return -1;\r\n\r\n let nextIndex = startIndex;\r\n\r\n for (let i = 0; i < filtered.length; i += 1) {\r\n nextIndex = (nextIndex + direction + filtered.length) % filtered.length;\r\n if (!filtered[nextIndex]?.disabled) {\r\n return nextIndex;\r\n }\r\n }\r\n\r\n return -1;\r\n },\r\n [filtered],\r\n );\r\n\r\n const activateCommand = useCallback(\r\n (cmd: CommandItem | undefined) => {\r\n if (!cmd || cmd.disabled) return;\r\n cmd.action();\r\n onClose();\r\n },\r\n [onClose],\r\n );\r\n\r\n const handleKeyDown = useCallback(\r\n (e: KeyboardEvent<HTMLInputElement>) => {\r\n if (e.key === \"ArrowDown\") {\r\n if (filtered.length === 0) return;\r\n e.preventDefault();\r\n setActiveIndex((prev) => getNextEnabledIndex(prev < 0 ? -1 : prev, 1));\r\n } else if (e.key === \"ArrowUp\") {\r\n if (filtered.length === 0) return;\r\n e.preventDefault();\r\n setActiveIndex((prev) => getNextEnabledIndex(prev < 0 ? 0 : prev, -1));\r\n } else if (e.key === \"Enter\") {\r\n if (activeIndex >= 0) {\r\n e.preventDefault();\r\n activateCommand(filtered[activeIndex]);\r\n }\r\n } else if (e.key === \"Escape\") {\r\n e.preventDefault();\r\n onClose();\r\n } else if (e.key === \"Home\") {\r\n e.preventDefault();\r\n const firstEnabledIndex = filtered.findIndex((item) => !item.disabled);\r\n setActiveIndex(firstEnabledIndex);\r\n } else if (e.key === \"End\") {\r\n e.preventDefault();\r\n const reversedIndex = [...filtered]\r\n .reverse()\r\n .findIndex((item) => !item.disabled);\r\n\r\n if (reversedIndex >= 0) {\r\n setActiveIndex(filtered.length - 1 - reversedIndex);\r\n }\r\n }\r\n },\r\n [filtered, activeIndex, getNextEnabledIndex, activateCommand, onClose],\r\n );\r\n\r\n const handleContainerKeyDown = useCallback(\r\n (e: KeyboardEvent<HTMLDivElement>) => {\r\n if (e.key === \"Escape\") {\r\n e.preventDefault();\r\n onClose();\r\n return;\r\n }\r\n\r\n if (trapFocus && e.key === \"Tab\") {\r\n const container = containerRef.current;\r\n if (!container) return;\r\n\r\n const focusable = container.querySelectorAll<HTMLElement>(\r\n [\r\n \"a[href]\",\r\n \"button:not([disabled])\",\r\n \"input:not([disabled])\",\r\n \"select:not([disabled])\",\r\n \"textarea:not([disabled])\",\r\n '[tabindex]:not([tabindex=\"-1\"])',\r\n ].join(\",\"),\r\n );\r\n\r\n if (focusable.length === 0) {\r\n e.preventDefault();\r\n return;\r\n }\r\n\r\n const first = focusable[0];\r\n const last = focusable[focusable.length - 1];\r\n const active = document.activeElement as HTMLElement | null;\r\n\r\n if (!e.shiftKey && active === last) {\r\n e.preventDefault();\r\n first.focus();\r\n } else if (e.shiftKey && active === first) {\r\n e.preventDefault();\r\n last.focus();\r\n }\r\n }\r\n },\r\n [onClose, trapFocus],\r\n );\r\n\r\n if (!isOpen || !mounted || !portalElement) return null;\r\n\r\n const activeItem =\r\n activeIndex >= 0 && filtered[activeIndex]\r\n ? filtered[activeIndex]\r\n : undefined;\r\n\r\n const computedActiveDescendant =\r\n ariaActiveDescendant ??\r\n (activeItem ? getItemId(activeItem, activeIndex) : undefined);\r\n\r\n const computedAriaExpanded =\r\n typeof ariaExpanded === \"boolean\" ? ariaExpanded : isOpen;\r\n\r\n const dialogRole = modal ? \"dialog\" : \"region\";\r\n\r\n const liveMessage = isLoading\r\n ? \"Searching commands\"\r\n : filtered.length === 0\r\n ? emptyMessage\r\n : `${filtered.length} ${resultsAnnouncement}`;\r\n\r\n return ReactDOM.createPortal(\r\n <div\r\n className={classMap.overlay}\r\n onClick={onClose}\r\n data-testid={`${testId}-overlay`}\r\n >\r\n <div\r\n {...rest}\r\n id={resolvedPaletteId}\r\n ref={containerRef}\r\n className={combineClassNames(\r\n classMap.command_palette,\r\n classMap[theme],\r\n classMap[state],\r\n shadow && classMap[`shadow${capitalize(shadow)}`],\r\n rounding && classMap[`round${capitalize(rounding)}`],\r\n className,\r\n )}\r\n onClick={(e) => e.stopPropagation()}\r\n onKeyDown={handleContainerKeyDown}\r\n role={dialogRole}\r\n aria-modal={modal ? true : undefined}\r\n aria-label={ariaLabel}\r\n aria-labelledby={ariaLabelledBy}\r\n aria-describedby={ariaDescribedBy}\r\n aria-controls={ariaControls}\r\n data-testid={testId}\r\n >\r\n {inputLabel && (\r\n <label\r\n id={resolvedLabelId}\r\n htmlFor={resolvedInputId}\r\n className={classMap.label}\r\n data-testid={`${testId}-input-label`}\r\n >\r\n {inputLabel}\r\n </label>\r\n )}\r\n\r\n <TextInputComponent\r\n ref={inputRef}\r\n id={resolvedInputId}\r\n type=\"text\"\r\n value={query}\r\n onChange={(\r\n valueOrEvent: string | React.ChangeEvent<HTMLInputElement>,\r\n event?: React.ChangeEvent<HTMLInputElement>,\r\n ) => {\r\n if (typeof valueOrEvent === \"string\") {\r\n setQuery(valueOrEvent);\r\n return;\r\n }\r\n\r\n setQuery(valueOrEvent.target.value ?? event?.target.value ?? \"\");\r\n }}\r\n onKeyDown={handleKeyDown}\r\n placeholder={placeholder}\r\n theme={theme}\r\n state={state}\r\n shadow={\"none\"}\r\n rounding={rounding}\r\n className={classMap.input}\r\n data-testid={`${testId}-input`}\r\n role=\"combobox\"\r\n aria-label={inputAriaLabel}\r\n aria-labelledby={\r\n inputAriaLabelledBy ??\r\n (!inputAriaLabel && inputLabel ? resolvedLabelId : undefined)\r\n }\r\n aria-describedby={inputAriaDescribedBy}\r\n aria-autocomplete=\"list\"\r\n aria-haspopup=\"listbox\"\r\n aria-expanded={computedAriaExpanded}\r\n aria-controls={resolvedListboxId}\r\n aria-activedescendant={computedActiveDescendant}\r\n />\r\n\r\n <div\r\n id={resolvedStatusId}\r\n className={classMap.srOnly}\r\n aria-live=\"polite\"\r\n aria-atomic=\"true\"\r\n data-testid={`${testId}-live-region`}\r\n >\r\n {liveMessage}\r\n </div>\r\n\r\n <ul\r\n id={resolvedListboxId}\r\n className={classMap.list}\r\n role=\"listbox\"\r\n aria-label={!ariaLabelledBy ? listAriaLabel : undefined}\r\n aria-labelledby={ariaLabelledBy}\r\n aria-busy={isLoading || undefined}\r\n data-testid={`${testId}-listbox`}\r\n >\r\n {isLoading ? (\r\n <li\r\n className={combineClassNames(classMap.item, classMap.empty)}\r\n role=\"option\"\r\n aria-disabled=\"true\"\r\n aria-selected=\"false\"\r\n data-testid={`${testId}-loading`}\r\n >\r\n Searching…\r\n </li>\r\n ) : filtered.length > 0 ? (\r\n filtered.map((cmd, index) => {\r\n const isActive = index === activeIndex;\r\n const isDisabled = Boolean(cmd.disabled);\r\n const itemId = getItemId(cmd, index);\r\n const descriptionId = cmd[\"aria-description\"]\r\n ? `${itemId}-description`\r\n : undefined;\r\n\r\n return (\r\n <li\r\n key={cmd.id ?? `${cmd.label}-${index}`}\r\n id={itemId}\r\n role=\"option\"\r\n aria-label={cmd[\"aria-label\"]}\r\n aria-describedby={descriptionId}\r\n aria-disabled={isDisabled || undefined}\r\n aria-selected={isActive}\r\n className={combineClassNames(\r\n classMap.item,\r\n classMap[theme],\r\n isActive && classMap.active,\r\n isDisabled && classMap.disabled,\r\n )}\r\n onClick={() => activateCommand(cmd)}\r\n onMouseEnter={() => {\r\n if (!isDisabled) setActiveIndex(index);\r\n }}\r\n data-testid={`${testId}-option-${index}`}\r\n >\r\n {cmd.icon && (\r\n <span className={classMap.icon} aria-hidden=\"true\">\r\n {cmd.icon}\r\n </span>\r\n )}\r\n\r\n <span\r\n className={classMap.itemLabel}\r\n data-testid={`${testId}-option-label-${index}`}\r\n >\r\n {cmd.label}\r\n </span>\r\n\r\n {cmd[\"aria-description\"] && (\r\n <span\r\n id={descriptionId}\r\n className={classMap.srOnly}\r\n data-testid={`${testId}-option-description-${index}`}\r\n >\r\n {cmd[\"aria-description\"]}\r\n </span>\r\n )}\r\n </li>\r\n );\r\n })\r\n ) : (\r\n <li\r\n role=\"option\"\r\n aria-selected=\"false\"\r\n aria-disabled=\"true\"\r\n className={combineClassNames(classMap.item, classMap.empty)}\r\n data-testid={`${testId}-empty`}\r\n >\r\n {emptyMessage}\r\n </li>\r\n )}\r\n </ul>\r\n </div>\r\n </div>,\r\n portalElement,\r\n );\r\n};\r\n\r\nCommandPaletteBase.displayName = \"CommandPaletteBase\";\r\n\r\nexport default CommandPaletteBase;\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\nimport CommandPaletteBase from \"../CommandPaletteBase\";\r\nimport styles from \"./CommandPalette.module.scss\";\r\nimport { TextInput } from \"@/index.next\";\r\nimport { CommandPaletteProps } from \"../CommandPalette.types\";\r\n\r\nconst CommandPalette: React.FC<CommandPaletteProps> = (props) => (\r\n <CommandPaletteBase\r\n {...props}\r\n classMap={styles}\r\n TextInputComponent={TextInput}\r\n />\r\n);\r\nCommandPalette.displayName = \"CommandPalette\";\r\nexport default CommandPalette;\r\n"],"names":["item","active"],"mappings":"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"}
1
+ {"version":3,"file":"CommandPalette-BAgsEdVA.js","sources":["../../src/components/CommandPalette/CommandPaletteBase.tsx","../../src/components/CommandPalette/next/CommandPalette.tsx"],"sourcesContent":["import React, {\r\n useEffect,\r\n useId,\r\n useRef,\r\n useState,\r\n useCallback,\r\n KeyboardEvent,\r\n} from \"react\";\r\nimport ReactDOM from \"react-dom\";\r\nimport { combineClassNames } from \"../../utils/classNames\";\r\nimport type {\r\n CommandPaletteBaseProps,\r\n CommandItem,\r\n} from \"./CommandPalette.types\";\r\nimport { capitalize } from \"../../utils/capitalize\";\r\nimport {\r\n getDefaultRounding,\r\n getDefaultShadow,\r\n getDefaultTheme,\r\n} from \"../../config/boreal-style-config\";\r\n\r\nconst CommandPaletteBase: React.FC<CommandPaletteBaseProps> = ({\r\n commands,\r\n placeholder = \"Search...\",\r\n isOpen,\r\n onClose,\r\n asyncSearch,\r\n debounceMs = 300,\r\n theme = getDefaultTheme(),\r\n rounding = getDefaultRounding(),\r\n shadow = getDefaultShadow(),\r\n state = \"\",\r\n classMap,\r\n TextInputComponent,\r\n inputAriaLabel,\r\n inputAriaLabelledBy,\r\n inputAriaDescribedBy,\r\n inputLabel,\r\n inputId,\r\n listboxId,\r\n paletteId,\r\n listAriaLabel = \"Command suggestions\",\r\n emptyMessage = \"No matching results\",\r\n resultsAnnouncement = \"results available\",\r\n modal = true,\r\n trapFocus = false,\r\n restoreFocusOnClose = true,\r\n \"aria-label\": ariaLabel,\r\n \"aria-labelledby\": ariaLabelledBy,\r\n \"aria-describedby\": ariaDescribedBy,\r\n \"aria-controls\": ariaControls,\r\n \"aria-expanded\": ariaExpanded,\r\n \"aria-activedescendant\": ariaActiveDescendant,\r\n \"data-testid\": testId = \"command-palette\",\r\n className,\r\n ...rest\r\n}) => {\r\n const reactId = useId();\r\n const resolvedPaletteId = paletteId ?? `${testId}-${reactId}-dialog`;\r\n const resolvedInputId = inputId ?? `${testId}-${reactId}-input`;\r\n const resolvedListboxId = listboxId ?? `${testId}-${reactId}-listbox`;\r\n const resolvedLabelId = `${resolvedInputId}-label`;\r\n const resolvedStatusId = `${resolvedPaletteId}-status`;\r\n\r\n const [query, setQuery] = useState(\"\");\r\n const [activeIndex, setActiveIndex] = useState<number>(-1);\r\n const inputRef = useRef<HTMLInputElement>(null);\r\n const containerRef = useRef<HTMLDivElement>(null);\r\n const [mounted, setMounted] = useState(false);\r\n const [portalElement, setPortalElement] = useState<HTMLElement | null>(null);\r\n const [asyncResults, setAsyncResults] = useState<CommandItem[]>([]);\r\n const [isLoading, setIsLoading] = useState(false);\r\n const debounceRef = useRef<ReturnType<typeof setTimeout> | null>(null);\r\n const prevFocusRef = useRef<HTMLElement | null>(null);\r\n\r\n const filtered = asyncSearch\r\n ? asyncResults\r\n : commands.filter((cmd) => {\r\n const q = query.toLowerCase();\r\n if (!q) return true;\r\n\r\n const labelMatch = cmd.label.toLowerCase().includes(q);\r\n const keywordMatch = cmd.keywords?.some((keyword) =>\r\n keyword.toLowerCase().includes(q),\r\n );\r\n\r\n return labelMatch || Boolean(keywordMatch);\r\n });\r\n\r\n useEffect(() => {\r\n if (filtered.length === 0) {\r\n setActiveIndex(-1);\r\n } else if (\r\n activeIndex < 0 ||\r\n activeIndex >= filtered.length ||\r\n filtered[activeIndex]?.disabled\r\n ) {\r\n const firstEnabledIndex = filtered.findIndex((item) => !item.disabled);\r\n setActiveIndex(firstEnabledIndex);\r\n }\r\n }, [filtered, activeIndex]);\r\n\r\n useEffect(() => {\r\n if (!asyncSearch) return;\r\n\r\n if (debounceRef.current) clearTimeout(debounceRef.current);\r\n\r\n const q = query.trim();\r\n if (!q) {\r\n setAsyncResults([]);\r\n setIsLoading(false);\r\n return;\r\n }\r\n\r\n setIsLoading(true);\r\n debounceRef.current = setTimeout(() => {\r\n asyncSearch(q)\r\n .then((results) => {\r\n setAsyncResults(results);\r\n setIsLoading(false);\r\n })\r\n .catch(() => {\r\n setAsyncResults([]);\r\n setIsLoading(false);\r\n });\r\n }, debounceMs);\r\n\r\n return () => {\r\n if (debounceRef.current) clearTimeout(debounceRef.current);\r\n };\r\n }, [query, asyncSearch, debounceMs]);\r\n\r\n useEffect(() => {\r\n if (!isOpen) return;\r\n\r\n setMounted(true);\r\n prevFocusRef.current = document.activeElement as HTMLElement | null;\r\n\r\n const portal =\r\n document.getElementById(\"widget-portal\") ||\r\n (() => {\r\n const el = document.createElement(\"div\");\r\n el.id = \"widget-portal\";\r\n document.body.appendChild(el);\r\n return el;\r\n })();\r\n\r\n setPortalElement(portal);\r\n document.body.classList.add(\"noScroll\");\r\n\r\n return () => {\r\n document.body.classList.remove(\"noScroll\");\r\n setQuery(\"\");\r\n setActiveIndex(-1);\r\n setMounted(false);\r\n\r\n if (restoreFocusOnClose) {\r\n prevFocusRef.current?.focus?.();\r\n }\r\n };\r\n }, [isOpen, restoreFocusOnClose]);\r\n\r\n useEffect(() => {\r\n if (isOpen && mounted && portalElement && inputRef.current) {\r\n inputRef.current.focus();\r\n }\r\n }, [isOpen, mounted, portalElement]);\r\n\r\n const getItemId = useCallback(\r\n (cmd: CommandItem, index: number) =>\r\n cmd.id\r\n ? `${resolvedListboxId}-option-${cmd.id}`\r\n : `${resolvedListboxId}-option-${index}`,\r\n [resolvedListboxId],\r\n );\r\n\r\n const getNextEnabledIndex = useCallback(\r\n (startIndex: number, direction: 1 | -1) => {\r\n if (filtered.length === 0) return -1;\r\n\r\n let nextIndex = startIndex;\r\n\r\n for (let i = 0; i < filtered.length; i += 1) {\r\n nextIndex = (nextIndex + direction + filtered.length) % filtered.length;\r\n if (!filtered[nextIndex]?.disabled) {\r\n return nextIndex;\r\n }\r\n }\r\n\r\n return -1;\r\n },\r\n [filtered],\r\n );\r\n\r\n const activateCommand = useCallback(\r\n (cmd: CommandItem | undefined) => {\r\n if (!cmd || cmd.disabled) return;\r\n cmd.action();\r\n onClose();\r\n },\r\n [onClose],\r\n );\r\n\r\n const handleKeyDown = useCallback(\r\n (e: KeyboardEvent<HTMLInputElement>) => {\r\n if (e.key === \"ArrowDown\") {\r\n if (filtered.length === 0) return;\r\n e.preventDefault();\r\n setActiveIndex((prev) => getNextEnabledIndex(prev < 0 ? -1 : prev, 1));\r\n } else if (e.key === \"ArrowUp\") {\r\n if (filtered.length === 0) return;\r\n e.preventDefault();\r\n setActiveIndex((prev) => getNextEnabledIndex(prev < 0 ? 0 : prev, -1));\r\n } else if (e.key === \"Enter\") {\r\n if (activeIndex >= 0) {\r\n e.preventDefault();\r\n activateCommand(filtered[activeIndex]);\r\n }\r\n } else if (e.key === \"Escape\") {\r\n e.preventDefault();\r\n onClose();\r\n } else if (e.key === \"Home\") {\r\n e.preventDefault();\r\n const firstEnabledIndex = filtered.findIndex((item) => !item.disabled);\r\n setActiveIndex(firstEnabledIndex);\r\n } else if (e.key === \"End\") {\r\n e.preventDefault();\r\n const reversedIndex = [...filtered]\r\n .reverse()\r\n .findIndex((item) => !item.disabled);\r\n\r\n if (reversedIndex >= 0) {\r\n setActiveIndex(filtered.length - 1 - reversedIndex);\r\n }\r\n }\r\n },\r\n [filtered, activeIndex, getNextEnabledIndex, activateCommand, onClose],\r\n );\r\n\r\n const handleContainerKeyDown = useCallback(\r\n (e: KeyboardEvent<HTMLDivElement>) => {\r\n if (e.key === \"Escape\") {\r\n e.preventDefault();\r\n onClose();\r\n return;\r\n }\r\n\r\n if (trapFocus && e.key === \"Tab\") {\r\n const container = containerRef.current;\r\n if (!container) return;\r\n\r\n const focusable = container.querySelectorAll<HTMLElement>(\r\n [\r\n \"a[href]\",\r\n \"button:not([disabled])\",\r\n \"input:not([disabled])\",\r\n \"select:not([disabled])\",\r\n \"textarea:not([disabled])\",\r\n '[tabindex]:not([tabindex=\"-1\"])',\r\n ].join(\",\"),\r\n );\r\n\r\n if (focusable.length === 0) {\r\n e.preventDefault();\r\n return;\r\n }\r\n\r\n const first = focusable[0];\r\n const last = focusable[focusable.length - 1];\r\n const active = document.activeElement as HTMLElement | null;\r\n\r\n if (!e.shiftKey && active === last) {\r\n e.preventDefault();\r\n first.focus();\r\n } else if (e.shiftKey && active === first) {\r\n e.preventDefault();\r\n last.focus();\r\n }\r\n }\r\n },\r\n [onClose, trapFocus],\r\n );\r\n\r\n if (!isOpen || !mounted || !portalElement) return null;\r\n\r\n const activeItem =\r\n activeIndex >= 0 && filtered[activeIndex]\r\n ? filtered[activeIndex]\r\n : undefined;\r\n\r\n const computedActiveDescendant =\r\n ariaActiveDescendant ??\r\n (activeItem ? getItemId(activeItem, activeIndex) : undefined);\r\n\r\n const computedAriaExpanded =\r\n typeof ariaExpanded === \"boolean\" ? ariaExpanded : isOpen;\r\n\r\n const dialogRole = modal ? \"dialog\" : \"region\";\r\n\r\n const liveMessage = isLoading\r\n ? \"Searching commands\"\r\n : filtered.length === 0\r\n ? emptyMessage\r\n : `${filtered.length} ${resultsAnnouncement}`;\r\n\r\n return ReactDOM.createPortal(\r\n <div\r\n className={classMap.overlay}\r\n onClick={onClose}\r\n data-testid={`${testId}-overlay`}\r\n >\r\n <div\r\n {...rest}\r\n id={resolvedPaletteId}\r\n ref={containerRef}\r\n className={combineClassNames(\r\n classMap.command_palette,\r\n classMap[theme],\r\n classMap[state],\r\n shadow && classMap[`shadow${capitalize(shadow)}`],\r\n rounding && classMap[`round${capitalize(rounding)}`],\r\n className,\r\n )}\r\n onClick={(e) => e.stopPropagation()}\r\n onKeyDown={handleContainerKeyDown}\r\n role={dialogRole}\r\n aria-modal={modal ? true : undefined}\r\n aria-label={ariaLabel}\r\n aria-labelledby={ariaLabelledBy}\r\n aria-describedby={ariaDescribedBy}\r\n aria-controls={ariaControls}\r\n data-testid={testId}\r\n >\r\n {inputLabel && (\r\n <label\r\n id={resolvedLabelId}\r\n htmlFor={resolvedInputId}\r\n className={classMap.label}\r\n data-testid={`${testId}-input-label`}\r\n >\r\n {inputLabel}\r\n </label>\r\n )}\r\n\r\n <TextInputComponent\r\n ref={inputRef}\r\n id={resolvedInputId}\r\n type=\"text\"\r\n value={query}\r\n onChange={(\r\n valueOrEvent: string | React.ChangeEvent<HTMLInputElement>,\r\n event?: React.ChangeEvent<HTMLInputElement>,\r\n ) => {\r\n if (typeof valueOrEvent === \"string\") {\r\n setQuery(valueOrEvent);\r\n return;\r\n }\r\n\r\n setQuery(valueOrEvent.target.value ?? event?.target.value ?? \"\");\r\n }}\r\n onKeyDown={handleKeyDown}\r\n placeholder={placeholder}\r\n theme={theme}\r\n state={state}\r\n shadow={\"none\"}\r\n rounding={rounding}\r\n className={classMap.input}\r\n data-testid={`${testId}-input`}\r\n role=\"combobox\"\r\n aria-label={inputAriaLabel}\r\n aria-labelledby={\r\n inputAriaLabelledBy ??\r\n (!inputAriaLabel && inputLabel ? resolvedLabelId : undefined)\r\n }\r\n aria-describedby={inputAriaDescribedBy}\r\n aria-autocomplete=\"list\"\r\n aria-haspopup=\"listbox\"\r\n aria-expanded={computedAriaExpanded}\r\n aria-controls={resolvedListboxId}\r\n aria-activedescendant={computedActiveDescendant}\r\n />\r\n\r\n <div\r\n id={resolvedStatusId}\r\n className={classMap.srOnly}\r\n aria-live=\"polite\"\r\n aria-atomic=\"true\"\r\n data-testid={`${testId}-live-region`}\r\n >\r\n {liveMessage}\r\n </div>\r\n\r\n <ul\r\n id={resolvedListboxId}\r\n className={classMap.list}\r\n role=\"listbox\"\r\n aria-label={!ariaLabelledBy ? listAriaLabel : undefined}\r\n aria-labelledby={ariaLabelledBy}\r\n aria-busy={isLoading || undefined}\r\n data-testid={`${testId}-listbox`}\r\n >\r\n {isLoading ? (\r\n <li\r\n className={combineClassNames(classMap.item, classMap.empty)}\r\n role=\"option\"\r\n aria-disabled=\"true\"\r\n aria-selected=\"false\"\r\n data-testid={`${testId}-loading`}\r\n >\r\n Searching…\r\n </li>\r\n ) : filtered.length > 0 ? (\r\n filtered.map((cmd, index) => {\r\n const isActive = index === activeIndex;\r\n const isDisabled = Boolean(cmd.disabled);\r\n const itemId = getItemId(cmd, index);\r\n const descriptionId = cmd[\"aria-description\"]\r\n ? `${itemId}-description`\r\n : undefined;\r\n\r\n return (\r\n <li\r\n key={cmd.id ?? `${cmd.label}-${index}`}\r\n id={itemId}\r\n role=\"option\"\r\n aria-label={cmd[\"aria-label\"]}\r\n aria-describedby={descriptionId}\r\n aria-disabled={isDisabled || undefined}\r\n aria-selected={isActive}\r\n className={combineClassNames(\r\n classMap.item,\r\n classMap[theme],\r\n isActive && classMap.active,\r\n isDisabled && classMap.disabled,\r\n )}\r\n onClick={() => activateCommand(cmd)}\r\n onMouseEnter={() => {\r\n if (!isDisabled) setActiveIndex(index);\r\n }}\r\n data-testid={`${testId}-option-${index}`}\r\n >\r\n {cmd.icon && (\r\n <span className={classMap.icon} aria-hidden=\"true\">\r\n {cmd.icon}\r\n </span>\r\n )}\r\n\r\n <span\r\n className={classMap.itemLabel}\r\n data-testid={`${testId}-option-label-${index}`}\r\n >\r\n {cmd.label}\r\n </span>\r\n\r\n {cmd[\"aria-description\"] && (\r\n <span\r\n id={descriptionId}\r\n className={classMap.srOnly}\r\n data-testid={`${testId}-option-description-${index}`}\r\n >\r\n {cmd[\"aria-description\"]}\r\n </span>\r\n )}\r\n </li>\r\n );\r\n })\r\n ) : (\r\n <li\r\n role=\"option\"\r\n aria-selected=\"false\"\r\n aria-disabled=\"true\"\r\n className={combineClassNames(classMap.item, classMap.empty)}\r\n data-testid={`${testId}-empty`}\r\n >\r\n {emptyMessage}\r\n </li>\r\n )}\r\n </ul>\r\n </div>\r\n </div>,\r\n portalElement,\r\n );\r\n};\r\n\r\nCommandPaletteBase.displayName = \"CommandPaletteBase\";\r\n\r\nexport default CommandPaletteBase;\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\nimport CommandPaletteBase from \"../CommandPaletteBase\";\r\nimport styles from \"./CommandPalette.module.scss\";\r\nimport TextInput from \"../../TextInput/next/TextInput\";\r\nimport { CommandPaletteProps } from \"../CommandPalette.types\";\r\n\r\nconst CommandPalette: React.FC<CommandPaletteProps> = (props) => (\r\n <CommandPaletteBase\r\n {...props}\r\n classMap={styles}\r\n TextInputComponent={TextInput}\r\n />\r\n);\r\nCommandPalette.displayName = \"CommandPalette\";\r\nexport default CommandPalette;\r\n"],"names":["item","active"],"mappings":"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"}