@commercetools/nimbus 0.0.0-canary-20250930190235 → 0.0.0-canary-20251001071243

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 (444) hide show
  1. package/dist/accordion.d.ts +3 -3
  2. package/dist/alert.d.ts +1 -1
  3. package/dist/calendar.d.ts +1 -1
  4. package/dist/chunks/{Button-BVaauB-c.es.js → Button-B6xR_FqM.es.js} +7 -7
  5. package/dist/chunks/{Button-BVaauB-c.es.js.map → Button-B6xR_FqM.es.js.map} +1 -1
  6. package/dist/chunks/{Button-BtJHe9xY.cjs.js → Button-BBCRIYjC.cjs.js} +2 -2
  7. package/dist/chunks/{Button-BtJHe9xY.cjs.js.map → Button-BBCRIYjC.cjs.js.map} +1 -1
  8. package/dist/chunks/{DateField-rweHHCKR.cjs.js → DateField-XplnfOh0.cjs.js} +2 -2
  9. package/dist/chunks/{DateField-rweHHCKR.cjs.js.map → DateField-XplnfOh0.cjs.js.map} +1 -1
  10. package/dist/chunks/{DateField-CoKm-f2B.es.js → DateField-ilC6DQcU.es.js} +29 -29
  11. package/dist/chunks/{DateField-CoKm-f2B.es.js.map → DateField-ilC6DQcU.es.js.map} +1 -1
  12. package/dist/chunks/{DatePicker-BYhiEF2C.cjs.js → DatePicker-Cy1-NRmz.cjs.js} +2 -2
  13. package/dist/chunks/{DatePicker-BYhiEF2C.cjs.js.map → DatePicker-Cy1-NRmz.cjs.js.map} +1 -1
  14. package/dist/chunks/{DatePicker-UdS55fqN.es.js → DatePicker-DOq_YUYb.es.js} +21 -21
  15. package/dist/chunks/{DatePicker-UdS55fqN.es.js.map → DatePicker-DOq_YUYb.es.js.map} +1 -1
  16. package/dist/chunks/{Dialog-C_Lr_ZUo.es.js → Dialog-BgV9Ur8E.es.js} +42 -37
  17. package/dist/chunks/{Dialog-C_Lr_ZUo.es.js.map → Dialog-BgV9Ur8E.es.js.map} +1 -1
  18. package/dist/chunks/{Dialog-32GmWneq.cjs.js → Dialog-BhqTE75I.cjs.js} +2 -2
  19. package/dist/chunks/{Dialog-32GmWneq.cjs.js.map → Dialog-BhqTE75I.cjs.js.map} +1 -1
  20. package/dist/chunks/{DragAndDrop-Bbd4HbfU.es.js → DragAndDrop-BnOybCz1.es.js} +12 -12
  21. package/dist/chunks/{DragAndDrop-Bbd4HbfU.es.js.map → DragAndDrop-BnOybCz1.es.js.map} +1 -1
  22. package/dist/chunks/{FocusScope-LBESYsSE.es.js → FocusScope-9EbM1-n6.es.js} +36 -36
  23. package/dist/chunks/{FocusScope-LBESYsSE.es.js.map → FocusScope-9EbM1-n6.es.js.map} +1 -1
  24. package/dist/chunks/{Group-DUCWhg7j.es.js → Group-DI0poa1g.es.js} +5 -5
  25. package/dist/chunks/{Group-DUCWhg7j.es.js.map → Group-DI0poa1g.es.js.map} +1 -1
  26. package/dist/chunks/{Header-C0mOQKWH.cjs.js → Header-BzYpow-F.cjs.js} +2 -2
  27. package/dist/chunks/{Header-C0mOQKWH.cjs.js.map → Header-BzYpow-F.cjs.js.map} +1 -1
  28. package/dist/chunks/{Header-CU7qXUk9.es.js → Header-LkbMVqUr.es.js} +8 -8
  29. package/dist/chunks/{Header-CU7qXUk9.es.js.map → Header-LkbMVqUr.es.js.map} +1 -1
  30. package/dist/chunks/{Heading-BaW6t55l.cjs.js → Heading-B83Y0yT_.cjs.js} +2 -2
  31. package/dist/chunks/{Heading-BaW6t55l.cjs.js.map → Heading-B83Y0yT_.cjs.js.map} +1 -1
  32. package/dist/chunks/{Heading-BX1t1Kmm.es.js → Heading-DK3LFGss.es.js} +76 -76
  33. package/dist/chunks/{Heading-BX1t1Kmm.es.js.map → Heading-DK3LFGss.es.js.map} +1 -1
  34. package/dist/chunks/{Input-FFG42ja6.es.js → Input-C_bvHj-u.es.js} +5 -5
  35. package/dist/chunks/{Input-FFG42ja6.es.js.map → Input-C_bvHj-u.es.js.map} +1 -1
  36. package/dist/chunks/{Label-BdaLJ5Ha.es.js → Label-DJtK5B3m.es.js} +2 -2
  37. package/dist/chunks/{Label-BdaLJ5Ha.es.js.map → Label-DJtK5B3m.es.js.map} +1 -1
  38. package/dist/chunks/{ListBox-DW2g6DgQ.cjs.js → ListBox-BBHyjoJ_.cjs.js} +2 -2
  39. package/dist/chunks/{ListBox-DW2g6DgQ.cjs.js.map → ListBox-BBHyjoJ_.cjs.js.map} +1 -1
  40. package/dist/chunks/{ListBox-CN09KH4h.es.js → ListBox-BLYSfKWM.es.js} +17 -17
  41. package/dist/chunks/{ListBox-CN09KH4h.es.js.map → ListBox-BLYSfKWM.es.js.map} +1 -1
  42. package/dist/chunks/{OverlayArrow-Kk4VWzmN.es.js → OverlayArrow-CTv6jme7.es.js} +3 -3
  43. package/dist/chunks/{OverlayArrow-Kk4VWzmN.es.js.map → OverlayArrow-CTv6jme7.es.js.map} +1 -1
  44. package/dist/chunks/{ProgressBar-CwFHab_J.es.js → ProgressBar-BTjAZZI-.es.js} +11 -11
  45. package/dist/chunks/{ProgressBar-CwFHab_J.es.js.map → ProgressBar-BTjAZZI-.es.js.map} +1 -1
  46. package/dist/chunks/{RSPContexts-B4yvXuBR.es.js → RSPContexts-sA4dJls7.es.js} +3 -3
  47. package/dist/chunks/{RSPContexts-B4yvXuBR.es.js.map → RSPContexts-sA4dJls7.es.js.map} +1 -1
  48. package/dist/chunks/{SSRProvider-v-LddFEs.es.js → SSRProvider-Cu8KibIK.es.js} +2 -2
  49. package/dist/chunks/{SSRProvider-v-LddFEs.es.js.map → SSRProvider-Cu8KibIK.es.js.map} +1 -1
  50. package/dist/chunks/{SelectionManager-3CeJgTGR.es.js → SelectionManager-DPe6sYkP.es.js} +27 -26
  51. package/dist/chunks/SelectionManager-DPe6sYkP.es.js.map +1 -0
  52. package/dist/chunks/SelectionManager-rtNqqyQQ.cjs.js +2 -0
  53. package/dist/chunks/SelectionManager-rtNqqyQQ.cjs.js.map +1 -0
  54. package/dist/chunks/Separator-CqqJM-tW.cjs.js +18 -0
  55. package/dist/chunks/Separator-CqqJM-tW.cjs.js.map +1 -0
  56. package/dist/chunks/{Separator-C_j2BhgD.es.js → Separator-DOY-4i96.es.js} +174 -174
  57. package/dist/chunks/Separator-DOY-4i96.es.js.map +1 -0
  58. package/dist/chunks/{TextArea-VPSW7sXC.es.js → TextArea-P6n8ajPu.es.js} +5 -5
  59. package/dist/chunks/{TextArea-VPSW7sXC.es.js.map → TextArea-P6n8ajPu.es.js.map} +1 -1
  60. package/dist/chunks/{ToggleButton-CPAdPTCr.cjs.js → ToggleButton-DVrc4vg7.cjs.js} +2 -2
  61. package/dist/chunks/{ToggleButton-CPAdPTCr.cjs.js.map → ToggleButton-DVrc4vg7.cjs.js.map} +1 -1
  62. package/dist/chunks/{ToggleButton-CRaJMq4q.es.js → ToggleButton-Xg4v21hw.es.js} +8 -8
  63. package/dist/chunks/{ToggleButton-CRaJMq4q.es.js.map → ToggleButton-Xg4v21hw.es.js.map} +1 -1
  64. package/dist/chunks/{VisuallyHidden-B0NiNh0E.es.js → VisuallyHidden-Do7AN5Hy.es.js} +3 -3
  65. package/dist/chunks/{VisuallyHidden-B0NiNh0E.es.js.map → VisuallyHidden-Do7AN5Hy.es.js.map} +1 -1
  66. package/dist/chunks/{accordion-DloMbCb7.cjs.js → accordion-4Vh8MRHG.cjs.js} +2 -2
  67. package/dist/chunks/{accordion-DloMbCb7.cjs.js.map → accordion-4Vh8MRHG.cjs.js.map} +1 -1
  68. package/dist/chunks/{accordion-BdPLxwi8.es.js → accordion-BSR4mSOu.es.js} +7 -7
  69. package/dist/chunks/{accordion-BdPLxwi8.es.js.map → accordion-BSR4mSOu.es.js.map} +1 -1
  70. package/dist/chunks/{alert-CiUQDrPl.es.js → alert-C0YsaZz2.es.js} +2 -2
  71. package/dist/chunks/{alert-CiUQDrPl.es.js.map → alert-C0YsaZz2.es.js.map} +1 -1
  72. package/dist/chunks/{alert-DpqyCZ2q.cjs.js → alert-cCy3Ka2E.cjs.js} +2 -2
  73. package/dist/chunks/{alert-DpqyCZ2q.cjs.js.map → alert-cCy3Ka2E.cjs.js.map} +1 -1
  74. package/dist/chunks/{badge-CHmfeeRs.es.js → badge-qLydLdTu.es.js} +2 -2
  75. package/dist/chunks/{badge-CHmfeeRs.es.js.map → badge-qLydLdTu.es.js.map} +1 -1
  76. package/dist/chunks/{button-DxNEOjS_.cjs.js → button-BAH2aLJh.cjs.js} +2 -2
  77. package/dist/chunks/{button-DxNEOjS_.cjs.js.map → button-BAH2aLJh.cjs.js.map} +1 -1
  78. package/dist/chunks/{button-CzLJhEV7.es.js → button-DSws4IjQ.es.js} +7 -7
  79. package/dist/chunks/{button-CzLJhEV7.es.js.map → button-DSws4IjQ.es.js.map} +1 -1
  80. package/dist/chunks/{calendar-CxWpOUYN.cjs.js → calendar-CNjZUyhZ.cjs.js} +2 -2
  81. package/dist/chunks/{calendar-CxWpOUYN.cjs.js.map → calendar-CNjZUyhZ.cjs.js.map} +1 -1
  82. package/dist/chunks/{range-calendar-BQsO9nZw.es.js → calendar-QYUcSSuy.es.js} +34 -34
  83. package/dist/chunks/{calendar-B_H9_kwD.es.js.map → calendar-QYUcSSuy.es.js.map} +1 -1
  84. package/dist/chunks/{card-D9fWUQqs.es.js → card-B-NYoYot.es.js} +3 -3
  85. package/dist/chunks/{card-D9fWUQqs.es.js.map → card-B-NYoYot.es.js.map} +1 -1
  86. package/dist/chunks/{checkbox-hKLS_Hpf.es.js → checkbox-BYw5k4jR.es.js} +11 -11
  87. package/dist/chunks/{checkbox-hKLS_Hpf.es.js.map → checkbox-BYw5k4jR.es.js.map} +1 -1
  88. package/dist/chunks/{checkbox-B5AI2jZt.cjs.js → checkbox-BjhklyOp.cjs.js} +2 -2
  89. package/dist/chunks/{checkbox-B5AI2jZt.cjs.js.map → checkbox-BjhklyOp.cjs.js.map} +1 -1
  90. package/dist/chunks/{collapsible-motion-D8dG2JLf.es.js → collapsible-motion-BASfX7dq.es.js} +5 -5
  91. package/dist/chunks/{collapsible-motion-D8dG2JLf.es.js.map → collapsible-motion-BASfX7dq.es.js.map} +1 -1
  92. package/dist/chunks/{collapsible-motion-BQ6C7uqG.cjs.js → collapsible-motion-CKitPEjA.cjs.js} +2 -2
  93. package/dist/chunks/{collapsible-motion-BQ6C7uqG.cjs.js.map → collapsible-motion-CKitPEjA.cjs.js.map} +1 -1
  94. package/dist/chunks/combobox-D0zYU4ZZ.cjs.js +2 -0
  95. package/dist/chunks/{combobox-CnveMVKQ.cjs.js.map → combobox-D0zYU4ZZ.cjs.js.map} +1 -1
  96. package/dist/chunks/{combobox-wkLS3Qcd.es.js → combobox-DmQUeFFT.es.js} +65 -65
  97. package/dist/chunks/{combobox-wkLS3Qcd.es.js.map → combobox-DmQUeFFT.es.js.map} +1 -1
  98. package/dist/chunks/{context-DHW7D0wv.es.js → context-R4YUlO9Y.es.js} +2 -2
  99. package/dist/chunks/{context-DHW7D0wv.es.js.map → context-R4YUlO9Y.es.js.map} +1 -1
  100. package/dist/chunks/{data-table-Bp2P2wVh.es.js → data-table-BKJDvxYT.es.js} +39 -39
  101. package/dist/chunks/{data-table-Bp2P2wVh.es.js.map → data-table-BKJDvxYT.es.js.map} +1 -1
  102. package/dist/chunks/{data-table-0qRALK0I.cjs.js → data-table-Cipv3jS9.cjs.js} +2 -2
  103. package/dist/chunks/{data-table-0qRALK0I.cjs.js.map → data-table-Cipv3jS9.cjs.js.map} +1 -1
  104. package/dist/chunks/{date-input-KbMioTti.es.js → date-input-BS7NT0zS.es.js} +4 -4
  105. package/dist/chunks/{date-input-KbMioTti.es.js.map → date-input-BS7NT0zS.es.js.map} +1 -1
  106. package/dist/chunks/{date-input-8mtWarDE.cjs.js → date-input-x1wfQ64a.cjs.js} +2 -2
  107. package/dist/chunks/{date-input-8mtWarDE.cjs.js.map → date-input-x1wfQ64a.cjs.js.map} +1 -1
  108. package/dist/chunks/{date-picker-rBQTH5hR.es.js → date-picker-BIvJI-6_.es.js} +32 -32
  109. package/dist/chunks/{date-picker-rBQTH5hR.es.js.map → date-picker-BIvJI-6_.es.js.map} +1 -1
  110. package/dist/chunks/{date-picker-BYhvkKI0.cjs.js → date-picker-BKudarck.cjs.js} +2 -2
  111. package/dist/chunks/{date-picker-BYhvkKI0.cjs.js.map → date-picker-BKudarck.cjs.js.map} +1 -1
  112. package/dist/chunks/{date-range-picker-6rafHs9g.cjs.js → date-range-picker-4mZ19UM7.cjs.js} +2 -2
  113. package/dist/chunks/{date-range-picker-6rafHs9g.cjs.js.map → date-range-picker-4mZ19UM7.cjs.js.map} +1 -1
  114. package/dist/chunks/{date-range-picker-BEk9kT2e.es.js → date-range-picker-DelR30zw.es.js} +28 -28
  115. package/dist/chunks/{date-range-picker-BEk9kT2e.es.js.map → date-range-picker-DelR30zw.es.js.map} +1 -1
  116. package/dist/chunks/dialog-B-NKwVSi.es.js +165 -0
  117. package/dist/chunks/dialog-B-NKwVSi.es.js.map +1 -0
  118. package/dist/chunks/dialog-D0RnaoTx.cjs.js +2 -0
  119. package/dist/chunks/dialog-D0RnaoTx.cjs.js.map +1 -0
  120. package/dist/chunks/dialog.title-Co1QDiYA.cjs.js +2 -0
  121. package/dist/chunks/dialog.title-Co1QDiYA.cjs.js.map +1 -0
  122. package/dist/chunks/dialog.title-DyRR_xdZ.es.js +322 -0
  123. package/dist/chunks/dialog.title-DyRR_xdZ.es.js.map +1 -0
  124. package/dist/chunks/{extractStyleProps-B-gDi9Qk.cjs.js → extractStyleProps-BIJocpXL.cjs.js} +2 -2
  125. package/dist/chunks/{extractStyleProps-B-gDi9Qk.cjs.js.map → extractStyleProps-BIJocpXL.cjs.js.map} +1 -1
  126. package/dist/chunks/{extractStyleProps-D6kxUL-O.es.js → extractStyleProps-i_um9deg.es.js} +2 -2
  127. package/dist/chunks/{extractStyleProps-D6kxUL-O.es.js.map → extractStyleProps-i_um9deg.es.js.map} +1 -1
  128. package/dist/chunks/{focusSafely-DS3RePi9.es.js → focusSafely-Bi_1H1qm.es.js} +3 -3
  129. package/dist/chunks/{focusSafely-DS3RePi9.es.js.map → focusSafely-Bi_1H1qm.es.js.map} +1 -1
  130. package/dist/chunks/{form-field-ZCIvXD-t.es.js → form-field-ClSAs-Vz.es.js} +11 -11
  131. package/dist/chunks/{form-field-ZCIvXD-t.es.js.map → form-field-ClSAs-Vz.es.js.map} +1 -1
  132. package/dist/chunks/{form-field-Cy7eAZCz.cjs.js → form-field-DVpuX6t5.cjs.js} +3 -3
  133. package/dist/chunks/{form-field-Cy7eAZCz.cjs.js.map → form-field-DVpuX6t5.cjs.js.map} +1 -1
  134. package/dist/chunks/{group-FqYM3Go1.es.js → group-DRLYSxIt.es.js} +2 -2
  135. package/dist/chunks/{group-FqYM3Go1.es.js.map → group-DRLYSxIt.es.js.map} +1 -1
  136. package/dist/chunks/heading-C3E6ZfYZ.es.js +25 -0
  137. package/dist/chunks/heading-C3E6ZfYZ.es.js.map +1 -0
  138. package/dist/chunks/heading-DmM-w8Sb.cjs.js +2 -0
  139. package/dist/chunks/heading-DmM-w8Sb.cjs.js.map +1 -0
  140. package/dist/chunks/icon-button-CBhvV2Ok.cjs.js +2 -0
  141. package/dist/chunks/{icon-button-DWBhjWpa.cjs.js.map → icon-button-CBhvV2Ok.cjs.js.map} +1 -1
  142. package/dist/chunks/icon-button-_9swBHc3.es.js +14 -0
  143. package/dist/chunks/{icon-button-CwG0NBaY.es.js.map → icon-button-_9swBHc3.es.js.map} +1 -1
  144. package/dist/chunks/{icon-toggle-button-Ya3xXEj8.es.js → icon-toggle-button-S56p30pP.es.js} +2 -2
  145. package/dist/chunks/{icon-toggle-button-Ya3xXEj8.es.js.map → icon-toggle-button-S56p30pP.es.js.map} +1 -1
  146. package/dist/chunks/{icon-toggle-button-BpLuJRaJ.cjs.js → icon-toggle-button-wPsxrI7v.cjs.js} +2 -2
  147. package/dist/chunks/{icon-toggle-button-BpLuJRaJ.cjs.js.map → icon-toggle-button-wPsxrI7v.cjs.js.map} +1 -1
  148. package/dist/chunks/{index-C7AV1c1_.es.js → index-DRb2wMPi.es.js} +290 -371
  149. package/dist/chunks/index-DRb2wMPi.es.js.map +1 -0
  150. package/dist/chunks/index-L5KSWClG.cjs.js +4 -0
  151. package/dist/chunks/index-L5KSWClG.cjs.js.map +1 -0
  152. package/dist/chunks/{kbd-D10CDyIE.es.js → kbd-DwetANiO.es.js} +2 -2
  153. package/dist/chunks/{kbd-D10CDyIE.es.js.map → kbd-DwetANiO.es.js.map} +1 -1
  154. package/dist/chunks/{link-CwFZrz1A.es.js → link--ktzvjSJ.es.js} +9 -9
  155. package/dist/chunks/{link-CwFZrz1A.es.js.map → link--ktzvjSJ.es.js.map} +1 -1
  156. package/dist/chunks/{link-DWa1zIUJ.cjs.js → link-CUKAEwrI.cjs.js} +2 -2
  157. package/dist/chunks/{link-DWa1zIUJ.cjs.js.map → link-CUKAEwrI.cjs.js.map} +1 -1
  158. package/dist/chunks/{loading-spinner-D3xWum_0.es.js → loading-spinner-CcVJ_X-1.es.js} +3 -3
  159. package/dist/chunks/{loading-spinner-D3xWum_0.es.js.map → loading-spinner-CcVJ_X-1.es.js.map} +1 -1
  160. package/dist/chunks/{make-element-focusable-DRTJNWHH.es.js → make-element-focusable-D5ajCMdm.es.js} +6 -6
  161. package/dist/chunks/{make-element-focusable-DRTJNWHH.es.js.map → make-element-focusable-D5ajCMdm.es.js.map} +1 -1
  162. package/dist/chunks/{menu-DbyMTgKs.cjs.js → menu-BfwjSmIS.cjs.js} +2 -2
  163. package/dist/chunks/{menu-DbyMTgKs.cjs.js.map → menu-BfwjSmIS.cjs.js.map} +1 -1
  164. package/dist/chunks/{menu-Bo_DdYZH.es.js → menu-CVO7gYdK.es.js} +7 -7
  165. package/dist/chunks/{menu-Bo_DdYZH.es.js.map → menu-CVO7gYdK.es.js.map} +1 -1
  166. package/dist/chunks/{mergeProps-uJMZqSEt.es.js → mergeProps-CzyOU2NE.es.js} +7 -7
  167. package/dist/chunks/{mergeProps-uJMZqSEt.es.js.map → mergeProps-CzyOU2NE.es.js.map} +1 -1
  168. package/dist/chunks/{money-input-Bp0LI7WP.es.js → money-input-C1jSkjXo.es.js} +23 -23
  169. package/dist/chunks/{money-input-Bp0LI7WP.es.js.map → money-input-C1jSkjXo.es.js.map} +1 -1
  170. package/dist/chunks/{money-input-CZ72JQGm.cjs.js → money-input-DJMTLGRy.cjs.js} +2 -2
  171. package/dist/chunks/{money-input-CZ72JQGm.cjs.js.map → money-input-DJMTLGRy.cjs.js.map} +1 -1
  172. package/dist/chunks/{multiline-text-input-N6E5HpPN.cjs.js → multiline-text-input-Dz0ikaM-.cjs.js} +2 -2
  173. package/dist/chunks/{multiline-text-input-N6E5HpPN.cjs.js.map → multiline-text-input-Dz0ikaM-.cjs.js.map} +1 -1
  174. package/dist/chunks/{multiline-text-input-uXOEV56a.es.js → multiline-text-input-_G6GcQrg.es.js} +4 -4
  175. package/dist/chunks/{multiline-text-input-uXOEV56a.es.js.map → multiline-text-input-_G6GcQrg.es.js.map} +1 -1
  176. package/dist/chunks/{nimbus-provider-DBBdCIeV.es.js → nimbus-provider-BDP4hXF7.es.js} +7 -7
  177. package/dist/chunks/{nimbus-provider-DBBdCIeV.es.js.map → nimbus-provider-BDP4hXF7.es.js.map} +1 -1
  178. package/dist/chunks/{nimbus-provider-CoNjJjM9.cjs.js → nimbus-provider-CyRDR7rD.cjs.js} +2 -2
  179. package/dist/chunks/{nimbus-provider-CoNjJjM9.cjs.js.map → nimbus-provider-CyRDR7rD.cjs.js.map} +1 -1
  180. package/dist/chunks/{number-input-GalEa1xO.es.js → number-input-CI0DSniW.es.js} +118 -118
  181. package/dist/chunks/{number-input-GalEa1xO.es.js.map → number-input-CI0DSniW.es.js.map} +1 -1
  182. package/dist/chunks/{number-input-BlWDe877.cjs.js → number-input-DnBbey5l.cjs.js} +2 -2
  183. package/dist/chunks/{number-input-BlWDe877.cjs.js.map → number-input-DnBbey5l.cjs.js.map} +1 -1
  184. package/dist/chunks/{openLink-Ctl0AdAy.es.js → openLink-BMfblNBC.es.js} +5 -5
  185. package/dist/chunks/{openLink-Ctl0AdAy.es.js.map → openLink-BMfblNBC.es.js.map} +1 -1
  186. package/dist/chunks/{pagination-wNk5gMNe.es.js → pagination-Bi6keZ3a.es.js} +14 -14
  187. package/dist/chunks/{pagination-wNk5gMNe.es.js.map → pagination-Bi6keZ3a.es.js.map} +1 -1
  188. package/dist/chunks/{pagination-g1eYG6Lt.cjs.js → pagination-DdGULNPt.cjs.js} +2 -2
  189. package/dist/chunks/{pagination-g1eYG6Lt.cjs.js.map → pagination-DdGULNPt.cjs.js.map} +1 -1
  190. package/dist/chunks/{password-input-XPlnNgUY.es.js → password-input-BC8qYtsr.es.js} +12 -12
  191. package/dist/chunks/{password-input-XPlnNgUY.es.js.map → password-input-BC8qYtsr.es.js.map} +1 -1
  192. package/dist/chunks/{password-input-CahrOPlY.cjs.js → password-input-Lh2HHpnL.cjs.js} +2 -2
  193. package/dist/chunks/{password-input-CahrOPlY.cjs.js.map → password-input-Lh2HHpnL.cjs.js.map} +1 -1
  194. package/dist/chunks/{progress-bar-CpKSaB_5.es.js → progress-bar-7H8xrBrA.es.js} +10 -10
  195. package/dist/chunks/{progress-bar-CpKSaB_5.es.js.map → progress-bar-7H8xrBrA.es.js.map} +1 -1
  196. package/dist/chunks/{progress-bar-DHA74qr-.cjs.js → progress-bar-Cw9FWHlW.cjs.js} +2 -2
  197. package/dist/chunks/{progress-bar-DHA74qr-.cjs.js.map → progress-bar-Cw9FWHlW.cjs.js.map} +1 -1
  198. package/dist/chunks/{radio-input-B0M7JizK.es.js → radio-input-BR53WuBU.es.js} +41 -41
  199. package/dist/chunks/{radio-input-B0M7JizK.es.js.map → radio-input-BR53WuBU.es.js.map} +1 -1
  200. package/dist/chunks/{radio-input-DnRVGbA1.cjs.js → radio-input-CsIiU86R.cjs.js} +2 -2
  201. package/dist/chunks/{radio-input-DnRVGbA1.cjs.js.map → radio-input-CsIiU86R.cjs.js.map} +1 -1
  202. package/dist/chunks/{range-calendar-ou9EuY-p.cjs.js → range-calendar-BH-2JsiF.cjs.js} +2 -2
  203. package/dist/chunks/{range-calendar-ou9EuY-p.cjs.js.map → range-calendar-BH-2JsiF.cjs.js.map} +1 -1
  204. package/dist/chunks/{calendar-B_H9_kwD.es.js → range-calendar-DFb9bsJ4.es.js} +31 -31
  205. package/dist/chunks/{range-calendar-BQsO9nZw.es.js.map → range-calendar-DFb9bsJ4.es.js.map} +1 -1
  206. package/dist/chunks/{rich-text-input-frvGdwoR.cjs.js → rich-text-input-BZ-Msa-L.cjs.js} +2 -2
  207. package/dist/chunks/{rich-text-input-frvGdwoR.cjs.js.map → rich-text-input-BZ-Msa-L.cjs.js.map} +1 -1
  208. package/dist/chunks/{rich-text-input-ADGWauFn.es.js → rich-text-input-BmdxXmR4.es.js} +25 -25
  209. package/dist/chunks/{rich-text-input-ADGWauFn.es.js.map → rich-text-input-BmdxXmR4.es.js.map} +1 -1
  210. package/dist/chunks/{scrollIntoView-DW7gkKpB.es.js → scrollIntoView-CAVHG58T.es.js} +2 -2
  211. package/dist/chunks/{scrollIntoView-DW7gkKpB.es.js.map → scrollIntoView-CAVHG58T.es.js.map} +1 -1
  212. package/dist/chunks/{select-CU6bPTz6.es.js → select-CTbgnj8L.es.js} +28 -28
  213. package/dist/chunks/{select-CU6bPTz6.es.js.map → select-CTbgnj8L.es.js.map} +1 -1
  214. package/dist/chunks/{select-BCsl2nEh.cjs.js → select-kYdilBPV.cjs.js} +2 -2
  215. package/dist/chunks/{select-BCsl2nEh.cjs.js.map → select-kYdilBPV.cjs.js.map} +1 -1
  216. package/dist/chunks/{separator-hUd3X_aL.cjs.js → separator-BPbw-2l_.cjs.js} +2 -2
  217. package/dist/chunks/{separator-hUd3X_aL.cjs.js.map → separator-BPbw-2l_.cjs.js.map} +1 -1
  218. package/dist/chunks/{separator-Demj-lbE.es.js → separator-kuEDe6AG.es.js} +3 -3
  219. package/dist/chunks/{separator-Demj-lbE.es.js.map → separator-kuEDe6AG.es.js.map} +1 -1
  220. package/dist/chunks/{split-button-DKBX--jQ.cjs.js → split-button-OxOyRI3k.cjs.js} +2 -2
  221. package/dist/chunks/{split-button-DKBX--jQ.cjs.js.map → split-button-OxOyRI3k.cjs.js.map} +1 -1
  222. package/dist/chunks/{split-button-8Dt6KkSc.es.js → split-button-VbEC4QmQ.es.js} +5 -5
  223. package/dist/chunks/{split-button-8Dt6KkSc.es.js.map → split-button-VbEC4QmQ.es.js.map} +1 -1
  224. package/dist/chunks/{switch-BID-KiLr.cjs.js → switch-BtgfHCUU.cjs.js} +2 -2
  225. package/dist/chunks/{switch-BID-KiLr.cjs.js.map → switch-BtgfHCUU.cjs.js.map} +1 -1
  226. package/dist/chunks/{switch-D28v2iAJ.es.js → switch-Cqlh-hxo.es.js} +14 -14
  227. package/dist/chunks/{switch-D28v2iAJ.es.js.map → switch-Cqlh-hxo.es.js.map} +1 -1
  228. package/dist/chunks/{tag-group-CXwXfpL3.cjs.js → tag-group-BiHCKIBb.cjs.js} +2 -2
  229. package/dist/chunks/{tag-group-CXwXfpL3.cjs.js.map → tag-group-BiHCKIBb.cjs.js.map} +1 -1
  230. package/dist/chunks/{tag-group-RzZiEVi1.es.js → tag-group-Dd6RDJ85.es.js} +23 -23
  231. package/dist/chunks/{tag-group-RzZiEVi1.es.js.map → tag-group-Dd6RDJ85.es.js.map} +1 -1
  232. package/dist/chunks/{text-Bi4Gre95.es.js → text-05SUCJIk.es.js} +2 -2
  233. package/dist/chunks/{text-Bi4Gre95.es.js.map → text-05SUCJIk.es.js.map} +1 -1
  234. package/dist/chunks/{text-input-CiZheGLu.es.js → text-input-Ch6OZEU5.es.js} +5 -5
  235. package/dist/chunks/{text-input-CiZheGLu.es.js.map → text-input-Ch6OZEU5.es.js.map} +1 -1
  236. package/dist/chunks/{text-input-xJIpxbYd.cjs.js → text-input-NqDP9nsj.cjs.js} +2 -2
  237. package/dist/chunks/{text-input-xJIpxbYd.cjs.js.map → text-input-NqDP9nsj.cjs.js.map} +1 -1
  238. package/dist/chunks/{time-input-CGwOrAf4.es.js → time-input-BPMoY1TY.es.js} +3 -3
  239. package/dist/chunks/{time-input-CGwOrAf4.es.js.map → time-input-BPMoY1TY.es.js.map} +1 -1
  240. package/dist/chunks/{time-input-Dqbx5jq_.cjs.js → time-input-CAUpjIAO.cjs.js} +2 -2
  241. package/dist/chunks/{time-input-Dqbx5jq_.cjs.js.map → time-input-CAUpjIAO.cjs.js.map} +1 -1
  242. package/dist/chunks/{toggle-button-Cv291lWy.cjs.js → toggle-button-BcqqrZ6N.cjs.js} +2 -2
  243. package/dist/chunks/{toggle-button-Cv291lWy.cjs.js.map → toggle-button-BcqqrZ6N.cjs.js.map} +1 -1
  244. package/dist/chunks/{toggle-button-Cj4XMEzn.es.js → toggle-button-Q0HDyGR5.es.js} +4 -4
  245. package/dist/chunks/{toggle-button-Cj4XMEzn.es.js.map → toggle-button-Q0HDyGR5.es.js.map} +1 -1
  246. package/dist/chunks/{toggle-button-group-DX134q7m.cjs.js → toggle-button-group-BR8PFfEf.cjs.js} +2 -2
  247. package/dist/chunks/{toggle-button-group-DX134q7m.cjs.js.map → toggle-button-group-BR8PFfEf.cjs.js.map} +1 -1
  248. package/dist/chunks/{toggle-button-group-DXmJCAH5.es.js → toggle-button-group-CYpa7G3-.es.js} +2 -2
  249. package/dist/chunks/{toggle-button-group-DXmJCAH5.es.js.map → toggle-button-group-CYpa7G3-.es.js.map} +1 -1
  250. package/dist/chunks/{toolbar-CoeY5d0M.cjs.js → toolbar-CK8vOB4V.cjs.js} +2 -2
  251. package/dist/chunks/{toolbar-CoeY5d0M.cjs.js.map → toolbar-CK8vOB4V.cjs.js.map} +1 -1
  252. package/dist/chunks/{toolbar-5TZLzPq3.es.js → toolbar-CpMMNKHw.es.js} +6 -6
  253. package/dist/chunks/{toolbar-5TZLzPq3.es.js.map → toolbar-CpMMNKHw.es.js.map} +1 -1
  254. package/dist/chunks/{tooltip-BE3LzL7I.es.js → tooltip-B8OD-6ed.es.js} +8 -8
  255. package/dist/chunks/{tooltip-BE3LzL7I.es.js.map → tooltip-B8OD-6ed.es.js.map} +1 -1
  256. package/dist/chunks/{useButton-CYfXo2Jm.es.js → useButton-exR3VPRk.es.js} +4 -4
  257. package/dist/chunks/{useButton-CYfXo2Jm.es.js.map → useButton-exR3VPRk.es.js.map} +1 -1
  258. package/dist/chunks/{useButton-BgBfaV_L.cjs.js → useButton-uDev7ez9.cjs.js} +2 -2
  259. package/dist/chunks/{useButton-BgBfaV_L.cjs.js.map → useButton-uDev7ez9.cjs.js.map} +1 -1
  260. package/dist/chunks/{useCollator-Y-oU82PA.es.js → useCollator-BHMZd1r6.es.js} +2 -2
  261. package/dist/chunks/{useCollator-Y-oU82PA.es.js.map → useCollator-BHMZd1r6.es.js.map} +1 -1
  262. package/dist/chunks/{useDateFormatter-BuXtxdR1.es.js → useDateFormatter-CUeAfTit.es.js} +5 -5
  263. package/dist/chunks/{useDateFormatter-BuXtxdR1.es.js.map → useDateFormatter-CUeAfTit.es.js.map} +1 -1
  264. package/dist/chunks/{useDateFormatter-CS19Cch2.cjs.js → useDateFormatter-DawPGCXt.cjs.js} +2 -2
  265. package/dist/chunks/{useDateFormatter-CS19Cch2.cjs.js.map → useDateFormatter-DawPGCXt.cjs.js.map} +1 -1
  266. package/dist/chunks/{useDisclosureState-BlZT0hmS.es.js → useDisclosureState-Tf9crdBs.es.js} +4 -4
  267. package/dist/chunks/{useDisclosureState-BlZT0hmS.es.js.map → useDisclosureState-Tf9crdBs.es.js.map} +1 -1
  268. package/dist/chunks/{useEvent-Bxxy8Y3o.es.js → useEvent-Bh_fbauk.es.js} +7 -7
  269. package/dist/chunks/{useEvent-Bxxy8Y3o.es.js.map → useEvent-Bh_fbauk.es.js.map} +1 -1
  270. package/dist/chunks/{useField-Do87rtEk.es.js → useField-BHGdzEiI.es.js} +8 -8
  271. package/dist/chunks/{useField-Do87rtEk.es.js.map → useField-BHGdzEiI.es.js.map} +1 -1
  272. package/dist/chunks/{useFilter-ClBjQ7pb.es.js → useFilter-DOfNzeZ9.es.js} +2 -2
  273. package/dist/chunks/{useFilter-ClBjQ7pb.es.js.map → useFilter-DOfNzeZ9.es.js.map} +1 -1
  274. package/dist/chunks/{useFocus-BmMqaBAE.es.js → useFocus-C9lb2m-i.es.js} +6 -6
  275. package/dist/chunks/{useFocus-BmMqaBAE.es.js.map → useFocus-C9lb2m-i.es.js.map} +1 -1
  276. package/dist/chunks/{useFocusRing-SQNQ9yn0.es.js → useFocusRing-h0FI3Bnv.es.js} +4 -4
  277. package/dist/chunks/{useFocusRing-SQNQ9yn0.es.js.map → useFocusRing-h0FI3Bnv.es.js.map} +1 -1
  278. package/dist/chunks/{useFocusVisible-BrqHqmb9.es.js → useFocusVisible-BQJ0cc5O.es.js} +6 -6
  279. package/dist/chunks/{useFocusVisible-BrqHqmb9.es.js.map → useFocusVisible-BQJ0cc5O.es.js.map} +1 -1
  280. package/dist/chunks/{useFocusWithin-Db5nhiOm.es.js → useFocusWithin-CelvVfPc.es.js} +6 -6
  281. package/dist/chunks/{useFocusWithin-Db5nhiOm.es.js.map → useFocusWithin-CelvVfPc.es.js.map} +1 -1
  282. package/dist/chunks/{useFocusable-BqRFi3ok.es.js → useFocusable-2UlJ2jic.es.js} +10 -10
  283. package/dist/chunks/{useFocusable-BqRFi3ok.es.js.map → useFocusable-2UlJ2jic.es.js.map} +1 -1
  284. package/dist/chunks/{useFormReset-S3fDvX8g.es.js → useFormReset-D_wskGk5.es.js} +2 -2
  285. package/dist/chunks/{useFormReset-S3fDvX8g.es.js.map → useFormReset-D_wskGk5.es.js.map} +1 -1
  286. package/dist/chunks/{useFormValidation-CzvY15hR.es.js → useFormValidation-UuUTYmIX.es.js} +3 -3
  287. package/dist/chunks/{useFormValidation-CzvY15hR.es.js.map → useFormValidation-UuUTYmIX.es.js.map} +1 -1
  288. package/dist/chunks/{useHighlightSelectionDescription-VzA5DMaE.es.js → useHighlightSelectionDescription-pmA2R2J7.es.js} +6 -6
  289. package/dist/chunks/{useHighlightSelectionDescription-VzA5DMaE.es.js.map → useHighlightSelectionDescription-pmA2R2J7.es.js.map} +1 -1
  290. package/dist/chunks/{useHover-B6UI1gbJ.es.js → useHover-Cb0lPkvP.es.js} +2 -2
  291. package/dist/chunks/{useHover-B6UI1gbJ.es.js.map → useHover-Cb0lPkvP.es.js.map} +1 -1
  292. package/dist/chunks/{useLabel-BZKxdTDn.es.js → useLabel-CzA-UqrL.es.js} +2 -2
  293. package/dist/chunks/{useLabel-BZKxdTDn.es.js.map → useLabel-CzA-UqrL.es.js.map} +1 -1
  294. package/dist/chunks/{useLocalizedStringFormatter-BpL9LNnx.es.js → useLocalizedStringFormatter-BRnRyxJp.es.js} +2 -2
  295. package/dist/chunks/{useLocalizedStringFormatter-BpL9LNnx.es.js.map → useLocalizedStringFormatter-BRnRyxJp.es.js.map} +1 -1
  296. package/dist/chunks/{usePress-C8-hLXJw.cjs.js → usePress-BrVCtBty.cjs.js} +3 -3
  297. package/dist/chunks/{usePress-C8-hLXJw.cjs.js.map → usePress-BrVCtBty.cjs.js.map} +1 -1
  298. package/dist/chunks/{usePress-BuSQ4Y3L.es.js → usePress-DWxMRKB2.es.js} +20 -20
  299. package/dist/chunks/{usePress-BuSQ4Y3L.es.js.map → usePress-DWxMRKB2.es.js.map} +1 -1
  300. package/dist/chunks/{useProgressBar-g3lb_jPQ.es.js → useProgressBar-C9zDMfHv.es.js} +8 -8
  301. package/dist/chunks/{useProgressBar-g3lb_jPQ.es.js.map → useProgressBar-C9zDMfHv.es.js.map} +1 -1
  302. package/dist/chunks/{useSingleSelectListState-ZzM7H50N.es.js → useSingleSelectListState-BCxpO0gf.es.js} +2 -2
  303. package/dist/chunks/{useSingleSelectListState-ZzM7H50N.es.js.map → useSingleSelectListState-BCxpO0gf.es.js.map} +1 -1
  304. package/dist/chunks/{useSingleSelectListState-BjYKH0pH.cjs.js → useSingleSelectListState-DbqMu5y_.cjs.js} +2 -2
  305. package/dist/chunks/{useSingleSelectListState-BjYKH0pH.cjs.js.map → useSingleSelectListState-DbqMu5y_.cjs.js.map} +1 -1
  306. package/dist/chunks/{useSpinButton-DedtXIGZ.es.js → useSpinButton-2dD53rZp.es.js} +3 -3
  307. package/dist/chunks/{useSpinButton-DedtXIGZ.es.js.map → useSpinButton-2dD53rZp.es.js.map} +1 -1
  308. package/dist/chunks/{useSyncRef-Cipkqs1s.es.js → useSyncRef-nVBzPD3o.es.js} +2 -2
  309. package/dist/chunks/{useSyncRef-Cipkqs1s.es.js.map → useSyncRef-nVBzPD3o.es.js.map} +1 -1
  310. package/dist/chunks/{useTextField-tbVMyexr.es.js → useTextField-CFlmp99F.es.js} +7 -7
  311. package/dist/chunks/{useTextField-tbVMyexr.es.js.map → useTextField-CFlmp99F.es.js.map} +1 -1
  312. package/dist/chunks/{useToggle-VJWgbeCC.cjs.js → useToggle-CB9pQ8ri.cjs.js} +2 -2
  313. package/dist/chunks/{useToggle-VJWgbeCC.cjs.js.map → useToggle-CB9pQ8ri.cjs.js.map} +1 -1
  314. package/dist/chunks/{useToggle-CoHAX6Sy.es.js → useToggle-lFy51sx5.es.js} +5 -5
  315. package/dist/chunks/{useToggle-CoHAX6Sy.es.js.map → useToggle-lFy51sx5.es.js.map} +1 -1
  316. package/dist/chunks/{useToolbar-B1WYuGxA.es.js → useToolbar-DAsENCEY.es.js} +4 -4
  317. package/dist/chunks/{useToolbar-B1WYuGxA.es.js.map → useToolbar-DAsENCEY.es.js.map} +1 -1
  318. package/dist/chunks/{utils-CsKCu3xh.es.js → utils-DkbE8ciF.es.js} +5 -5
  319. package/dist/chunks/{utils-CsKCu3xh.es.js.map → utils-DkbE8ciF.es.js.map} +1 -1
  320. package/dist/chunks/{utils-d3Zmq36h.es.js → utils-bpt7OfyH.es.js} +28 -28
  321. package/dist/chunks/{utils-d3Zmq36h.es.js.map → utils-bpt7OfyH.es.js.map} +1 -1
  322. package/dist/chunks/{visually-hidden-09RsVX6x.es.js → visually-hidden-BoNAVE5W.es.js} +2 -2
  323. package/dist/chunks/{visually-hidden-09RsVX6x.es.js.map → visually-hidden-BoNAVE5W.es.js.map} +1 -1
  324. package/dist/collapsible-motion.d.ts +1 -1
  325. package/dist/combobox.d.ts +1 -1
  326. package/dist/components/accordion.cjs +1 -1
  327. package/dist/components/accordion.es.js +1 -1
  328. package/dist/components/alert.cjs +1 -1
  329. package/dist/components/alert.es.js +1 -1
  330. package/dist/components/badge.es.js +1 -1
  331. package/dist/components/button.cjs +1 -1
  332. package/dist/components/button.es.js +1 -1
  333. package/dist/components/calendar.cjs +1 -1
  334. package/dist/components/calendar.es.js +1 -1
  335. package/dist/components/card.es.js +1 -1
  336. package/dist/components/checkbox.cjs +1 -1
  337. package/dist/components/checkbox.es.js +1 -1
  338. package/dist/components/collapsible-motion.cjs +1 -1
  339. package/dist/components/collapsible-motion.es.js +1 -1
  340. package/dist/components/combobox.cjs +1 -1
  341. package/dist/components/combobox.es.js +1 -1
  342. package/dist/components/components.cjs +1 -1
  343. package/dist/components/components.es.js +9 -174
  344. package/dist/components/components.es.js.map +1 -1
  345. package/dist/components/data-table.cjs +1 -1
  346. package/dist/components/data-table.es.js +1 -1
  347. package/dist/components/date-input.cjs +1 -1
  348. package/dist/components/date-input.es.js +1 -1
  349. package/dist/components/date-picker.cjs +1 -1
  350. package/dist/components/date-picker.es.js +1 -1
  351. package/dist/components/date-range-picker.cjs +1 -1
  352. package/dist/components/date-range-picker.es.js +1 -1
  353. package/dist/components/dialog.cjs +1 -1
  354. package/dist/components/dialog.es.js +1 -1
  355. package/dist/components/form-field.cjs +1 -1
  356. package/dist/components/form-field.es.js +1 -1
  357. package/dist/components/group.es.js +1 -1
  358. package/dist/components/heading.cjs +1 -1
  359. package/dist/components/heading.es.js +2 -2
  360. package/dist/components/icon-button.cjs +1 -1
  361. package/dist/components/icon-button.es.js +1 -1
  362. package/dist/components/icon-toggle-button.cjs +1 -1
  363. package/dist/components/icon-toggle-button.es.js +1 -1
  364. package/dist/components/kbd.es.js +1 -1
  365. package/dist/components/link.cjs +1 -1
  366. package/dist/components/link.es.js +1 -1
  367. package/dist/components/loading-spinner.es.js +1 -1
  368. package/dist/components/money-input.cjs +1 -1
  369. package/dist/components/money-input.es.js +1 -1
  370. package/dist/components/multiline-text-input.cjs +1 -1
  371. package/dist/components/multiline-text-input.es.js +1 -1
  372. package/dist/components/nimbus-provider.cjs +1 -1
  373. package/dist/components/nimbus-provider.es.js +1 -1
  374. package/dist/components/number-input.cjs +1 -1
  375. package/dist/components/number-input.es.js +1 -1
  376. package/dist/components/pagination.cjs +1 -1
  377. package/dist/components/pagination.es.js +1 -1
  378. package/dist/components/password-input.cjs +1 -1
  379. package/dist/components/password-input.es.js +1 -1
  380. package/dist/components/popover.cjs +1 -1
  381. package/dist/components/popover.es.js +1 -1
  382. package/dist/components/progress-bar.cjs +1 -1
  383. package/dist/components/progress-bar.es.js +1 -1
  384. package/dist/components/radio-input.cjs +1 -1
  385. package/dist/components/radio-input.es.js +1 -1
  386. package/dist/components/range-calendar.cjs +1 -1
  387. package/dist/components/range-calendar.es.js +1 -1
  388. package/dist/components/rich-text-input.cjs +1 -1
  389. package/dist/components/rich-text-input.es.js +1 -1
  390. package/dist/components/select.cjs +1 -1
  391. package/dist/components/select.es.js +1 -1
  392. package/dist/components/separator.cjs +1 -1
  393. package/dist/components/separator.es.js +1 -1
  394. package/dist/components/split-button.cjs +1 -1
  395. package/dist/components/split-button.es.js +1 -1
  396. package/dist/components/switch.cjs +1 -1
  397. package/dist/components/switch.es.js +1 -1
  398. package/dist/components/tag-group.cjs +1 -1
  399. package/dist/components/tag-group.es.js +1 -1
  400. package/dist/components/text-input.cjs +1 -1
  401. package/dist/components/text-input.es.js +1 -1
  402. package/dist/components/text.es.js +1 -1
  403. package/dist/components/time-input.cjs +1 -1
  404. package/dist/components/time-input.es.js +1 -1
  405. package/dist/components/toggle-button-group.cjs +1 -1
  406. package/dist/components/toggle-button-group.es.js +1 -1
  407. package/dist/components/toggle-button.cjs +1 -1
  408. package/dist/components/toggle-button.es.js +1 -1
  409. package/dist/components/toolbar.cjs +1 -1
  410. package/dist/components/toolbar.es.js +1 -1
  411. package/dist/components/tooltip.es.js +2 -2
  412. package/dist/components/visually-hidden.es.js +1 -1
  413. package/dist/components.d.ts +216 -5337
  414. package/dist/data-table.d.ts +7 -7
  415. package/dist/date-picker.d.ts +1 -1
  416. package/dist/date-range-picker.d.ts +1 -1
  417. package/dist/dialog.d.ts +505 -25
  418. package/dist/form-field.d.ts +1 -1
  419. package/dist/heading.d.ts +30 -2
  420. package/dist/index.cjs +1 -1
  421. package/dist/index.cjs.map +1 -1
  422. package/dist/index.d.ts +224 -5345
  423. package/dist/index.es.js +182 -182
  424. package/dist/progress-bar.d.ts +1 -1
  425. package/dist/range-calendar.d.ts +1 -1
  426. package/dist/rich-text-input.d.ts +1 -1
  427. package/dist/select.d.ts +1 -1
  428. package/package.json +5 -5
  429. package/dist/chunks/SelectionManager-3CeJgTGR.es.js.map +0 -1
  430. package/dist/chunks/SelectionManager-CZSEfn4s.cjs.js +0 -2
  431. package/dist/chunks/SelectionManager-CZSEfn4s.cjs.js.map +0 -1
  432. package/dist/chunks/Separator-C_j2BhgD.es.js.map +0 -1
  433. package/dist/chunks/Separator-DQ53Zxpp.cjs.js +0 -18
  434. package/dist/chunks/Separator-DQ53Zxpp.cjs.js.map +0 -1
  435. package/dist/chunks/combobox-CnveMVKQ.cjs.js +0 -2
  436. package/dist/chunks/dialog-CVa-E9-A.cjs.js +0 -2
  437. package/dist/chunks/dialog-CVa-E9-A.cjs.js.map +0 -1
  438. package/dist/chunks/dialog-DTSuKnyk.es.js +0 -34
  439. package/dist/chunks/dialog-DTSuKnyk.es.js.map +0 -1
  440. package/dist/chunks/icon-button-CwG0NBaY.es.js +0 -14
  441. package/dist/chunks/icon-button-DWBhjWpa.cjs.js +0 -2
  442. package/dist/chunks/index-C7AV1c1_.es.js.map +0 -1
  443. package/dist/chunks/index-ChJGUoLk.cjs.js +0 -4
  444. package/dist/chunks/index-ChJGUoLk.cjs.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"date-range-picker-6rafHs9g.cjs.js","sources":["../../src/components/date-range-picker/date-range-picker.slots.tsx","../../src/components/date-range-picker/components/date-range-picker.time-input.tsx","../../src/components/date-range-picker/components/date-range-picker.custom-context.tsx","../../src/components/date-range-picker/date-range-picker.tsx"],"sourcesContent":["import {\n type HTMLChakraProps,\n type RecipeProps,\n type UnstyledProp,\n createSlotRecipeContext,\n} from \"@chakra-ui/react/styled-system\";\n\nimport { dateRangePickerSlotRecipe } from \"./date-range-picker.recipe\";\n\n/**\n * Base recipe props interface that combines Chakra UI's recipe props\n * with the unstyled prop option for the div element.\n */\ninterface DateRangePickerRecipeProps extends RecipeProps<\"div\">, UnstyledProp {}\n\n/**\n * Root props interface that extends Chakra's HTML props with our recipe props.\n * This creates a complete set of props for the root element, combining\n * HTML attributes, Chakra's styling system, and our custom recipe props.\n */\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface DateRangePickerRootProps\n extends HTMLChakraProps<\"div\", DateRangePickerRecipeProps> {}\n\n// Correctly destructure from createSlotRecipeContext based on project examples\nconst { withProvider, withContext } = createSlotRecipeContext({\n recipe: dateRangePickerSlotRecipe,\n});\n\n/**\n * Root component that provides the styling context for the DateRangePicker component.\n * Uses Chakra UI's recipe context system for consistent styling across instances.\n */\nexport const DateRangePickerRootSlot = withProvider<\n HTMLDivElement,\n DateRangePickerRootProps\n>(\"div\", \"root\");\n\n/**\n * Slot component for the input group containing the DateInput and trigger button.\n */\nexport const DateRangePickerGroupSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"group\");\n\n/**\n * Slot component for the trigger button that opens the calendar popover.\n */\nexport const DateRangePickerTriggerSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"trigger\");\n\n/**\n * Slot component for the popover container.\n */\nexport const DateRangePickerPopoverSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"popover\");\n\n/**\n * Slot component for the calendar container within the popover.\n */\nexport const DateRangePickerCalendarSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"calendar\");\n\n/**\n * Slot component for the calendar header.\n */\nexport const DateRangePickerCalendarHeaderSlot = withContext<\n HTMLElement,\n HTMLChakraProps<\"header\">\n>(\"header\", \"calendarHeader\");\n\n/**\n * Slot component for the calendar grid.\n */\nexport const DateRangePickerCalendarGridSlot = withContext<\n HTMLTableElement,\n HTMLChakraProps<\"table\">\n>(\"table\", \"calendarGrid\");\n\n/**\n * Slot component for individual calendar cells.\n */\nexport const DateRangePickerCalendarCellSlot = withContext<\n HTMLTableCellElement,\n HTMLChakraProps<\"td\">\n>(\"td\", \"calendarCell\");\n","import { Flex, Text, TimeInput } from \"@/components\";\nimport { useContext, useRef, useEffect } from \"react\";\nimport { DateRangePickerStateContext } from \"react-aria-components\";\nimport type { DateRangePickerTimeInputProps } from \"../date-range-picker.types\";\n\nexport const DateRangePickerTimeInput = ({\n hideTimeZone,\n hourCycle,\n}: DateRangePickerTimeInputProps) => {\n const dateRangePickerState = useContext(DateRangePickerStateContext);\n const { granularity, value } = dateRangePickerState!;\n const timeInputRef = useRef<HTMLDivElement>(null);\n const previousValueRef = useRef(value);\n\n // do not show up to the party if you're not invited\n if (granularity === \"day\") {\n return null;\n }\n\n // Focus the time input when date range changes (user selects dates from calendar)\n useEffect(() => {\n let timeoutId: ReturnType<typeof setTimeout> | undefined;\n\n // Check if date range changed by comparing start and end dates\n const hasValueChanged =\n (value?.start &&\n previousValueRef.current?.start?.compare(value.start) !== 0) ||\n (value?.end && previousValueRef.current?.end?.compare(value.end) !== 0);\n\n if (hasValueChanged) {\n // Only auto-focus if no time input segment currently has focus\n // This prevents stealing focus during user interaction with time segments\n const container = timeInputRef.current;\n const activeElement = document.activeElement;\n const hasTimeSegmentFocus =\n container?.contains(activeElement) &&\n activeElement?.getAttribute(\"role\") === \"spinbutton\";\n\n if (!hasTimeSegmentFocus) {\n // Small delay to ensure the DOM is ready\n timeoutId = setTimeout(() => {\n // Find the first focusable segment within the time input container\n if (container) {\n const firstSegment = container.querySelector(\n '[role=\"spinbutton\"]'\n ) as HTMLElement;\n\n if (firstSegment) {\n firstSegment.focus();\n }\n }\n }, 50);\n }\n }\n\n previousValueRef.current = value;\n\n // Cleanup timeout on effect re-run or unmount to prevent memory leaks\n return () => {\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n };\n }, [value]);\n\n return (\n <Flex\n ref={timeInputRef}\n borderTop=\"solid-25\"\n borderColor=\"neutral.3\"\n py=\"300\"\n px=\"400\"\n alignItems=\"center\"\n justifyContent=\"center\"\n gap=\"200\"\n >\n {/* Start DateInput with separate label */}\n <Flex alignItems=\"center\" gap=\"200\">\n {/* TODO: translate hardcoded string */}\n <Text\n textStyle=\"xs\"\n fontWeight=\"500\"\n color=\"neutral.12\"\n minWidth=\"fit-content\"\n >\n Start time\n </Text>\n <TimeInput\n slot=\"startTimeInput\"\n variant=\"ghost\"\n size=\"sm\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Flex>\n\n {/* End DateInput with separate label */}\n <Flex alignItems=\"center\" gap=\"200\">\n {/* TODO: translate hardcoded string */}\n <Text\n textStyle=\"xs\"\n fontWeight=\"500\"\n color=\"neutral.12\"\n minWidth=\"fit-content\"\n >\n End time\n </Text>\n <TimeInput\n slot=\"endTimeInput\"\n variant=\"ghost\"\n size=\"sm\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Flex>\n </Flex>\n );\n};\n","import { useContext, type ReactNode } from \"react\";\nimport {\n Provider,\n ButtonContext,\n DateRangePickerStateContext,\n TimeFieldContext,\n useSlottedContext,\n} from \"react-aria-components\";\nimport type { PressEvent, TimeValue } from \"react-aria\";\n\nexport const DateRangePickerCustomContext = ({\n children,\n}: {\n children: ReactNode;\n}) => {\n const buttonContext = useSlottedContext(ButtonContext) || {};\n const dateRangePickerState = useContext(DateRangePickerStateContext);\n\n // Check if all 6 segments (start: day, month, year; end: day, month, year) have values\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const hasCompleteRangeDate = (date: any) =>\n date?.day && date?.month && date?.year;\n\n const incompleteValue =\n !dateRangePickerState?.value ||\n !hasCompleteRangeDate(dateRangePickerState.value.start) ||\n !hasCompleteRangeDate(dateRangePickerState.value.end);\n\n const { granularity } = dateRangePickerState!;\n\n // Extract time values from start and end dates separately\n const startTimeValue =\n dateRangePickerState?.value?.start &&\n \"hour\" in dateRangePickerState.value.start\n ? dateRangePickerState.value.start\n : null;\n const endTimeValue =\n dateRangePickerState?.value?.end && \"hour\" in dateRangePickerState.value.end\n ? dateRangePickerState.value.end\n : null;\n\n // Try to get disabled state from the button context\n const isDateRangePickerDisabled = buttonContext?.isDisabled;\n\n // Generate default aria-label based on granularity if not provided\n const getDefaultTimeInputAriaLabel = (type: \"start\" | \"end\") => {\n const prefix = type === \"start\" ? \"Start\" : \"End\";\n switch (granularity) {\n case \"hour\":\n return `${prefix} time (hour)`;\n case \"minute\":\n return `${prefix} time (hour and minute)`;\n case \"second\":\n return `${prefix} time (hour, minute, and second)`;\n default:\n return `${prefix} time`;\n }\n };\n\n /**\n * Button slots\n * ================================\n */\n const buttonSlots = {\n /** toggles the calendar popover */\n calendarToggle: {\n ...buttonContext,\n onPress: (event: PressEvent) => {\n // Ensure any active input (e.g., date picker segment) loses focus\n // because blurring the input will close the popover if it's open (or was just opened)\n const activeElement = document?.activeElement as HTMLElement | null;\n\n if (activeElement) {\n activeElement.blur();\n }\n\n buttonContext.onPress?.(event);\n },\n },\n /** Clear button that displays when there's a value in each segment - hidden from both visual and screen readers when there's no value */\n clear: {\n // Clear both start and end values\n onPress: () => dateRangePickerState?.setValue(null),\n \"aria-label\": \"Clear input value\",\n isDisabled: isDateRangePickerDisabled,\n // Hide the button when there's no value\n style: incompleteValue ? { display: \"none\" } : undefined,\n \"aria-hidden\": incompleteValue ? true : undefined,\n },\n };\n\n /**\n * TimeInput slots\n * ================================\n */\n\n // Separate time input slots for start and end times\n const timeInputSlots = {\n startTimeInput: {\n value: startTimeValue,\n onChange: (value: TimeValue | null) => {\n if (value !== null && dateRangePickerState?.value?.start) {\n // Update the start date with the new time\n const currentValue = dateRangePickerState.value;\n const startDate = currentValue.start;\n const endDate = currentValue.end;\n if (startDate && endDate) {\n const newStartDate = startDate.set({\n hour: value.hour,\n minute: value.minute || 0,\n second: value.second || 0,\n millisecond: value.millisecond || 0,\n });\n\n dateRangePickerState.setValue({\n start: newStartDate,\n end: endDate,\n });\n }\n }\n },\n granularity: granularity === \"day\" ? undefined : granularity,\n \"aria-label\": getDefaultTimeInputAriaLabel(\"start\"),\n },\n endTimeInput: {\n value: endTimeValue,\n onChange: (value: TimeValue | null) => {\n if (value !== null && dateRangePickerState?.value?.end) {\n // Update the end date with the new time\n const currentValue = dateRangePickerState.value;\n const startDate = currentValue.start;\n const endDate = currentValue.end;\n if (startDate && endDate) {\n const newEndDate = endDate.set({\n hour: value.hour,\n minute: value.minute || 0,\n second: value.second || 0,\n millisecond: value.millisecond || 0,\n });\n\n dateRangePickerState.setValue({\n start: startDate,\n end: newEndDate,\n });\n }\n }\n },\n granularity: granularity === \"day\" ? undefined : granularity,\n \"aria-label\": getDefaultTimeInputAriaLabel(\"end\"),\n },\n };\n\n return (\n <Provider\n values={[\n [\n ButtonContext,\n {\n slots: buttonSlots,\n },\n ],\n [TimeFieldContext, { slots: timeInputSlots }],\n ]}\n >\n {children}\n </Provider>\n );\n};\n","import {\n DateRangePickerRootSlot,\n DateRangePickerGroupSlot,\n DateRangePickerTriggerSlot,\n DateRangePickerPopoverSlot,\n DateRangePickerCalendarSlot,\n} from \"./date-range-picker.slots\";\n\nimport { CalendarMonth, Close } from \"@commercetools/nimbus-icons\";\n\nimport {\n DateRangePicker as ReactAriaDateRangePicker,\n Group,\n Popover,\n Dialog,\n} from \"react-aria-components\";\nimport { useSlotRecipe } from \"@chakra-ui/react/styled-system\";\nimport { dateRangePickerSlotRecipe } from \"./date-range-picker.recipe\";\nimport type { DateRangePickerProps } from \"./date-range-picker.types\";\nimport { extractStyleProps } from \"@/utils/extractStyleProps\";\nimport { DateInput, RangeCalendar, IconButton, Text } from \"@/components\";\nimport { DateRangePickerTimeInput } from \"./components/date-range-picker.time-input\";\nimport { DateRangePickerCustomContext } from \"./components/date-range-picker.custom-context\";\n\n/**\n * DateRangePicker\n * ============================================================\n * Combines a DateInput with a RangeCalendar popover for date range selection.\n * Users can either type a date range directly or select from the calendar.\n */\nexport const DateRangePicker = (props: DateRangePickerProps) => {\n // Forward hideTimeZone and hourCycle to child components (footer time inputs)\n const { granularity = \"day\", hideTimeZone, hourCycle } = props;\n const recipe = useSlotRecipe({ recipe: dateRangePickerSlotRecipe });\n const [recipeProps, remainingProps] = recipe.splitVariantProps(props);\n\n const [styleProps, otherProps] = extractStyleProps(remainingProps);\n\n // Extract size and variant from recipe props to pass to DateInputs\n const { size = \"md\" } = recipeProps;\n\n // the size of the buttons overlaying the input\n const overlayButtonSize = size === \"md\" ? \"xs\" : \"2xs\";\n\n // When granularity is \"day\", use the prop value (defaults to true if not provided)\n // For other granularities (time-based), force to false so users can set both date and time\n const shouldCloseOnSelect =\n granularity === \"day\" ? props.shouldCloseOnSelect : false;\n\n return (\n <DateRangePickerRootSlot {...recipeProps} {...styleProps} asChild>\n <ReactAriaDateRangePicker\n {...otherProps}\n shouldCloseOnSelect={shouldCloseOnSelect}\n >\n <DateRangePickerCustomContext>\n <DateRangePickerGroupSlot asChild>\n <Group>\n <DateInput\n slot=\"start\"\n size={size}\n variant=\"plain\"\n width=\"auto\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n <Text\n as=\"span\"\n px=\"150\"\n color=\"neutral.11\"\n userSelect=\"none\"\n aria-hidden=\"true\"\n slot={null}\n >\n –\n </Text>\n <DateInput\n slot=\"end\"\n size={size}\n variant=\"plain\"\n width=\"auto\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n <DateRangePickerTriggerSlot>\n {/* @ts-expect-error react aria is adding the aria-label prop */}\n <IconButton\n tone=\"primary\"\n variant=\"ghost\"\n size={overlayButtonSize}\n slot=\"clear\"\n >\n <Close />\n </IconButton>\n {/* @ts-expect-error react aria is adding the aria-label prop */}\n <IconButton\n tone=\"primary\"\n variant=\"ghost\"\n size={overlayButtonSize}\n slot=\"calendarToggle\"\n >\n <CalendarMonth />\n </IconButton>\n </DateRangePickerTriggerSlot>\n </Group>\n </DateRangePickerGroupSlot>\n <DateRangePickerPopoverSlot asChild>\n <Popover placement=\"bottom end\">\n <Dialog>\n <DateRangePickerCalendarSlot>\n <RangeCalendar />\n </DateRangePickerCalendarSlot>\n <DateRangePickerTimeInput\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Dialog>\n </Popover>\n </DateRangePickerPopoverSlot>\n </DateRangePickerCustomContext>\n </ReactAriaDateRangePicker>\n </DateRangePickerRootSlot>\n );\n};\n\nDateRangePicker.displayName = \"DateRangePicker\";\n"],"names":["withProvider","withContext","createSlotRecipeContext","dateRangePickerSlotRecipe","DateRangePickerRootSlot","DateRangePickerGroupSlot","DateRangePickerTriggerSlot","DateRangePickerPopoverSlot","DateRangePickerCalendarSlot","DateRangePickerTimeInput","hideTimeZone","hourCycle","dateRangePickerState","useContext","DateRangePickerStateContext","granularity","value","timeInputRef","useRef","previousValueRef","useEffect","timeoutId","container","activeElement","firstSegment","jsxs","Flex","jsx","Text","TimeInput","DateRangePickerCustomContext","children","buttonContext","useSlottedContext","ButtonContext","hasCompleteRangeDate","date","incompleteValue","startTimeValue","endTimeValue","isDateRangePickerDisabled","getDefaultTimeInputAriaLabel","type","prefix","buttonSlots","event","timeInputSlots","currentValue","startDate","endDate","newStartDate","newEndDate","Provider","TimeFieldContext","DateRangePicker","props","recipe","useSlotRecipe","recipeProps","remainingProps","styleProps","otherProps","extractStyleProps","size","overlayButtonSize","shouldCloseOnSelect","ReactAriaDateRangePicker","Group","DateInput","IconButton","Close","CalendarMonth","Popover","Dialog","RangeCalendar"],"mappings":"6sBAyBM,CAAE,aAAAA,EAAc,YAAAC,CAAA,EAAgBC,0BAAwB,CAC5D,OAAQC,EAAAA,yBACV,CAAC,EAMYC,EAA0BJ,EAGrC,MAAO,MAAM,EAKFK,EAA2BJ,EAGtC,MAAO,OAAO,EAKHK,EAA6BL,EAGxC,MAAO,SAAS,EAKLM,EAA6BN,EAGxC,MAAO,SAAS,EAKLO,EAA8BP,EAGzC,MAAO,UAAU,EC/DNQ,EAA2B,CAAC,CACvC,aAAAC,EACA,UAAAC,CACF,IAAqC,CACnC,MAAMC,EAAuBC,EAAAA,WAAWC,2CAA2B,EAC7D,CAAE,YAAAC,EAAa,MAAAC,CAAA,EAAUJ,EACzBK,EAAeC,EAAAA,OAAuB,IAAI,EAC1CC,EAAmBD,EAAAA,OAAOF,CAAK,EAGrC,OAAID,IAAgB,MACX,MAITK,EAAAA,UAAU,IAAM,CACd,IAAIC,EAQJ,GAJGL,GAAO,OACNG,EAAiB,SAAS,OAAO,QAAQH,EAAM,KAAK,IAAM,GAC3DA,GAAO,KAAOG,EAAiB,SAAS,KAAK,QAAQH,EAAM,GAAG,IAAM,EAElD,CAGnB,MAAMM,EAAYL,EAAa,QACzBM,EAAgB,SAAS,cAE7BD,GAAW,SAASC,CAAa,GACjCA,GAAe,aAAa,MAAM,IAAM,eAIxCF,EAAY,WAAW,IAAM,CAE3B,GAAIC,EAAW,CACb,MAAME,EAAeF,EAAU,cAC7B,qBAAA,EAGEE,GACFA,EAAa,MAAA,CAEjB,CACF,EAAG,EAAE,EAET,CAEA,OAAAL,EAAiB,QAAUH,EAGpB,IAAM,CACPK,GACF,aAAaA,CAAS,CAE1B,CACF,EAAG,CAACL,CAAK,CAAC,EAGRS,EAAAA,KAACC,EAAAA,KAAA,CACC,IAAKT,EACL,UAAU,WACV,YAAY,YACZ,GAAG,MACH,GAAG,MACH,WAAW,SACX,eAAe,SACf,IAAI,MAGJ,SAAA,CAAAQ,EAAAA,KAACC,EAAAA,KAAA,CAAK,WAAW,SAAS,IAAI,MAE5B,SAAA,CAAAC,EAAAA,IAACC,EAAAA,KAAA,CACC,UAAU,KACV,WAAW,MACX,MAAM,aACN,SAAS,cACV,SAAA,YAAA,CAAA,EAGDD,EAAAA,IAACE,EAAAA,UAAA,CACC,KAAK,iBACL,QAAQ,QACR,KAAK,KACL,aAAAnB,EACA,UAAAC,CAAA,CAAA,CACF,EACF,EAGAc,EAAAA,KAACC,EAAAA,KAAA,CAAK,WAAW,SAAS,IAAI,MAE5B,SAAA,CAAAC,EAAAA,IAACC,EAAAA,KAAA,CACC,UAAU,KACV,WAAW,MACX,MAAM,aACN,SAAS,cACV,SAAA,UAAA,CAAA,EAGDD,EAAAA,IAACE,EAAAA,UAAA,CACC,KAAK,eACL,QAAQ,QACR,KAAK,KACL,aAAAnB,EACA,UAAAC,CAAA,CAAA,CACF,CAAA,CACF,CAAA,CAAA,CAAA,EAGN,EC3GamB,EAA+B,CAAC,CAC3C,SAAAC,CACF,IAEM,CACJ,MAAMC,EAAgBC,EAAAA,0CAAkBC,EAAAA,yCAAa,GAAK,CAAA,EACpDtB,EAAuBC,EAAAA,WAAWC,2CAA2B,EAI7DqB,EAAwBC,GAC5BA,GAAM,KAAOA,GAAM,OAASA,GAAM,KAE9BC,EACJ,CAACzB,GAAsB,OACvB,CAACuB,EAAqBvB,EAAqB,MAAM,KAAK,GACtD,CAACuB,EAAqBvB,EAAqB,MAAM,GAAG,EAEhD,CAAE,YAAAG,GAAgBH,EAGlB0B,EACJ1B,GAAsB,OAAO,OAC7B,SAAUA,EAAqB,MAAM,MACjCA,EAAqB,MAAM,MAC3B,KACA2B,EACJ3B,GAAsB,OAAO,KAAO,SAAUA,EAAqB,MAAM,IACrEA,EAAqB,MAAM,IAC3B,KAGA4B,EAA4BR,GAAe,WAG3CS,EAAgCC,GAA0B,CAC9D,MAAMC,EAASD,IAAS,QAAU,QAAU,MAC5C,OAAQ3B,EAAA,CACN,IAAK,OACH,MAAO,GAAG4B,CAAM,eAClB,IAAK,SACH,MAAO,GAAGA,CAAM,0BAClB,IAAK,SACH,MAAO,GAAGA,CAAM,mCAClB,QACE,MAAO,GAAGA,CAAM,OAAA,CAEtB,EAMMC,EAAc,CAElB,eAAgB,CACd,GAAGZ,EACH,QAAUa,GAAsB,CAG9B,MAAMtB,EAAgB,UAAU,cAE5BA,GACFA,EAAc,KAAA,EAGhBS,EAAc,UAAUa,CAAK,CAC/B,CAAA,EAGF,MAAO,CAEL,QAAS,IAAMjC,GAAsB,SAAS,IAAI,EAClD,aAAc,oBACd,WAAY4B,EAEZ,MAAOH,EAAkB,CAAE,QAAS,QAAW,OAC/C,cAAeA,EAAkB,GAAO,MAAA,CAC1C,EASIS,EAAiB,CACrB,eAAgB,CACd,MAAOR,EACP,SAAWtB,GAA4B,CACrC,GAAIA,IAAU,MAAQJ,GAAsB,OAAO,MAAO,CAExD,MAAMmC,EAAenC,EAAqB,MACpCoC,EAAYD,EAAa,MACzBE,EAAUF,EAAa,IAC7B,GAAIC,GAAaC,EAAS,CACxB,MAAMC,EAAeF,EAAU,IAAI,CACjC,KAAMhC,EAAM,KACZ,OAAQA,EAAM,QAAU,EACxB,OAAQA,EAAM,QAAU,EACxB,YAAaA,EAAM,aAAe,CAAA,CACnC,EAEDJ,EAAqB,SAAS,CAC5B,MAAOsC,EACP,IAAKD,CAAA,CACN,CACH,CACF,CACF,EACA,YAAalC,IAAgB,MAAQ,OAAYA,EACjD,aAAc0B,EAA6B,OAAO,CAAA,EAEpD,aAAc,CACZ,MAAOF,EACP,SAAWvB,GAA4B,CACrC,GAAIA,IAAU,MAAQJ,GAAsB,OAAO,IAAK,CAEtD,MAAMmC,EAAenC,EAAqB,MACpCoC,EAAYD,EAAa,MACzBE,EAAUF,EAAa,IAC7B,GAAIC,GAAaC,EAAS,CACxB,MAAME,EAAaF,EAAQ,IAAI,CAC7B,KAAMjC,EAAM,KACZ,OAAQA,EAAM,QAAU,EACxB,OAAQA,EAAM,QAAU,EACxB,YAAaA,EAAM,aAAe,CAAA,CACnC,EAEDJ,EAAqB,SAAS,CAC5B,MAAOoC,EACP,IAAKG,CAAA,CACN,CACH,CACF,CACF,EACA,YAAapC,IAAgB,MAAQ,OAAYA,EACjD,aAAc0B,EAA6B,KAAK,CAAA,CAClD,EAGF,OACEd,EAAAA,IAACyB,EAAAA,0CAAA,CACC,OAAQ,CACN,CACElB,EAAAA,0CACA,CACE,MAAOU,CAAA,CACT,EAEF,CAACS,EAAAA,0CAAkB,CAAE,MAAOP,EAAgB,CAAA,EAG7C,SAAAf,CAAA,CAAA,CAGP,ECzIauB,EAAmBC,GAAgC,CAE9D,KAAM,CAAE,YAAAxC,EAAc,MAAO,aAAAL,EAAc,UAAAC,GAAc4C,EACnDC,EAASC,EAAAA,cAAc,CAAE,OAAQtD,EAAAA,0BAA2B,EAC5D,CAACuD,EAAaC,CAAc,EAAIH,EAAO,kBAAkBD,CAAK,EAE9D,CAACK,EAAYC,CAAU,EAAIC,EAAAA,kBAAkBH,CAAc,EAG3D,CAAE,KAAAI,EAAO,IAAA,EAASL,EAGlBM,EAAoBD,IAAS,KAAO,KAAO,MAI3CE,EACJlD,IAAgB,MAAQwC,EAAM,oBAAsB,GAEtD,aACGnD,EAAA,CAAyB,GAAGsD,EAAc,GAAGE,EAAY,QAAO,GAC/D,SAAAjC,EAAAA,IAACuC,EAAAA,0CAAA,CACE,GAAGL,EACJ,oBAAAI,EAEA,gBAACnC,EAAA,CACC,SAAA,CAAAH,MAACtB,EAAA,CAAyB,QAAO,GAC/B,SAAAoB,EAAAA,KAAC0C,4CAAA,CACC,SAAA,CAAAxC,EAAAA,IAACyC,EAAAA,UAAA,CACC,KAAK,QACL,KAAAL,EACA,QAAQ,QACR,MAAM,OACN,aAAArD,EACA,UAAAC,CAAA,CAAA,EAEFgB,EAAAA,IAACC,EAAAA,KAAA,CACC,GAAG,OACH,GAAG,MACH,MAAM,aACN,WAAW,OACX,cAAY,OACZ,KAAM,KACP,SAAA,GAAA,CAAA,EAGDD,EAAAA,IAACyC,EAAAA,UAAA,CACC,KAAK,MACL,KAAAL,EACA,QAAQ,QACR,MAAM,OACN,aAAArD,EACA,UAAAC,CAAA,CAAA,SAEDL,EAAA,CAEC,SAAA,CAAAqB,EAAAA,IAAC0C,EAAAA,WAAA,CACC,KAAK,UACL,QAAQ,QACR,KAAML,EACN,KAAK,QAEL,eAACM,EAAAA,MAAA,CAAA,CAAM,CAAA,CAAA,EAGT3C,EAAAA,IAAC0C,EAAAA,WAAA,CACC,KAAK,UACL,QAAQ,QACR,KAAML,EACN,KAAK,iBAEL,eAACO,EAAAA,cAAA,CAAA,CAAc,CAAA,CAAA,CACjB,CAAA,CACF,CAAA,CAAA,CACF,CAAA,CACF,EACA5C,EAAAA,IAACpB,GAA2B,QAAO,GACjC,eAACiE,EAAAA,0CAAA,CAAQ,UAAU,aACjB,SAAA/C,EAAAA,KAACgD,EAAAA,0CAAA,CACC,SAAA,CAAA9C,EAAAA,IAACnB,EAAA,CACC,SAAAmB,EAAAA,IAAC+C,EAAAA,cAAA,CAAA,CAAc,EACjB,EACA/C,EAAAA,IAAClB,EAAA,CACC,aAAAC,EACA,UAAAC,CAAA,CAAA,CACF,CAAA,CACF,EACF,CAAA,CACF,CAAA,CAAA,CACF,CAAA,CAAA,EAEJ,CAEJ,EAEA2C,EAAgB,YAAc"}
1
+ {"version":3,"file":"date-range-picker-4mZ19UM7.cjs.js","sources":["../../src/components/date-range-picker/date-range-picker.slots.tsx","../../src/components/date-range-picker/components/date-range-picker.time-input.tsx","../../src/components/date-range-picker/components/date-range-picker.custom-context.tsx","../../src/components/date-range-picker/date-range-picker.tsx"],"sourcesContent":["import {\n type HTMLChakraProps,\n type RecipeProps,\n type UnstyledProp,\n createSlotRecipeContext,\n} from \"@chakra-ui/react/styled-system\";\n\nimport { dateRangePickerSlotRecipe } from \"./date-range-picker.recipe\";\n\n/**\n * Base recipe props interface that combines Chakra UI's recipe props\n * with the unstyled prop option for the div element.\n */\ninterface DateRangePickerRecipeProps extends RecipeProps<\"div\">, UnstyledProp {}\n\n/**\n * Root props interface that extends Chakra's HTML props with our recipe props.\n * This creates a complete set of props for the root element, combining\n * HTML attributes, Chakra's styling system, and our custom recipe props.\n */\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface DateRangePickerRootProps\n extends HTMLChakraProps<\"div\", DateRangePickerRecipeProps> {}\n\n// Correctly destructure from createSlotRecipeContext based on project examples\nconst { withProvider, withContext } = createSlotRecipeContext({\n recipe: dateRangePickerSlotRecipe,\n});\n\n/**\n * Root component that provides the styling context for the DateRangePicker component.\n * Uses Chakra UI's recipe context system for consistent styling across instances.\n */\nexport const DateRangePickerRootSlot = withProvider<\n HTMLDivElement,\n DateRangePickerRootProps\n>(\"div\", \"root\");\n\n/**\n * Slot component for the input group containing the DateInput and trigger button.\n */\nexport const DateRangePickerGroupSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"group\");\n\n/**\n * Slot component for the trigger button that opens the calendar popover.\n */\nexport const DateRangePickerTriggerSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"trigger\");\n\n/**\n * Slot component for the popover container.\n */\nexport const DateRangePickerPopoverSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"popover\");\n\n/**\n * Slot component for the calendar container within the popover.\n */\nexport const DateRangePickerCalendarSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"calendar\");\n\n/**\n * Slot component for the calendar header.\n */\nexport const DateRangePickerCalendarHeaderSlot = withContext<\n HTMLElement,\n HTMLChakraProps<\"header\">\n>(\"header\", \"calendarHeader\");\n\n/**\n * Slot component for the calendar grid.\n */\nexport const DateRangePickerCalendarGridSlot = withContext<\n HTMLTableElement,\n HTMLChakraProps<\"table\">\n>(\"table\", \"calendarGrid\");\n\n/**\n * Slot component for individual calendar cells.\n */\nexport const DateRangePickerCalendarCellSlot = withContext<\n HTMLTableCellElement,\n HTMLChakraProps<\"td\">\n>(\"td\", \"calendarCell\");\n","import { Flex, Text, TimeInput } from \"@/components\";\nimport { useContext, useRef, useEffect } from \"react\";\nimport { DateRangePickerStateContext } from \"react-aria-components\";\nimport type { DateRangePickerTimeInputProps } from \"../date-range-picker.types\";\n\nexport const DateRangePickerTimeInput = ({\n hideTimeZone,\n hourCycle,\n}: DateRangePickerTimeInputProps) => {\n const dateRangePickerState = useContext(DateRangePickerStateContext);\n const { granularity, value } = dateRangePickerState!;\n const timeInputRef = useRef<HTMLDivElement>(null);\n const previousValueRef = useRef(value);\n\n // do not show up to the party if you're not invited\n if (granularity === \"day\") {\n return null;\n }\n\n // Focus the time input when date range changes (user selects dates from calendar)\n useEffect(() => {\n let timeoutId: ReturnType<typeof setTimeout> | undefined;\n\n // Check if date range changed by comparing start and end dates\n const hasValueChanged =\n (value?.start &&\n previousValueRef.current?.start?.compare(value.start) !== 0) ||\n (value?.end && previousValueRef.current?.end?.compare(value.end) !== 0);\n\n if (hasValueChanged) {\n // Only auto-focus if no time input segment currently has focus\n // This prevents stealing focus during user interaction with time segments\n const container = timeInputRef.current;\n const activeElement = document.activeElement;\n const hasTimeSegmentFocus =\n container?.contains(activeElement) &&\n activeElement?.getAttribute(\"role\") === \"spinbutton\";\n\n if (!hasTimeSegmentFocus) {\n // Small delay to ensure the DOM is ready\n timeoutId = setTimeout(() => {\n // Find the first focusable segment within the time input container\n if (container) {\n const firstSegment = container.querySelector(\n '[role=\"spinbutton\"]'\n ) as HTMLElement;\n\n if (firstSegment) {\n firstSegment.focus();\n }\n }\n }, 50);\n }\n }\n\n previousValueRef.current = value;\n\n // Cleanup timeout on effect re-run or unmount to prevent memory leaks\n return () => {\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n };\n }, [value]);\n\n return (\n <Flex\n ref={timeInputRef}\n borderTop=\"solid-25\"\n borderColor=\"neutral.3\"\n py=\"300\"\n px=\"400\"\n alignItems=\"center\"\n justifyContent=\"center\"\n gap=\"200\"\n >\n {/* Start DateInput with separate label */}\n <Flex alignItems=\"center\" gap=\"200\">\n {/* TODO: translate hardcoded string */}\n <Text\n textStyle=\"xs\"\n fontWeight=\"500\"\n color=\"neutral.12\"\n minWidth=\"fit-content\"\n >\n Start time\n </Text>\n <TimeInput\n slot=\"startTimeInput\"\n variant=\"ghost\"\n size=\"sm\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Flex>\n\n {/* End DateInput with separate label */}\n <Flex alignItems=\"center\" gap=\"200\">\n {/* TODO: translate hardcoded string */}\n <Text\n textStyle=\"xs\"\n fontWeight=\"500\"\n color=\"neutral.12\"\n minWidth=\"fit-content\"\n >\n End time\n </Text>\n <TimeInput\n slot=\"endTimeInput\"\n variant=\"ghost\"\n size=\"sm\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Flex>\n </Flex>\n );\n};\n","import { useContext, type ReactNode } from \"react\";\nimport {\n Provider,\n ButtonContext,\n DateRangePickerStateContext,\n TimeFieldContext,\n useSlottedContext,\n} from \"react-aria-components\";\nimport type { PressEvent, TimeValue } from \"react-aria\";\n\nexport const DateRangePickerCustomContext = ({\n children,\n}: {\n children: ReactNode;\n}) => {\n const buttonContext = useSlottedContext(ButtonContext) || {};\n const dateRangePickerState = useContext(DateRangePickerStateContext);\n\n // Check if all 6 segments (start: day, month, year; end: day, month, year) have values\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const hasCompleteRangeDate = (date: any) =>\n date?.day && date?.month && date?.year;\n\n const incompleteValue =\n !dateRangePickerState?.value ||\n !hasCompleteRangeDate(dateRangePickerState.value.start) ||\n !hasCompleteRangeDate(dateRangePickerState.value.end);\n\n const { granularity } = dateRangePickerState!;\n\n // Extract time values from start and end dates separately\n const startTimeValue =\n dateRangePickerState?.value?.start &&\n \"hour\" in dateRangePickerState.value.start\n ? dateRangePickerState.value.start\n : null;\n const endTimeValue =\n dateRangePickerState?.value?.end && \"hour\" in dateRangePickerState.value.end\n ? dateRangePickerState.value.end\n : null;\n\n // Try to get disabled state from the button context\n const isDateRangePickerDisabled = buttonContext?.isDisabled;\n\n // Generate default aria-label based on granularity if not provided\n const getDefaultTimeInputAriaLabel = (type: \"start\" | \"end\") => {\n const prefix = type === \"start\" ? \"Start\" : \"End\";\n switch (granularity) {\n case \"hour\":\n return `${prefix} time (hour)`;\n case \"minute\":\n return `${prefix} time (hour and minute)`;\n case \"second\":\n return `${prefix} time (hour, minute, and second)`;\n default:\n return `${prefix} time`;\n }\n };\n\n /**\n * Button slots\n * ================================\n */\n const buttonSlots = {\n /** toggles the calendar popover */\n calendarToggle: {\n ...buttonContext,\n onPress: (event: PressEvent) => {\n // Ensure any active input (e.g., date picker segment) loses focus\n // because blurring the input will close the popover if it's open (or was just opened)\n const activeElement = document?.activeElement as HTMLElement | null;\n\n if (activeElement) {\n activeElement.blur();\n }\n\n buttonContext.onPress?.(event);\n },\n },\n /** Clear button that displays when there's a value in each segment - hidden from both visual and screen readers when there's no value */\n clear: {\n // Clear both start and end values\n onPress: () => dateRangePickerState?.setValue(null),\n \"aria-label\": \"Clear input value\",\n isDisabled: isDateRangePickerDisabled,\n // Hide the button when there's no value\n style: incompleteValue ? { display: \"none\" } : undefined,\n \"aria-hidden\": incompleteValue ? true : undefined,\n },\n };\n\n /**\n * TimeInput slots\n * ================================\n */\n\n // Separate time input slots for start and end times\n const timeInputSlots = {\n startTimeInput: {\n value: startTimeValue,\n onChange: (value: TimeValue | null) => {\n if (value !== null && dateRangePickerState?.value?.start) {\n // Update the start date with the new time\n const currentValue = dateRangePickerState.value;\n const startDate = currentValue.start;\n const endDate = currentValue.end;\n if (startDate && endDate) {\n const newStartDate = startDate.set({\n hour: value.hour,\n minute: value.minute || 0,\n second: value.second || 0,\n millisecond: value.millisecond || 0,\n });\n\n dateRangePickerState.setValue({\n start: newStartDate,\n end: endDate,\n });\n }\n }\n },\n granularity: granularity === \"day\" ? undefined : granularity,\n \"aria-label\": getDefaultTimeInputAriaLabel(\"start\"),\n },\n endTimeInput: {\n value: endTimeValue,\n onChange: (value: TimeValue | null) => {\n if (value !== null && dateRangePickerState?.value?.end) {\n // Update the end date with the new time\n const currentValue = dateRangePickerState.value;\n const startDate = currentValue.start;\n const endDate = currentValue.end;\n if (startDate && endDate) {\n const newEndDate = endDate.set({\n hour: value.hour,\n minute: value.minute || 0,\n second: value.second || 0,\n millisecond: value.millisecond || 0,\n });\n\n dateRangePickerState.setValue({\n start: startDate,\n end: newEndDate,\n });\n }\n }\n },\n granularity: granularity === \"day\" ? undefined : granularity,\n \"aria-label\": getDefaultTimeInputAriaLabel(\"end\"),\n },\n };\n\n return (\n <Provider\n values={[\n [\n ButtonContext,\n {\n slots: buttonSlots,\n },\n ],\n [TimeFieldContext, { slots: timeInputSlots }],\n ]}\n >\n {children}\n </Provider>\n );\n};\n","import {\n DateRangePickerRootSlot,\n DateRangePickerGroupSlot,\n DateRangePickerTriggerSlot,\n DateRangePickerPopoverSlot,\n DateRangePickerCalendarSlot,\n} from \"./date-range-picker.slots\";\n\nimport { CalendarMonth, Close } from \"@commercetools/nimbus-icons\";\n\nimport {\n DateRangePicker as ReactAriaDateRangePicker,\n Group,\n Popover,\n Dialog,\n} from \"react-aria-components\";\nimport { useSlotRecipe } from \"@chakra-ui/react/styled-system\";\nimport { dateRangePickerSlotRecipe } from \"./date-range-picker.recipe\";\nimport type { DateRangePickerProps } from \"./date-range-picker.types\";\nimport { extractStyleProps } from \"@/utils/extractStyleProps\";\nimport { DateInput, RangeCalendar, IconButton, Text } from \"@/components\";\nimport { DateRangePickerTimeInput } from \"./components/date-range-picker.time-input\";\nimport { DateRangePickerCustomContext } from \"./components/date-range-picker.custom-context\";\n\n/**\n * DateRangePicker\n * ============================================================\n * Combines a DateInput with a RangeCalendar popover for date range selection.\n * Users can either type a date range directly or select from the calendar.\n */\nexport const DateRangePicker = (props: DateRangePickerProps) => {\n // Forward hideTimeZone and hourCycle to child components (footer time inputs)\n const { granularity = \"day\", hideTimeZone, hourCycle } = props;\n const recipe = useSlotRecipe({ recipe: dateRangePickerSlotRecipe });\n const [recipeProps, remainingProps] = recipe.splitVariantProps(props);\n\n const [styleProps, otherProps] = extractStyleProps(remainingProps);\n\n // Extract size and variant from recipe props to pass to DateInputs\n const { size = \"md\" } = recipeProps;\n\n // the size of the buttons overlaying the input\n const overlayButtonSize = size === \"md\" ? \"xs\" : \"2xs\";\n\n // When granularity is \"day\", use the prop value (defaults to true if not provided)\n // For other granularities (time-based), force to false so users can set both date and time\n const shouldCloseOnSelect =\n granularity === \"day\" ? props.shouldCloseOnSelect : false;\n\n return (\n <DateRangePickerRootSlot {...recipeProps} {...styleProps} asChild>\n <ReactAriaDateRangePicker\n {...otherProps}\n shouldCloseOnSelect={shouldCloseOnSelect}\n >\n <DateRangePickerCustomContext>\n <DateRangePickerGroupSlot asChild>\n <Group>\n <DateInput\n slot=\"start\"\n size={size}\n variant=\"plain\"\n width=\"auto\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n <Text\n as=\"span\"\n px=\"150\"\n color=\"neutral.11\"\n userSelect=\"none\"\n aria-hidden=\"true\"\n slot={null}\n >\n –\n </Text>\n <DateInput\n slot=\"end\"\n size={size}\n variant=\"plain\"\n width=\"auto\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n <DateRangePickerTriggerSlot>\n {/* @ts-expect-error react aria is adding the aria-label prop */}\n <IconButton\n tone=\"primary\"\n variant=\"ghost\"\n size={overlayButtonSize}\n slot=\"clear\"\n >\n <Close />\n </IconButton>\n {/* @ts-expect-error react aria is adding the aria-label prop */}\n <IconButton\n tone=\"primary\"\n variant=\"ghost\"\n size={overlayButtonSize}\n slot=\"calendarToggle\"\n >\n <CalendarMonth />\n </IconButton>\n </DateRangePickerTriggerSlot>\n </Group>\n </DateRangePickerGroupSlot>\n <DateRangePickerPopoverSlot asChild>\n <Popover placement=\"bottom end\">\n <Dialog>\n <DateRangePickerCalendarSlot>\n <RangeCalendar />\n </DateRangePickerCalendarSlot>\n <DateRangePickerTimeInput\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Dialog>\n </Popover>\n </DateRangePickerPopoverSlot>\n </DateRangePickerCustomContext>\n </ReactAriaDateRangePicker>\n </DateRangePickerRootSlot>\n );\n};\n\nDateRangePicker.displayName = \"DateRangePicker\";\n"],"names":["withProvider","withContext","createSlotRecipeContext","dateRangePickerSlotRecipe","DateRangePickerRootSlot","DateRangePickerGroupSlot","DateRangePickerTriggerSlot","DateRangePickerPopoverSlot","DateRangePickerCalendarSlot","DateRangePickerTimeInput","hideTimeZone","hourCycle","dateRangePickerState","useContext","DateRangePickerStateContext","granularity","value","timeInputRef","useRef","previousValueRef","useEffect","timeoutId","container","activeElement","firstSegment","jsxs","Flex","jsx","Text","TimeInput","DateRangePickerCustomContext","children","buttonContext","useSlottedContext","ButtonContext","hasCompleteRangeDate","date","incompleteValue","startTimeValue","endTimeValue","isDateRangePickerDisabled","getDefaultTimeInputAriaLabel","type","prefix","buttonSlots","event","timeInputSlots","currentValue","startDate","endDate","newStartDate","newEndDate","Provider","TimeFieldContext","DateRangePicker","props","recipe","useSlotRecipe","recipeProps","remainingProps","styleProps","otherProps","extractStyleProps","size","overlayButtonSize","shouldCloseOnSelect","ReactAriaDateRangePicker","Group","DateInput","IconButton","Close","CalendarMonth","Popover","Dialog","RangeCalendar"],"mappings":"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"}
@@ -1,29 +1,29 @@
1
1
  import { jsxs as p, jsx as n } from "react/jsx-runtime";
2
2
  import { createSlotRecipeContext as V, useSlotRecipe as E } from "@chakra-ui/react/styled-system";
3
- import { f as T } from "./index-C7AV1c1_.es.js";
3
+ import { f as T } from "./index-DRb2wMPi.es.js";
4
4
  import { Close as w, CalendarMonth as z } from "@commercetools/nimbus-icons";
5
- import { $ as I, a as W } from "./DatePicker-UdS55fqN.es.js";
6
- import { $ as j, a as F } from "./Dialog-C_Lr_ZUo.es.js";
7
- import { $ as A } from "./Group-DUCWhg7j.es.js";
8
- import { e as B } from "./extractStyleProps-D6kxUL-O.es.js";
9
- import { I as y } from "./icon-button-CwG0NBaY.es.js";
10
- import { T as S } from "./text-Bi4Gre95.es.js";
11
- import { D as C } from "./date-input-KbMioTti.es.js";
12
- import { R as G } from "./range-calendar-BQsO9nZw.es.js";
13
- import { T as D } from "./time-input-CGwOrAf4.es.js";
14
- import { useContext as k, useRef as P, useEffect as O } from "react";
5
+ import { $ as I, a as W } from "./DatePicker-DOq_YUYb.es.js";
6
+ import { $ as j, a as F } from "./Dialog-BgV9Ur8E.es.js";
7
+ import { $ as A } from "./Group-DI0poa1g.es.js";
8
+ import { e as B } from "./extractStyleProps-i_um9deg.es.js";
9
+ import { useContext as k, useRef as y, useEffect as G } from "react";
15
10
  import { Flex as x } from "@chakra-ui/react/flex";
16
- import { $ as R } from "./Button-BVaauB-c.es.js";
17
- import { c as q, d as H } from "./utils-CsKCu3xh.es.js";
18
- import { d as L } from "./DateField-CoKm-f2B.es.js";
11
+ import { T as S } from "./text-05SUCJIk.es.js";
12
+ import { T as C } from "./time-input-BPMoY1TY.es.js";
13
+ import { $ as D } from "./Button-B6xR_FqM.es.js";
14
+ import { c as O, d as q } from "./utils-DkbE8ciF.es.js";
15
+ import { d as H } from "./DateField-ilC6DQcU.es.js";
16
+ import { R as L } from "./range-calendar-DFb9bsJ4.es.js";
17
+ import { D as P } from "./date-input-BS7NT0zS.es.js";
18
+ import { I as R } from "./icon-button-_9swBHc3.es.js";
19
19
  const { withProvider: M, withContext: $ } = /* @__PURE__ */ V({
20
20
  recipe: T
21
21
  }), N = /* @__PURE__ */ M("div", "root"), J = /* @__PURE__ */ $("div", "group"), K = /* @__PURE__ */ $("div", "trigger"), Q = /* @__PURE__ */ $("div", "popover"), U = /* @__PURE__ */ $("div", "calendar"), X = ({
22
22
  hideTimeZone: s,
23
23
  hourCycle: l
24
24
  }) => {
25
- const e = k(I), { granularity: c, value: a } = e, o = P(null), d = P(a);
26
- return c === "day" ? null : (O(() => {
25
+ const e = k(I), { granularity: c, value: a } = e, o = y(null), d = y(a);
26
+ return c === "day" ? null : (G(() => {
27
27
  let u;
28
28
  if (a?.start && d.current?.start?.compare(a.start) !== 0 || a?.end && d.current?.end?.compare(a.end) !== 0) {
29
29
  const i = o.current, m = document.activeElement;
@@ -63,7 +63,7 @@ const { withProvider: M, withContext: $ } = /* @__PURE__ */ V({
63
63
  }
64
64
  ),
65
65
  /* @__PURE__ */ n(
66
- D,
66
+ C,
67
67
  {
68
68
  slot: "startTimeInput",
69
69
  variant: "ghost",
@@ -85,7 +85,7 @@ const { withProvider: M, withContext: $ } = /* @__PURE__ */ V({
85
85
  }
86
86
  ),
87
87
  /* @__PURE__ */ n(
88
- D,
88
+ C,
89
89
  {
90
90
  slot: "endTimeInput",
91
91
  variant: "ghost",
@@ -101,7 +101,7 @@ const { withProvider: M, withContext: $ } = /* @__PURE__ */ V({
101
101
  }, Y = ({
102
102
  children: s
103
103
  }) => {
104
- const l = q(R) || {}, e = k(I), c = (t) => t?.day && t?.month && t?.year, a = !e?.value || !c(e.value.start) || !c(e.value.end), { granularity: o } = e, d = e?.value?.start && "hour" in e.value.start ? e.value.start : null, u = e?.value?.end && "hour" in e.value.end ? e.value.end : null, g = l?.isDisabled, i = (t) => {
104
+ const l = O(D) || {}, e = k(I), c = (t) => t?.day && t?.month && t?.year, a = !e?.value || !c(e.value.start) || !c(e.value.end), { granularity: o } = e, d = e?.value?.start && "hour" in e.value.start ? e.value.start : null, u = e?.value?.end && "hour" in e.value.end ? e.value.end : null, g = l?.isDisabled, i = (t) => {
105
105
  const r = t === "start" ? "Start" : "End";
106
106
  switch (o) {
107
107
  case "hour":
@@ -179,16 +179,16 @@ const { withProvider: M, withContext: $ } = /* @__PURE__ */ V({
179
179
  }
180
180
  };
181
181
  return /* @__PURE__ */ n(
182
- H,
182
+ q,
183
183
  {
184
184
  values: [
185
185
  [
186
- R,
186
+ D,
187
187
  {
188
188
  slots: m
189
189
  }
190
190
  ],
191
- [L, { slots: b }]
191
+ [H, { slots: b }]
192
192
  ],
193
193
  children: s
194
194
  }
@@ -203,7 +203,7 @@ const { withProvider: M, withContext: $ } = /* @__PURE__ */ V({
203
203
  children: /* @__PURE__ */ p(Y, { children: [
204
204
  /* @__PURE__ */ n(J, { asChild: !0, children: /* @__PURE__ */ p(A, { children: [
205
205
  /* @__PURE__ */ n(
206
- C,
206
+ P,
207
207
  {
208
208
  slot: "start",
209
209
  size: i,
@@ -226,7 +226,7 @@ const { withProvider: M, withContext: $ } = /* @__PURE__ */ V({
226
226
  }
227
227
  ),
228
228
  /* @__PURE__ */ n(
229
- C,
229
+ P,
230
230
  {
231
231
  slot: "end",
232
232
  size: i,
@@ -238,7 +238,7 @@ const { withProvider: M, withContext: $ } = /* @__PURE__ */ V({
238
238
  ),
239
239
  /* @__PURE__ */ p(K, { children: [
240
240
  /* @__PURE__ */ n(
241
- y,
241
+ R,
242
242
  {
243
243
  tone: "primary",
244
244
  variant: "ghost",
@@ -248,7 +248,7 @@ const { withProvider: M, withContext: $ } = /* @__PURE__ */ V({
248
248
  }
249
249
  ),
250
250
  /* @__PURE__ */ n(
251
- y,
251
+ R,
252
252
  {
253
253
  tone: "primary",
254
254
  variant: "ghost",
@@ -260,7 +260,7 @@ const { withProvider: M, withContext: $ } = /* @__PURE__ */ V({
260
260
  ] })
261
261
  ] }) }),
262
262
  /* @__PURE__ */ n(Q, { asChild: !0, children: /* @__PURE__ */ n(j, { placement: "bottom end", children: /* @__PURE__ */ p(F, { children: [
263
- /* @__PURE__ */ n(U, { children: /* @__PURE__ */ n(G, {}) }),
263
+ /* @__PURE__ */ n(U, { children: /* @__PURE__ */ n(L, {}) }),
264
264
  /* @__PURE__ */ n(
265
265
  X,
266
266
  {
@@ -277,4 +277,4 @@ Z.displayName = "DateRangePicker";
277
277
  export {
278
278
  Z as D
279
279
  };
280
- //# sourceMappingURL=date-range-picker-BEk9kT2e.es.js.map
280
+ //# sourceMappingURL=date-range-picker-DelR30zw.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"date-range-picker-BEk9kT2e.es.js","sources":["../../src/components/date-range-picker/date-range-picker.slots.tsx","../../src/components/date-range-picker/components/date-range-picker.time-input.tsx","../../src/components/date-range-picker/components/date-range-picker.custom-context.tsx","../../src/components/date-range-picker/date-range-picker.tsx"],"sourcesContent":["import {\n type HTMLChakraProps,\n type RecipeProps,\n type UnstyledProp,\n createSlotRecipeContext,\n} from \"@chakra-ui/react/styled-system\";\n\nimport { dateRangePickerSlotRecipe } from \"./date-range-picker.recipe\";\n\n/**\n * Base recipe props interface that combines Chakra UI's recipe props\n * with the unstyled prop option for the div element.\n */\ninterface DateRangePickerRecipeProps extends RecipeProps<\"div\">, UnstyledProp {}\n\n/**\n * Root props interface that extends Chakra's HTML props with our recipe props.\n * This creates a complete set of props for the root element, combining\n * HTML attributes, Chakra's styling system, and our custom recipe props.\n */\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface DateRangePickerRootProps\n extends HTMLChakraProps<\"div\", DateRangePickerRecipeProps> {}\n\n// Correctly destructure from createSlotRecipeContext based on project examples\nconst { withProvider, withContext } = createSlotRecipeContext({\n recipe: dateRangePickerSlotRecipe,\n});\n\n/**\n * Root component that provides the styling context for the DateRangePicker component.\n * Uses Chakra UI's recipe context system for consistent styling across instances.\n */\nexport const DateRangePickerRootSlot = withProvider<\n HTMLDivElement,\n DateRangePickerRootProps\n>(\"div\", \"root\");\n\n/**\n * Slot component for the input group containing the DateInput and trigger button.\n */\nexport const DateRangePickerGroupSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"group\");\n\n/**\n * Slot component for the trigger button that opens the calendar popover.\n */\nexport const DateRangePickerTriggerSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"trigger\");\n\n/**\n * Slot component for the popover container.\n */\nexport const DateRangePickerPopoverSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"popover\");\n\n/**\n * Slot component for the calendar container within the popover.\n */\nexport const DateRangePickerCalendarSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"calendar\");\n\n/**\n * Slot component for the calendar header.\n */\nexport const DateRangePickerCalendarHeaderSlot = withContext<\n HTMLElement,\n HTMLChakraProps<\"header\">\n>(\"header\", \"calendarHeader\");\n\n/**\n * Slot component for the calendar grid.\n */\nexport const DateRangePickerCalendarGridSlot = withContext<\n HTMLTableElement,\n HTMLChakraProps<\"table\">\n>(\"table\", \"calendarGrid\");\n\n/**\n * Slot component for individual calendar cells.\n */\nexport const DateRangePickerCalendarCellSlot = withContext<\n HTMLTableCellElement,\n HTMLChakraProps<\"td\">\n>(\"td\", \"calendarCell\");\n","import { Flex, Text, TimeInput } from \"@/components\";\nimport { useContext, useRef, useEffect } from \"react\";\nimport { DateRangePickerStateContext } from \"react-aria-components\";\nimport type { DateRangePickerTimeInputProps } from \"../date-range-picker.types\";\n\nexport const DateRangePickerTimeInput = ({\n hideTimeZone,\n hourCycle,\n}: DateRangePickerTimeInputProps) => {\n const dateRangePickerState = useContext(DateRangePickerStateContext);\n const { granularity, value } = dateRangePickerState!;\n const timeInputRef = useRef<HTMLDivElement>(null);\n const previousValueRef = useRef(value);\n\n // do not show up to the party if you're not invited\n if (granularity === \"day\") {\n return null;\n }\n\n // Focus the time input when date range changes (user selects dates from calendar)\n useEffect(() => {\n let timeoutId: ReturnType<typeof setTimeout> | undefined;\n\n // Check if date range changed by comparing start and end dates\n const hasValueChanged =\n (value?.start &&\n previousValueRef.current?.start?.compare(value.start) !== 0) ||\n (value?.end && previousValueRef.current?.end?.compare(value.end) !== 0);\n\n if (hasValueChanged) {\n // Only auto-focus if no time input segment currently has focus\n // This prevents stealing focus during user interaction with time segments\n const container = timeInputRef.current;\n const activeElement = document.activeElement;\n const hasTimeSegmentFocus =\n container?.contains(activeElement) &&\n activeElement?.getAttribute(\"role\") === \"spinbutton\";\n\n if (!hasTimeSegmentFocus) {\n // Small delay to ensure the DOM is ready\n timeoutId = setTimeout(() => {\n // Find the first focusable segment within the time input container\n if (container) {\n const firstSegment = container.querySelector(\n '[role=\"spinbutton\"]'\n ) as HTMLElement;\n\n if (firstSegment) {\n firstSegment.focus();\n }\n }\n }, 50);\n }\n }\n\n previousValueRef.current = value;\n\n // Cleanup timeout on effect re-run or unmount to prevent memory leaks\n return () => {\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n };\n }, [value]);\n\n return (\n <Flex\n ref={timeInputRef}\n borderTop=\"solid-25\"\n borderColor=\"neutral.3\"\n py=\"300\"\n px=\"400\"\n alignItems=\"center\"\n justifyContent=\"center\"\n gap=\"200\"\n >\n {/* Start DateInput with separate label */}\n <Flex alignItems=\"center\" gap=\"200\">\n {/* TODO: translate hardcoded string */}\n <Text\n textStyle=\"xs\"\n fontWeight=\"500\"\n color=\"neutral.12\"\n minWidth=\"fit-content\"\n >\n Start time\n </Text>\n <TimeInput\n slot=\"startTimeInput\"\n variant=\"ghost\"\n size=\"sm\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Flex>\n\n {/* End DateInput with separate label */}\n <Flex alignItems=\"center\" gap=\"200\">\n {/* TODO: translate hardcoded string */}\n <Text\n textStyle=\"xs\"\n fontWeight=\"500\"\n color=\"neutral.12\"\n minWidth=\"fit-content\"\n >\n End time\n </Text>\n <TimeInput\n slot=\"endTimeInput\"\n variant=\"ghost\"\n size=\"sm\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Flex>\n </Flex>\n );\n};\n","import { useContext, type ReactNode } from \"react\";\nimport {\n Provider,\n ButtonContext,\n DateRangePickerStateContext,\n TimeFieldContext,\n useSlottedContext,\n} from \"react-aria-components\";\nimport type { PressEvent, TimeValue } from \"react-aria\";\n\nexport const DateRangePickerCustomContext = ({\n children,\n}: {\n children: ReactNode;\n}) => {\n const buttonContext = useSlottedContext(ButtonContext) || {};\n const dateRangePickerState = useContext(DateRangePickerStateContext);\n\n // Check if all 6 segments (start: day, month, year; end: day, month, year) have values\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const hasCompleteRangeDate = (date: any) =>\n date?.day && date?.month && date?.year;\n\n const incompleteValue =\n !dateRangePickerState?.value ||\n !hasCompleteRangeDate(dateRangePickerState.value.start) ||\n !hasCompleteRangeDate(dateRangePickerState.value.end);\n\n const { granularity } = dateRangePickerState!;\n\n // Extract time values from start and end dates separately\n const startTimeValue =\n dateRangePickerState?.value?.start &&\n \"hour\" in dateRangePickerState.value.start\n ? dateRangePickerState.value.start\n : null;\n const endTimeValue =\n dateRangePickerState?.value?.end && \"hour\" in dateRangePickerState.value.end\n ? dateRangePickerState.value.end\n : null;\n\n // Try to get disabled state from the button context\n const isDateRangePickerDisabled = buttonContext?.isDisabled;\n\n // Generate default aria-label based on granularity if not provided\n const getDefaultTimeInputAriaLabel = (type: \"start\" | \"end\") => {\n const prefix = type === \"start\" ? \"Start\" : \"End\";\n switch (granularity) {\n case \"hour\":\n return `${prefix} time (hour)`;\n case \"minute\":\n return `${prefix} time (hour and minute)`;\n case \"second\":\n return `${prefix} time (hour, minute, and second)`;\n default:\n return `${prefix} time`;\n }\n };\n\n /**\n * Button slots\n * ================================\n */\n const buttonSlots = {\n /** toggles the calendar popover */\n calendarToggle: {\n ...buttonContext,\n onPress: (event: PressEvent) => {\n // Ensure any active input (e.g., date picker segment) loses focus\n // because blurring the input will close the popover if it's open (or was just opened)\n const activeElement = document?.activeElement as HTMLElement | null;\n\n if (activeElement) {\n activeElement.blur();\n }\n\n buttonContext.onPress?.(event);\n },\n },\n /** Clear button that displays when there's a value in each segment - hidden from both visual and screen readers when there's no value */\n clear: {\n // Clear both start and end values\n onPress: () => dateRangePickerState?.setValue(null),\n \"aria-label\": \"Clear input value\",\n isDisabled: isDateRangePickerDisabled,\n // Hide the button when there's no value\n style: incompleteValue ? { display: \"none\" } : undefined,\n \"aria-hidden\": incompleteValue ? true : undefined,\n },\n };\n\n /**\n * TimeInput slots\n * ================================\n */\n\n // Separate time input slots for start and end times\n const timeInputSlots = {\n startTimeInput: {\n value: startTimeValue,\n onChange: (value: TimeValue | null) => {\n if (value !== null && dateRangePickerState?.value?.start) {\n // Update the start date with the new time\n const currentValue = dateRangePickerState.value;\n const startDate = currentValue.start;\n const endDate = currentValue.end;\n if (startDate && endDate) {\n const newStartDate = startDate.set({\n hour: value.hour,\n minute: value.minute || 0,\n second: value.second || 0,\n millisecond: value.millisecond || 0,\n });\n\n dateRangePickerState.setValue({\n start: newStartDate,\n end: endDate,\n });\n }\n }\n },\n granularity: granularity === \"day\" ? undefined : granularity,\n \"aria-label\": getDefaultTimeInputAriaLabel(\"start\"),\n },\n endTimeInput: {\n value: endTimeValue,\n onChange: (value: TimeValue | null) => {\n if (value !== null && dateRangePickerState?.value?.end) {\n // Update the end date with the new time\n const currentValue = dateRangePickerState.value;\n const startDate = currentValue.start;\n const endDate = currentValue.end;\n if (startDate && endDate) {\n const newEndDate = endDate.set({\n hour: value.hour,\n minute: value.minute || 0,\n second: value.second || 0,\n millisecond: value.millisecond || 0,\n });\n\n dateRangePickerState.setValue({\n start: startDate,\n end: newEndDate,\n });\n }\n }\n },\n granularity: granularity === \"day\" ? undefined : granularity,\n \"aria-label\": getDefaultTimeInputAriaLabel(\"end\"),\n },\n };\n\n return (\n <Provider\n values={[\n [\n ButtonContext,\n {\n slots: buttonSlots,\n },\n ],\n [TimeFieldContext, { slots: timeInputSlots }],\n ]}\n >\n {children}\n </Provider>\n );\n};\n","import {\n DateRangePickerRootSlot,\n DateRangePickerGroupSlot,\n DateRangePickerTriggerSlot,\n DateRangePickerPopoverSlot,\n DateRangePickerCalendarSlot,\n} from \"./date-range-picker.slots\";\n\nimport { CalendarMonth, Close } from \"@commercetools/nimbus-icons\";\n\nimport {\n DateRangePicker as ReactAriaDateRangePicker,\n Group,\n Popover,\n Dialog,\n} from \"react-aria-components\";\nimport { useSlotRecipe } from \"@chakra-ui/react/styled-system\";\nimport { dateRangePickerSlotRecipe } from \"./date-range-picker.recipe\";\nimport type { DateRangePickerProps } from \"./date-range-picker.types\";\nimport { extractStyleProps } from \"@/utils/extractStyleProps\";\nimport { DateInput, RangeCalendar, IconButton, Text } from \"@/components\";\nimport { DateRangePickerTimeInput } from \"./components/date-range-picker.time-input\";\nimport { DateRangePickerCustomContext } from \"./components/date-range-picker.custom-context\";\n\n/**\n * DateRangePicker\n * ============================================================\n * Combines a DateInput with a RangeCalendar popover for date range selection.\n * Users can either type a date range directly or select from the calendar.\n */\nexport const DateRangePicker = (props: DateRangePickerProps) => {\n // Forward hideTimeZone and hourCycle to child components (footer time inputs)\n const { granularity = \"day\", hideTimeZone, hourCycle } = props;\n const recipe = useSlotRecipe({ recipe: dateRangePickerSlotRecipe });\n const [recipeProps, remainingProps] = recipe.splitVariantProps(props);\n\n const [styleProps, otherProps] = extractStyleProps(remainingProps);\n\n // Extract size and variant from recipe props to pass to DateInputs\n const { size = \"md\" } = recipeProps;\n\n // the size of the buttons overlaying the input\n const overlayButtonSize = size === \"md\" ? \"xs\" : \"2xs\";\n\n // When granularity is \"day\", use the prop value (defaults to true if not provided)\n // For other granularities (time-based), force to false so users can set both date and time\n const shouldCloseOnSelect =\n granularity === \"day\" ? props.shouldCloseOnSelect : false;\n\n return (\n <DateRangePickerRootSlot {...recipeProps} {...styleProps} asChild>\n <ReactAriaDateRangePicker\n {...otherProps}\n shouldCloseOnSelect={shouldCloseOnSelect}\n >\n <DateRangePickerCustomContext>\n <DateRangePickerGroupSlot asChild>\n <Group>\n <DateInput\n slot=\"start\"\n size={size}\n variant=\"plain\"\n width=\"auto\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n <Text\n as=\"span\"\n px=\"150\"\n color=\"neutral.11\"\n userSelect=\"none\"\n aria-hidden=\"true\"\n slot={null}\n >\n –\n </Text>\n <DateInput\n slot=\"end\"\n size={size}\n variant=\"plain\"\n width=\"auto\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n <DateRangePickerTriggerSlot>\n {/* @ts-expect-error react aria is adding the aria-label prop */}\n <IconButton\n tone=\"primary\"\n variant=\"ghost\"\n size={overlayButtonSize}\n slot=\"clear\"\n >\n <Close />\n </IconButton>\n {/* @ts-expect-error react aria is adding the aria-label prop */}\n <IconButton\n tone=\"primary\"\n variant=\"ghost\"\n size={overlayButtonSize}\n slot=\"calendarToggle\"\n >\n <CalendarMonth />\n </IconButton>\n </DateRangePickerTriggerSlot>\n </Group>\n </DateRangePickerGroupSlot>\n <DateRangePickerPopoverSlot asChild>\n <Popover placement=\"bottom end\">\n <Dialog>\n <DateRangePickerCalendarSlot>\n <RangeCalendar />\n </DateRangePickerCalendarSlot>\n <DateRangePickerTimeInput\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Dialog>\n </Popover>\n </DateRangePickerPopoverSlot>\n </DateRangePickerCustomContext>\n </ReactAriaDateRangePicker>\n </DateRangePickerRootSlot>\n );\n};\n\nDateRangePicker.displayName = \"DateRangePicker\";\n"],"names":["withProvider","withContext","createSlotRecipeContext","dateRangePickerSlotRecipe","DateRangePickerRootSlot","DateRangePickerGroupSlot","DateRangePickerTriggerSlot","DateRangePickerPopoverSlot","DateRangePickerCalendarSlot","DateRangePickerTimeInput","hideTimeZone","hourCycle","dateRangePickerState","useContext","DateRangePickerStateContext","granularity","value","timeInputRef","useRef","previousValueRef","useEffect","timeoutId","container","activeElement","firstSegment","jsxs","Flex","jsx","Text","TimeInput","DateRangePickerCustomContext","children","buttonContext","useSlottedContext","ButtonContext","hasCompleteRangeDate","date","incompleteValue","startTimeValue","endTimeValue","isDateRangePickerDisabled","getDefaultTimeInputAriaLabel","type","prefix","buttonSlots","event","timeInputSlots","currentValue","startDate","endDate","newStartDate","newEndDate","Provider","TimeFieldContext","DateRangePicker","props","recipe","useSlotRecipe","recipeProps","remainingProps","styleProps","otherProps","extractStyleProps","size","overlayButtonSize","shouldCloseOnSelect","ReactAriaDateRangePicker","Group","DateInput","IconButton","Close","CalendarMonth","Popover","Dialog","RangeCalendar"],"mappings":"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"}
1
+ {"version":3,"file":"date-range-picker-DelR30zw.es.js","sources":["../../src/components/date-range-picker/date-range-picker.slots.tsx","../../src/components/date-range-picker/components/date-range-picker.time-input.tsx","../../src/components/date-range-picker/components/date-range-picker.custom-context.tsx","../../src/components/date-range-picker/date-range-picker.tsx"],"sourcesContent":["import {\n type HTMLChakraProps,\n type RecipeProps,\n type UnstyledProp,\n createSlotRecipeContext,\n} from \"@chakra-ui/react/styled-system\";\n\nimport { dateRangePickerSlotRecipe } from \"./date-range-picker.recipe\";\n\n/**\n * Base recipe props interface that combines Chakra UI's recipe props\n * with the unstyled prop option for the div element.\n */\ninterface DateRangePickerRecipeProps extends RecipeProps<\"div\">, UnstyledProp {}\n\n/**\n * Root props interface that extends Chakra's HTML props with our recipe props.\n * This creates a complete set of props for the root element, combining\n * HTML attributes, Chakra's styling system, and our custom recipe props.\n */\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface DateRangePickerRootProps\n extends HTMLChakraProps<\"div\", DateRangePickerRecipeProps> {}\n\n// Correctly destructure from createSlotRecipeContext based on project examples\nconst { withProvider, withContext } = createSlotRecipeContext({\n recipe: dateRangePickerSlotRecipe,\n});\n\n/**\n * Root component that provides the styling context for the DateRangePicker component.\n * Uses Chakra UI's recipe context system for consistent styling across instances.\n */\nexport const DateRangePickerRootSlot = withProvider<\n HTMLDivElement,\n DateRangePickerRootProps\n>(\"div\", \"root\");\n\n/**\n * Slot component for the input group containing the DateInput and trigger button.\n */\nexport const DateRangePickerGroupSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"group\");\n\n/**\n * Slot component for the trigger button that opens the calendar popover.\n */\nexport const DateRangePickerTriggerSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"trigger\");\n\n/**\n * Slot component for the popover container.\n */\nexport const DateRangePickerPopoverSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"popover\");\n\n/**\n * Slot component for the calendar container within the popover.\n */\nexport const DateRangePickerCalendarSlot = withContext<\n HTMLDivElement,\n HTMLChakraProps<\"div\">\n>(\"div\", \"calendar\");\n\n/**\n * Slot component for the calendar header.\n */\nexport const DateRangePickerCalendarHeaderSlot = withContext<\n HTMLElement,\n HTMLChakraProps<\"header\">\n>(\"header\", \"calendarHeader\");\n\n/**\n * Slot component for the calendar grid.\n */\nexport const DateRangePickerCalendarGridSlot = withContext<\n HTMLTableElement,\n HTMLChakraProps<\"table\">\n>(\"table\", \"calendarGrid\");\n\n/**\n * Slot component for individual calendar cells.\n */\nexport const DateRangePickerCalendarCellSlot = withContext<\n HTMLTableCellElement,\n HTMLChakraProps<\"td\">\n>(\"td\", \"calendarCell\");\n","import { Flex, Text, TimeInput } from \"@/components\";\nimport { useContext, useRef, useEffect } from \"react\";\nimport { DateRangePickerStateContext } from \"react-aria-components\";\nimport type { DateRangePickerTimeInputProps } from \"../date-range-picker.types\";\n\nexport const DateRangePickerTimeInput = ({\n hideTimeZone,\n hourCycle,\n}: DateRangePickerTimeInputProps) => {\n const dateRangePickerState = useContext(DateRangePickerStateContext);\n const { granularity, value } = dateRangePickerState!;\n const timeInputRef = useRef<HTMLDivElement>(null);\n const previousValueRef = useRef(value);\n\n // do not show up to the party if you're not invited\n if (granularity === \"day\") {\n return null;\n }\n\n // Focus the time input when date range changes (user selects dates from calendar)\n useEffect(() => {\n let timeoutId: ReturnType<typeof setTimeout> | undefined;\n\n // Check if date range changed by comparing start and end dates\n const hasValueChanged =\n (value?.start &&\n previousValueRef.current?.start?.compare(value.start) !== 0) ||\n (value?.end && previousValueRef.current?.end?.compare(value.end) !== 0);\n\n if (hasValueChanged) {\n // Only auto-focus if no time input segment currently has focus\n // This prevents stealing focus during user interaction with time segments\n const container = timeInputRef.current;\n const activeElement = document.activeElement;\n const hasTimeSegmentFocus =\n container?.contains(activeElement) &&\n activeElement?.getAttribute(\"role\") === \"spinbutton\";\n\n if (!hasTimeSegmentFocus) {\n // Small delay to ensure the DOM is ready\n timeoutId = setTimeout(() => {\n // Find the first focusable segment within the time input container\n if (container) {\n const firstSegment = container.querySelector(\n '[role=\"spinbutton\"]'\n ) as HTMLElement;\n\n if (firstSegment) {\n firstSegment.focus();\n }\n }\n }, 50);\n }\n }\n\n previousValueRef.current = value;\n\n // Cleanup timeout on effect re-run or unmount to prevent memory leaks\n return () => {\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n };\n }, [value]);\n\n return (\n <Flex\n ref={timeInputRef}\n borderTop=\"solid-25\"\n borderColor=\"neutral.3\"\n py=\"300\"\n px=\"400\"\n alignItems=\"center\"\n justifyContent=\"center\"\n gap=\"200\"\n >\n {/* Start DateInput with separate label */}\n <Flex alignItems=\"center\" gap=\"200\">\n {/* TODO: translate hardcoded string */}\n <Text\n textStyle=\"xs\"\n fontWeight=\"500\"\n color=\"neutral.12\"\n minWidth=\"fit-content\"\n >\n Start time\n </Text>\n <TimeInput\n slot=\"startTimeInput\"\n variant=\"ghost\"\n size=\"sm\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Flex>\n\n {/* End DateInput with separate label */}\n <Flex alignItems=\"center\" gap=\"200\">\n {/* TODO: translate hardcoded string */}\n <Text\n textStyle=\"xs\"\n fontWeight=\"500\"\n color=\"neutral.12\"\n minWidth=\"fit-content\"\n >\n End time\n </Text>\n <TimeInput\n slot=\"endTimeInput\"\n variant=\"ghost\"\n size=\"sm\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Flex>\n </Flex>\n );\n};\n","import { useContext, type ReactNode } from \"react\";\nimport {\n Provider,\n ButtonContext,\n DateRangePickerStateContext,\n TimeFieldContext,\n useSlottedContext,\n} from \"react-aria-components\";\nimport type { PressEvent, TimeValue } from \"react-aria\";\n\nexport const DateRangePickerCustomContext = ({\n children,\n}: {\n children: ReactNode;\n}) => {\n const buttonContext = useSlottedContext(ButtonContext) || {};\n const dateRangePickerState = useContext(DateRangePickerStateContext);\n\n // Check if all 6 segments (start: day, month, year; end: day, month, year) have values\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const hasCompleteRangeDate = (date: any) =>\n date?.day && date?.month && date?.year;\n\n const incompleteValue =\n !dateRangePickerState?.value ||\n !hasCompleteRangeDate(dateRangePickerState.value.start) ||\n !hasCompleteRangeDate(dateRangePickerState.value.end);\n\n const { granularity } = dateRangePickerState!;\n\n // Extract time values from start and end dates separately\n const startTimeValue =\n dateRangePickerState?.value?.start &&\n \"hour\" in dateRangePickerState.value.start\n ? dateRangePickerState.value.start\n : null;\n const endTimeValue =\n dateRangePickerState?.value?.end && \"hour\" in dateRangePickerState.value.end\n ? dateRangePickerState.value.end\n : null;\n\n // Try to get disabled state from the button context\n const isDateRangePickerDisabled = buttonContext?.isDisabled;\n\n // Generate default aria-label based on granularity if not provided\n const getDefaultTimeInputAriaLabel = (type: \"start\" | \"end\") => {\n const prefix = type === \"start\" ? \"Start\" : \"End\";\n switch (granularity) {\n case \"hour\":\n return `${prefix} time (hour)`;\n case \"minute\":\n return `${prefix} time (hour and minute)`;\n case \"second\":\n return `${prefix} time (hour, minute, and second)`;\n default:\n return `${prefix} time`;\n }\n };\n\n /**\n * Button slots\n * ================================\n */\n const buttonSlots = {\n /** toggles the calendar popover */\n calendarToggle: {\n ...buttonContext,\n onPress: (event: PressEvent) => {\n // Ensure any active input (e.g., date picker segment) loses focus\n // because blurring the input will close the popover if it's open (or was just opened)\n const activeElement = document?.activeElement as HTMLElement | null;\n\n if (activeElement) {\n activeElement.blur();\n }\n\n buttonContext.onPress?.(event);\n },\n },\n /** Clear button that displays when there's a value in each segment - hidden from both visual and screen readers when there's no value */\n clear: {\n // Clear both start and end values\n onPress: () => dateRangePickerState?.setValue(null),\n \"aria-label\": \"Clear input value\",\n isDisabled: isDateRangePickerDisabled,\n // Hide the button when there's no value\n style: incompleteValue ? { display: \"none\" } : undefined,\n \"aria-hidden\": incompleteValue ? true : undefined,\n },\n };\n\n /**\n * TimeInput slots\n * ================================\n */\n\n // Separate time input slots for start and end times\n const timeInputSlots = {\n startTimeInput: {\n value: startTimeValue,\n onChange: (value: TimeValue | null) => {\n if (value !== null && dateRangePickerState?.value?.start) {\n // Update the start date with the new time\n const currentValue = dateRangePickerState.value;\n const startDate = currentValue.start;\n const endDate = currentValue.end;\n if (startDate && endDate) {\n const newStartDate = startDate.set({\n hour: value.hour,\n minute: value.minute || 0,\n second: value.second || 0,\n millisecond: value.millisecond || 0,\n });\n\n dateRangePickerState.setValue({\n start: newStartDate,\n end: endDate,\n });\n }\n }\n },\n granularity: granularity === \"day\" ? undefined : granularity,\n \"aria-label\": getDefaultTimeInputAriaLabel(\"start\"),\n },\n endTimeInput: {\n value: endTimeValue,\n onChange: (value: TimeValue | null) => {\n if (value !== null && dateRangePickerState?.value?.end) {\n // Update the end date with the new time\n const currentValue = dateRangePickerState.value;\n const startDate = currentValue.start;\n const endDate = currentValue.end;\n if (startDate && endDate) {\n const newEndDate = endDate.set({\n hour: value.hour,\n minute: value.minute || 0,\n second: value.second || 0,\n millisecond: value.millisecond || 0,\n });\n\n dateRangePickerState.setValue({\n start: startDate,\n end: newEndDate,\n });\n }\n }\n },\n granularity: granularity === \"day\" ? undefined : granularity,\n \"aria-label\": getDefaultTimeInputAriaLabel(\"end\"),\n },\n };\n\n return (\n <Provider\n values={[\n [\n ButtonContext,\n {\n slots: buttonSlots,\n },\n ],\n [TimeFieldContext, { slots: timeInputSlots }],\n ]}\n >\n {children}\n </Provider>\n );\n};\n","import {\n DateRangePickerRootSlot,\n DateRangePickerGroupSlot,\n DateRangePickerTriggerSlot,\n DateRangePickerPopoverSlot,\n DateRangePickerCalendarSlot,\n} from \"./date-range-picker.slots\";\n\nimport { CalendarMonth, Close } from \"@commercetools/nimbus-icons\";\n\nimport {\n DateRangePicker as ReactAriaDateRangePicker,\n Group,\n Popover,\n Dialog,\n} from \"react-aria-components\";\nimport { useSlotRecipe } from \"@chakra-ui/react/styled-system\";\nimport { dateRangePickerSlotRecipe } from \"./date-range-picker.recipe\";\nimport type { DateRangePickerProps } from \"./date-range-picker.types\";\nimport { extractStyleProps } from \"@/utils/extractStyleProps\";\nimport { DateInput, RangeCalendar, IconButton, Text } from \"@/components\";\nimport { DateRangePickerTimeInput } from \"./components/date-range-picker.time-input\";\nimport { DateRangePickerCustomContext } from \"./components/date-range-picker.custom-context\";\n\n/**\n * DateRangePicker\n * ============================================================\n * Combines a DateInput with a RangeCalendar popover for date range selection.\n * Users can either type a date range directly or select from the calendar.\n */\nexport const DateRangePicker = (props: DateRangePickerProps) => {\n // Forward hideTimeZone and hourCycle to child components (footer time inputs)\n const { granularity = \"day\", hideTimeZone, hourCycle } = props;\n const recipe = useSlotRecipe({ recipe: dateRangePickerSlotRecipe });\n const [recipeProps, remainingProps] = recipe.splitVariantProps(props);\n\n const [styleProps, otherProps] = extractStyleProps(remainingProps);\n\n // Extract size and variant from recipe props to pass to DateInputs\n const { size = \"md\" } = recipeProps;\n\n // the size of the buttons overlaying the input\n const overlayButtonSize = size === \"md\" ? \"xs\" : \"2xs\";\n\n // When granularity is \"day\", use the prop value (defaults to true if not provided)\n // For other granularities (time-based), force to false so users can set both date and time\n const shouldCloseOnSelect =\n granularity === \"day\" ? props.shouldCloseOnSelect : false;\n\n return (\n <DateRangePickerRootSlot {...recipeProps} {...styleProps} asChild>\n <ReactAriaDateRangePicker\n {...otherProps}\n shouldCloseOnSelect={shouldCloseOnSelect}\n >\n <DateRangePickerCustomContext>\n <DateRangePickerGroupSlot asChild>\n <Group>\n <DateInput\n slot=\"start\"\n size={size}\n variant=\"plain\"\n width=\"auto\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n <Text\n as=\"span\"\n px=\"150\"\n color=\"neutral.11\"\n userSelect=\"none\"\n aria-hidden=\"true\"\n slot={null}\n >\n –\n </Text>\n <DateInput\n slot=\"end\"\n size={size}\n variant=\"plain\"\n width=\"auto\"\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n <DateRangePickerTriggerSlot>\n {/* @ts-expect-error react aria is adding the aria-label prop */}\n <IconButton\n tone=\"primary\"\n variant=\"ghost\"\n size={overlayButtonSize}\n slot=\"clear\"\n >\n <Close />\n </IconButton>\n {/* @ts-expect-error react aria is adding the aria-label prop */}\n <IconButton\n tone=\"primary\"\n variant=\"ghost\"\n size={overlayButtonSize}\n slot=\"calendarToggle\"\n >\n <CalendarMonth />\n </IconButton>\n </DateRangePickerTriggerSlot>\n </Group>\n </DateRangePickerGroupSlot>\n <DateRangePickerPopoverSlot asChild>\n <Popover placement=\"bottom end\">\n <Dialog>\n <DateRangePickerCalendarSlot>\n <RangeCalendar />\n </DateRangePickerCalendarSlot>\n <DateRangePickerTimeInput\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\n />\n </Dialog>\n </Popover>\n </DateRangePickerPopoverSlot>\n </DateRangePickerCustomContext>\n </ReactAriaDateRangePicker>\n </DateRangePickerRootSlot>\n );\n};\n\nDateRangePicker.displayName = \"DateRangePicker\";\n"],"names":["withProvider","withContext","createSlotRecipeContext","dateRangePickerSlotRecipe","DateRangePickerRootSlot","DateRangePickerGroupSlot","DateRangePickerTriggerSlot","DateRangePickerPopoverSlot","DateRangePickerCalendarSlot","DateRangePickerTimeInput","hideTimeZone","hourCycle","dateRangePickerState","useContext","DateRangePickerStateContext","granularity","value","timeInputRef","useRef","previousValueRef","useEffect","timeoutId","container","activeElement","firstSegment","jsxs","Flex","jsx","Text","TimeInput","DateRangePickerCustomContext","children","buttonContext","useSlottedContext","ButtonContext","hasCompleteRangeDate","date","incompleteValue","startTimeValue","endTimeValue","isDateRangePickerDisabled","getDefaultTimeInputAriaLabel","type","prefix","buttonSlots","event","timeInputSlots","currentValue","startDate","endDate","newStartDate","newEndDate","Provider","TimeFieldContext","DateRangePicker","props","recipe","useSlotRecipe","recipeProps","remainingProps","styleProps","otherProps","extractStyleProps","size","overlayButtonSize","shouldCloseOnSelect","ReactAriaDateRangePicker","Group","DateInput","IconButton","Close","CalendarMonth","Popover","Dialog","RangeCalendar"],"mappings":"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"}
@@ -0,0 +1,165 @@
1
+ import { g as o, f as a, e, d as g, c as i, b as r, a as l, D as t } from "./dialog.title-DyRR_xdZ.es.js";
2
+ const D = {
3
+ /**
4
+ * # Dialog.Root
5
+ *
6
+ * The root component that provides context and state management for the dialog.
7
+ * Uses React Aria's DialogTrigger for accessibility and keyboard interaction.
8
+ *
9
+ * This component must wrap all dialog parts (Trigger, Content, etc.) and provides
10
+ * the dialog open/close state and variant styling context.
11
+ *
12
+ * @example
13
+ * ```tsx
14
+ * <Dialog.Root>
15
+ * <Dialog.Trigger>Open Dialog</Dialog.Trigger>
16
+ * <Dialog.Content>
17
+ * <Dialog.Header>
18
+ * <Dialog.Title>Dialog Title</Dialog.Title>
19
+ * </Dialog.Header>
20
+ * <Dialog.Body>Dialog content</Dialog.Body>
21
+ * </Dialog.Content>
22
+ * </Dialog.Root>
23
+ * ```
24
+ */
25
+ Root: t,
26
+ /**
27
+ * # Dialog.Trigger
28
+ *
29
+ * The trigger element that opens the dialog when activated.
30
+ * Uses React Aria's Button for accessibility and keyboard support.
31
+ *
32
+ * @example
33
+ * ```tsx
34
+ * <Dialog.Root>
35
+ * <Dialog.Trigger>Open Dialog</Dialog.Trigger>
36
+ * <Dialog.Content>...</Dialog.Content>
37
+ * </Dialog.Root>
38
+ * ```
39
+ */
40
+ Trigger: l,
41
+ /**
42
+ * # Dialog.Content
43
+ *
44
+ * The main dialog content container that wraps React Aria's Modal and Dialog.
45
+ * Handles portalling, backdrop, positioning, and content styling.
46
+ *
47
+ * This component creates the dialog overlay, positions the content, and provides
48
+ * accessibility features like focus management and keyboard dismissal.
49
+ *
50
+ * @example
51
+ * ```tsx
52
+ * <Dialog.Root>
53
+ * <Dialog.Trigger>Open Dialog</Dialog.Trigger>
54
+ * <Dialog.Content size="md" placement="center">
55
+ * <Dialog.Header>
56
+ * <Dialog.Title>Title</Dialog.Title>
57
+ * </Dialog.Header>
58
+ * <Dialog.Body>Content</Dialog.Body>
59
+ * <Dialog.Footer>Actions</Dialog.Footer>
60
+ * </Dialog.Content>
61
+ * </Dialog.Root>
62
+ * ```
63
+ */
64
+ Content: r,
65
+ /**
66
+ * # Dialog.Header
67
+ *
68
+ * The header section of the dialog content.
69
+ * Typically contains the title and close button.
70
+ *
71
+ * @example
72
+ * ```tsx
73
+ * <Dialog.Content>
74
+ * <Dialog.Header>
75
+ * <Dialog.Title>Dialog Title</Dialog.Title>
76
+ * <Dialog.CloseTrigger />
77
+ * </Dialog.Header>
78
+ * <Dialog.Body>...</Dialog.Body>
79
+ * </Dialog.Content>
80
+ * ```
81
+ */
82
+ Header: i,
83
+ /**
84
+ * # Dialog.Body
85
+ *
86
+ * The main body content section of the dialog.
87
+ * Contains the primary dialog content and handles overflow/scrolling.
88
+ *
89
+ * @example
90
+ * ```tsx
91
+ * <Dialog.Content>
92
+ * <Dialog.Header>...</Dialog.Header>
93
+ * <Dialog.Body>
94
+ * <p>This is the main content of the dialog.</p>
95
+ * </Dialog.Body>
96
+ * <Dialog.Footer>...</Dialog.Footer>
97
+ * </Dialog.Content>
98
+ * ```
99
+ */
100
+ Body: g,
101
+ /**
102
+ * # Dialog.Footer
103
+ *
104
+ * The footer section of the dialog, typically containing action buttons.
105
+ * Provides consistent spacing and alignment for dialog actions.
106
+ *
107
+ * @example
108
+ * ```tsx
109
+ * <Dialog.Content>
110
+ * <Dialog.Header>...</Dialog.Header>
111
+ * <Dialog.Body>...</Dialog.Body>
112
+ * <Dialog.Footer>
113
+ * <Button variant="outline">Cancel</Button>
114
+ * <Button>Confirm</Button>
115
+ * </Dialog.Footer>
116
+ * </Dialog.Content>
117
+ * ```
118
+ */
119
+ Footer: e,
120
+ /**
121
+ * # Dialog.Title
122
+ *
123
+ * The accessible title element for the dialog.
124
+ * Uses React Aria's Heading for proper accessibility and screen reader support.
125
+ *
126
+ * @example
127
+ * ```tsx
128
+ * <Dialog.Content>
129
+ * <Dialog.Header>
130
+ * <Dialog.Title>Confirm Action</Dialog.Title>
131
+ * </Dialog.Header>
132
+ * <Dialog.Body>...</Dialog.Body>
133
+ * </Dialog.Content>
134
+ * ```
135
+ */
136
+ Title: a,
137
+ /**
138
+ * # Dialog.CloseTrigger
139
+ *
140
+ * A button that closes the dialog when activated.
141
+ * Displays an IconButton with a close (X) icon by default.
142
+ *
143
+ * The component automatically handles the close behavior through React Aria's
144
+ * context, so no additional onPress handler is needed.
145
+ *
146
+ * @example
147
+ * ```tsx
148
+ * <Dialog.Root>
149
+ * <Dialog.Trigger>Open Dialog</Dialog.Trigger>
150
+ * <Dialog.Content>
151
+ * <Dialog.Header>
152
+ * <Dialog.Title>Title</Dialog.Title>
153
+ * <Dialog.CloseTrigger aria-label="Close dialog" />
154
+ * </Dialog.Header>
155
+ * <Dialog.Body>Content</Dialog.Body>
156
+ * </Dialog.Content>
157
+ * </Dialog.Root>
158
+ * ```
159
+ */
160
+ CloseTrigger: o
161
+ };
162
+ export {
163
+ D
164
+ };
165
+ //# sourceMappingURL=dialog-B-NKwVSi.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dialog-B-NKwVSi.es.js","sources":["../../src/components/dialog/dialog.tsx"],"sourcesContent":["import { DialogRoot } from \"./components/dialog.root\";\nimport { DialogTrigger } from \"./components/dialog.trigger\";\nimport { DialogContent } from \"./components/dialog.content\";\nimport { DialogHeader } from \"./components/dialog.header\";\nimport { DialogBody } from \"./components/dialog.body\";\nimport { DialogFooter } from \"./components/dialog.footer\";\nimport { DialogTitle } from \"./components/dialog.title\";\nimport { DialogCloseTrigger } from \"./components/dialog.close-trigger\";\n\n/**\n * Dialog\n * ============================================================\n * A foundational dialog component for overlays that require user attention.\n * Built with React Aria Components for accessibility and WCAG 2.1 AA compliance.\n *\n * Features:\n * - Controlled and uncontrolled modes\n * - Customizable placement, size, and animations\n * - Focus management and keyboard navigation\n * - Click-outside and Escape key dismissal\n * - Portal rendering support\n * - Backdrop overlay with animations\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger>Open Dialog</Dialog.Trigger>\n * <Dialog.Content size=\"md\" placement=\"center\">\n * <Dialog.Header>\n * <Dialog.Title>Dialog Title</Dialog.Title>\n * <Dialog.CloseTrigger>×</Dialog.CloseTrigger>\n * </Dialog.Header>\n * <Dialog.Body>\n * Dialog content goes here\n * </Dialog.Body>\n * <Dialog.Footer>\n * <button>Cancel</button>\n * <button>Save</button>\n * </Dialog.Footer>\n * </Dialog.Content>\n * </Dialog.Root>\n * ```\n *\n * @see https://react-spectrum.adobe.com/react-aria/Dialog.html\n */\nexport const Dialog = {\n /**\n * # Dialog.Root\n *\n * The root component that provides context and state management for the dialog.\n * Uses React Aria's DialogTrigger for accessibility and keyboard interaction.\n *\n * This component must wrap all dialog parts (Trigger, Content, etc.) and provides\n * the dialog open/close state and variant styling context.\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger>Open Dialog</Dialog.Trigger>\n * <Dialog.Content>\n * <Dialog.Header>\n * <Dialog.Title>Dialog Title</Dialog.Title>\n * </Dialog.Header>\n * <Dialog.Body>Dialog content</Dialog.Body>\n * </Dialog.Content>\n * </Dialog.Root>\n * ```\n */\n Root: DialogRoot,\n /**\n * # Dialog.Trigger\n *\n * The trigger element that opens the dialog when activated.\n * Uses React Aria's Button for accessibility and keyboard support.\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger>Open Dialog</Dialog.Trigger>\n * <Dialog.Content>...</Dialog.Content>\n * </Dialog.Root>\n * ```\n */\n Trigger: DialogTrigger,\n /**\n * # Dialog.Content\n *\n * The main dialog content container that wraps React Aria's Modal and Dialog.\n * Handles portalling, backdrop, positioning, and content styling.\n *\n * This component creates the dialog overlay, positions the content, and provides\n * accessibility features like focus management and keyboard dismissal.\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger>Open Dialog</Dialog.Trigger>\n * <Dialog.Content size=\"md\" placement=\"center\">\n * <Dialog.Header>\n * <Dialog.Title>Title</Dialog.Title>\n * </Dialog.Header>\n * <Dialog.Body>Content</Dialog.Body>\n * <Dialog.Footer>Actions</Dialog.Footer>\n * </Dialog.Content>\n * </Dialog.Root>\n * ```\n */\n Content: DialogContent,\n /**\n * # Dialog.Header\n *\n * The header section of the dialog content.\n * Typically contains the title and close button.\n *\n * @example\n * ```tsx\n * <Dialog.Content>\n * <Dialog.Header>\n * <Dialog.Title>Dialog Title</Dialog.Title>\n * <Dialog.CloseTrigger />\n * </Dialog.Header>\n * <Dialog.Body>...</Dialog.Body>\n * </Dialog.Content>\n * ```\n */\n Header: DialogHeader,\n /**\n * # Dialog.Body\n *\n * The main body content section of the dialog.\n * Contains the primary dialog content and handles overflow/scrolling.\n *\n * @example\n * ```tsx\n * <Dialog.Content>\n * <Dialog.Header>...</Dialog.Header>\n * <Dialog.Body>\n * <p>This is the main content of the dialog.</p>\n * </Dialog.Body>\n * <Dialog.Footer>...</Dialog.Footer>\n * </Dialog.Content>\n * ```\n */\n Body: DialogBody,\n /**\n * # Dialog.Footer\n *\n * The footer section of the dialog, typically containing action buttons.\n * Provides consistent spacing and alignment for dialog actions.\n *\n * @example\n * ```tsx\n * <Dialog.Content>\n * <Dialog.Header>...</Dialog.Header>\n * <Dialog.Body>...</Dialog.Body>\n * <Dialog.Footer>\n * <Button variant=\"outline\">Cancel</Button>\n * <Button>Confirm</Button>\n * </Dialog.Footer>\n * </Dialog.Content>\n * ```\n */\n Footer: DialogFooter,\n /**\n * # Dialog.Title\n *\n * The accessible title element for the dialog.\n * Uses React Aria's Heading for proper accessibility and screen reader support.\n *\n * @example\n * ```tsx\n * <Dialog.Content>\n * <Dialog.Header>\n * <Dialog.Title>Confirm Action</Dialog.Title>\n * </Dialog.Header>\n * <Dialog.Body>...</Dialog.Body>\n * </Dialog.Content>\n * ```\n */\n Title: DialogTitle,\n /**\n * # Dialog.CloseTrigger\n *\n * A button that closes the dialog when activated.\n * Displays an IconButton with a close (X) icon by default.\n *\n * The component automatically handles the close behavior through React Aria's\n * context, so no additional onPress handler is needed.\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger>Open Dialog</Dialog.Trigger>\n * <Dialog.Content>\n * <Dialog.Header>\n * <Dialog.Title>Title</Dialog.Title>\n * <Dialog.CloseTrigger aria-label=\"Close dialog\" />\n * </Dialog.Header>\n * <Dialog.Body>Content</Dialog.Body>\n * </Dialog.Content>\n * </Dialog.Root>\n * ```\n */\n CloseTrigger: DialogCloseTrigger,\n};\n\n// Internal exports for react-docgen\nexport {\n DialogRoot as _DialogRoot,\n DialogTrigger as _DialogTrigger,\n DialogContent as _DialogContent,\n DialogHeader as _DialogHeader,\n DialogBody as _DialogBody,\n DialogFooter as _DialogFooter,\n DialogTitle as _DialogTitle,\n DialogCloseTrigger as _DialogCloseTrigger,\n};\n"],"names":["Dialog","DialogRoot","DialogTrigger","DialogContent","DialogHeader","DialogBody","DialogFooter","DialogTitle","DialogCloseTrigger"],"mappings":";AA6CO,MAAMA,IAAS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAuBpB,MAAMC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAeN,SAASC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAwBT,SAASC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBT,QAAQC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBR,MAAMC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAmBN,QAAQC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAiBR,OAAOC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAwBP,cAAcC;AAChB;"}
@@ -0,0 +1,2 @@
1
+ "use strict";const o=require("./dialog.title-Co1QDiYA.cjs.js"),e={Root:o.DialogRoot,Trigger:o.DialogTrigger,Content:o.DialogContent,Header:o.DialogHeader,Body:o.DialogBody,Footer:o.DialogFooter,Title:o.DialogTitle,CloseTrigger:o.DialogCloseTrigger};exports.Dialog=e;
2
+ //# sourceMappingURL=dialog-D0RnaoTx.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dialog-D0RnaoTx.cjs.js","sources":["../../src/components/dialog/dialog.tsx"],"sourcesContent":["import { DialogRoot } from \"./components/dialog.root\";\nimport { DialogTrigger } from \"./components/dialog.trigger\";\nimport { DialogContent } from \"./components/dialog.content\";\nimport { DialogHeader } from \"./components/dialog.header\";\nimport { DialogBody } from \"./components/dialog.body\";\nimport { DialogFooter } from \"./components/dialog.footer\";\nimport { DialogTitle } from \"./components/dialog.title\";\nimport { DialogCloseTrigger } from \"./components/dialog.close-trigger\";\n\n/**\n * Dialog\n * ============================================================\n * A foundational dialog component for overlays that require user attention.\n * Built with React Aria Components for accessibility and WCAG 2.1 AA compliance.\n *\n * Features:\n * - Controlled and uncontrolled modes\n * - Customizable placement, size, and animations\n * - Focus management and keyboard navigation\n * - Click-outside and Escape key dismissal\n * - Portal rendering support\n * - Backdrop overlay with animations\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger>Open Dialog</Dialog.Trigger>\n * <Dialog.Content size=\"md\" placement=\"center\">\n * <Dialog.Header>\n * <Dialog.Title>Dialog Title</Dialog.Title>\n * <Dialog.CloseTrigger>×</Dialog.CloseTrigger>\n * </Dialog.Header>\n * <Dialog.Body>\n * Dialog content goes here\n * </Dialog.Body>\n * <Dialog.Footer>\n * <button>Cancel</button>\n * <button>Save</button>\n * </Dialog.Footer>\n * </Dialog.Content>\n * </Dialog.Root>\n * ```\n *\n * @see https://react-spectrum.adobe.com/react-aria/Dialog.html\n */\nexport const Dialog = {\n /**\n * # Dialog.Root\n *\n * The root component that provides context and state management for the dialog.\n * Uses React Aria's DialogTrigger for accessibility and keyboard interaction.\n *\n * This component must wrap all dialog parts (Trigger, Content, etc.) and provides\n * the dialog open/close state and variant styling context.\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger>Open Dialog</Dialog.Trigger>\n * <Dialog.Content>\n * <Dialog.Header>\n * <Dialog.Title>Dialog Title</Dialog.Title>\n * </Dialog.Header>\n * <Dialog.Body>Dialog content</Dialog.Body>\n * </Dialog.Content>\n * </Dialog.Root>\n * ```\n */\n Root: DialogRoot,\n /**\n * # Dialog.Trigger\n *\n * The trigger element that opens the dialog when activated.\n * Uses React Aria's Button for accessibility and keyboard support.\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger>Open Dialog</Dialog.Trigger>\n * <Dialog.Content>...</Dialog.Content>\n * </Dialog.Root>\n * ```\n */\n Trigger: DialogTrigger,\n /**\n * # Dialog.Content\n *\n * The main dialog content container that wraps React Aria's Modal and Dialog.\n * Handles portalling, backdrop, positioning, and content styling.\n *\n * This component creates the dialog overlay, positions the content, and provides\n * accessibility features like focus management and keyboard dismissal.\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger>Open Dialog</Dialog.Trigger>\n * <Dialog.Content size=\"md\" placement=\"center\">\n * <Dialog.Header>\n * <Dialog.Title>Title</Dialog.Title>\n * </Dialog.Header>\n * <Dialog.Body>Content</Dialog.Body>\n * <Dialog.Footer>Actions</Dialog.Footer>\n * </Dialog.Content>\n * </Dialog.Root>\n * ```\n */\n Content: DialogContent,\n /**\n * # Dialog.Header\n *\n * The header section of the dialog content.\n * Typically contains the title and close button.\n *\n * @example\n * ```tsx\n * <Dialog.Content>\n * <Dialog.Header>\n * <Dialog.Title>Dialog Title</Dialog.Title>\n * <Dialog.CloseTrigger />\n * </Dialog.Header>\n * <Dialog.Body>...</Dialog.Body>\n * </Dialog.Content>\n * ```\n */\n Header: DialogHeader,\n /**\n * # Dialog.Body\n *\n * The main body content section of the dialog.\n * Contains the primary dialog content and handles overflow/scrolling.\n *\n * @example\n * ```tsx\n * <Dialog.Content>\n * <Dialog.Header>...</Dialog.Header>\n * <Dialog.Body>\n * <p>This is the main content of the dialog.</p>\n * </Dialog.Body>\n * <Dialog.Footer>...</Dialog.Footer>\n * </Dialog.Content>\n * ```\n */\n Body: DialogBody,\n /**\n * # Dialog.Footer\n *\n * The footer section of the dialog, typically containing action buttons.\n * Provides consistent spacing and alignment for dialog actions.\n *\n * @example\n * ```tsx\n * <Dialog.Content>\n * <Dialog.Header>...</Dialog.Header>\n * <Dialog.Body>...</Dialog.Body>\n * <Dialog.Footer>\n * <Button variant=\"outline\">Cancel</Button>\n * <Button>Confirm</Button>\n * </Dialog.Footer>\n * </Dialog.Content>\n * ```\n */\n Footer: DialogFooter,\n /**\n * # Dialog.Title\n *\n * The accessible title element for the dialog.\n * Uses React Aria's Heading for proper accessibility and screen reader support.\n *\n * @example\n * ```tsx\n * <Dialog.Content>\n * <Dialog.Header>\n * <Dialog.Title>Confirm Action</Dialog.Title>\n * </Dialog.Header>\n * <Dialog.Body>...</Dialog.Body>\n * </Dialog.Content>\n * ```\n */\n Title: DialogTitle,\n /**\n * # Dialog.CloseTrigger\n *\n * A button that closes the dialog when activated.\n * Displays an IconButton with a close (X) icon by default.\n *\n * The component automatically handles the close behavior through React Aria's\n * context, so no additional onPress handler is needed.\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger>Open Dialog</Dialog.Trigger>\n * <Dialog.Content>\n * <Dialog.Header>\n * <Dialog.Title>Title</Dialog.Title>\n * <Dialog.CloseTrigger aria-label=\"Close dialog\" />\n * </Dialog.Header>\n * <Dialog.Body>Content</Dialog.Body>\n * </Dialog.Content>\n * </Dialog.Root>\n * ```\n */\n CloseTrigger: DialogCloseTrigger,\n};\n\n// Internal exports for react-docgen\nexport {\n DialogRoot as _DialogRoot,\n DialogTrigger as _DialogTrigger,\n DialogContent as _DialogContent,\n DialogHeader as _DialogHeader,\n DialogBody as _DialogBody,\n DialogFooter as _DialogFooter,\n DialogTitle as _DialogTitle,\n DialogCloseTrigger as _DialogCloseTrigger,\n};\n"],"names":["Dialog","DialogRoot","DialogTrigger","DialogContent","DialogHeader","DialogBody","DialogFooter","DialogTitle","DialogCloseTrigger"],"mappings":"+DA6CaA,EAAS,CAuBpB,KAAMC,EAAAA,WAeN,QAASC,EAAAA,cAwBT,QAASC,EAAAA,cAkBT,OAAQC,EAAAA,aAkBR,KAAMC,EAAAA,WAmBN,OAAQC,EAAAA,aAiBR,MAAOC,EAAAA,YAwBP,aAAcC,EAAAA,kBAChB"}