@banzamel/mineralui 1.6.2 → 1.6.3

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 (441) hide show
  1. package/README.md +1 -1
  2. package/dist/{MAvatar-CnBVN71i.js → MAvatar-BHASnoyu.js} +5 -5
  3. package/dist/{MAvatar-CnBVN71i.js.map → MAvatar-BHASnoyu.js.map} +1 -1
  4. package/dist/MAvatar-BVJh6kgW.cjs +2 -0
  5. package/dist/{MAvatar-DGEQqUss.cjs.map → MAvatar-BVJh6kgW.cjs.map} +1 -1
  6. package/dist/MBadge-B4x-Lx7e.cjs +2 -0
  7. package/dist/{MBadge-DcIPfPH1.cjs.map → MBadge-B4x-Lx7e.cjs.map} +1 -1
  8. package/dist/{MBadge-C_vK2JdM.js → MBadge-_BggwkrM.js} +3 -3
  9. package/dist/{MBadge-C_vK2JdM.js.map → MBadge-_BggwkrM.js.map} +1 -1
  10. package/dist/MButton-DrkVdRDy.cjs +2 -0
  11. package/dist/{MButton-LUNWBBOV.cjs.map → MButton-DrkVdRDy.cjs.map} +1 -1
  12. package/dist/{MButton-BpSZUhpY.js → MButton-y9qXhhGt.js} +4 -4
  13. package/dist/{MButton-BpSZUhpY.js.map → MButton-y9qXhhGt.js.map} +1 -1
  14. package/dist/{MCheckbox-CNz73bQC.js → MCheckbox-B-nT2OBE.js} +3 -3
  15. package/dist/{MCheckbox-CNz73bQC.js.map → MCheckbox-B-nT2OBE.js.map} +1 -1
  16. package/dist/MCheckbox-C40ESQRe.cjs +2 -0
  17. package/dist/{MCheckbox-PzknJeM2.cjs.map → MCheckbox-C40ESQRe.cjs.map} +1 -1
  18. package/dist/{MCookieBootstrap-DSOT4FQo.cjs → MCookieBootstrap-3-wyz3Dk.cjs} +1 -1
  19. package/dist/{MCookieBootstrap-DSOT4FQo.cjs.map → MCookieBootstrap-3-wyz3Dk.cjs.map} +1 -1
  20. package/dist/{MCookieBootstrap-CNYLvKjW.js → MCookieBootstrap-CGvYxIK8.js} +1 -1
  21. package/dist/{MCookieBootstrap-CNYLvKjW.js.map → MCookieBootstrap-CGvYxIK8.js.map} +1 -1
  22. package/dist/MDataTable-Bx7W-Ari.cjs +2 -0
  23. package/dist/{MDataTable-Bq6UoNJX.cjs.map → MDataTable-Bx7W-Ari.cjs.map} +1 -1
  24. package/dist/{MDataTable-AH5Tnirs.js → MDataTable-ByvNQqNP.js} +6 -6
  25. package/dist/{MDataTable-AH5Tnirs.js.map → MDataTable-ByvNQqNP.js.map} +1 -1
  26. package/dist/MDrawer-DFkrFrnD.cjs +2 -0
  27. package/dist/{MDrawer-DRqMsjMt.cjs.map → MDrawer-DFkrFrnD.cjs.map} +1 -1
  28. package/dist/{MDrawer-C08QXXC4.js → MDrawer-W2WQs1sM.js} +5 -5
  29. package/dist/{MDrawer-C08QXXC4.js.map → MDrawer-W2WQs1sM.js.map} +1 -1
  30. package/dist/MDropdownMenu-BmfXSc46.cjs +2 -0
  31. package/dist/{MDropdownMenu-CymCQqyP.cjs.map → MDropdownMenu-BmfXSc46.cjs.map} +1 -1
  32. package/dist/{MDropdownMenu-CMnBt-wO.js → MDropdownMenu-D79Cm5aS.js} +4 -4
  33. package/dist/{MDropdownMenu-CMnBt-wO.js.map → MDropdownMenu-D79Cm5aS.js.map} +1 -1
  34. package/dist/MGalleryIllustration-BB3DoCl_.cjs +2 -0
  35. package/dist/{MGalleryIllustration-BHtRFizZ.cjs.map → MGalleryIllustration-BB3DoCl_.cjs.map} +1 -1
  36. package/dist/{MGalleryIllustration-DhOtXwhC.js → MGalleryIllustration-D7CVMSwO.js} +2 -2
  37. package/dist/{MGalleryIllustration-DhOtXwhC.js.map → MGalleryIllustration-D7CVMSwO.js.map} +1 -1
  38. package/dist/MHeading-BhCNoJeW.cjs +2 -0
  39. package/dist/{MHeading-DHT1gORD.cjs.map → MHeading-BhCNoJeW.cjs.map} +1 -1
  40. package/dist/{MHeading-BvpWyvjj.js → MHeading-MPh8Qm9q.js} +4 -4
  41. package/dist/{MHeading-BvpWyvjj.js.map → MHeading-MPh8Qm9q.js.map} +1 -1
  42. package/dist/MI18nProvider-B2sE0x5D.cjs +2 -0
  43. package/dist/{MI18nProvider-Bml7Vs2-.cjs.map → MI18nProvider-B2sE0x5D.cjs.map} +1 -1
  44. package/dist/{MI18nProvider-BRZxEMqL.js → MI18nProvider-VH14CI8u.js} +1 -1
  45. package/dist/{MI18nProvider-BRZxEMqL.js.map → MI18nProvider-VH14CI8u.js.map} +1 -1
  46. package/dist/MImage-L_zgfWRY.cjs +2 -0
  47. package/dist/{MImage-CxeuH-cT.cjs.map → MImage-L_zgfWRY.cjs.map} +1 -1
  48. package/dist/{MImage-BQs91GK-.js → MImage-gwFphZk2.js} +9 -9
  49. package/dist/{MImage-BQs91GK-.js.map → MImage-gwFphZk2.js.map} +1 -1
  50. package/dist/MInline-CHrh3PHH.cjs +2 -0
  51. package/dist/{MInline-D9p9Sazp.cjs.map → MInline-CHrh3PHH.cjs.map} +1 -1
  52. package/dist/{MInline-DA_ehefx.js → MInline-CoMhfX5V.js} +4 -4
  53. package/dist/{MInline-DA_ehefx.js.map → MInline-CoMhfX5V.js.map} +1 -1
  54. package/dist/MInput-DYqV3-rQ.cjs +2 -0
  55. package/dist/{MInput-DDZ71Qqn.cjs.map → MInput-DYqV3-rQ.cjs.map} +1 -1
  56. package/dist/{MInput-l3MY93Su.js → MInput-bzSwK880.js} +6 -6
  57. package/dist/{MInput-l3MY93Su.js.map → MInput-bzSwK880.js.map} +1 -1
  58. package/dist/MInputCVC-5NkYSxV8.cjs +2 -0
  59. package/dist/{MInputCVC-Sp2uZ5aO.cjs.map → MInputCVC-5NkYSxV8.cjs.map} +1 -1
  60. package/dist/{MInputCVC-CN91scmw.js → MInputCVC-BHpMHTO5.js} +5 -5
  61. package/dist/{MInputCVC-CN91scmw.js.map → MInputCVC-BHpMHTO5.js.map} +1 -1
  62. package/dist/MInputSearch-DfoenJIm.cjs +2 -0
  63. package/dist/{MInputSearch-30o4bcDC.cjs.map → MInputSearch-DfoenJIm.cjs.map} +1 -1
  64. package/dist/{MInputSearch-CdPfJ4v_.js → MInputSearch-Dh4C3Tz5.js} +4 -4
  65. package/dist/{MInputSearch-CdPfJ4v_.js.map → MInputSearch-Dh4C3Tz5.js.map} +1 -1
  66. package/dist/MLink-CY45UR_j.cjs +2 -0
  67. package/dist/{MLink-U_wAUuz1.cjs.map → MLink-CY45UR_j.cjs.map} +1 -1
  68. package/dist/{MLink-CRUWGES-.js → MLink-rFKN1mcM.js} +3 -3
  69. package/dist/{MLink-CRUWGES-.js.map → MLink-rFKN1mcM.js.map} +1 -1
  70. package/dist/{MModal-CHSo5gKE.js → MModal-BDTAgnrm.js} +4 -4
  71. package/dist/{MModal-CHSo5gKE.js.map → MModal-BDTAgnrm.js.map} +1 -1
  72. package/dist/MModal-DT5BBgNZ.cjs +2 -0
  73. package/dist/{MModal-Czy-rR--.cjs.map → MModal-DT5BBgNZ.cjs.map} +1 -1
  74. package/dist/{MPagination-DdT1uNzD.js → MPagination-CTnaW5AW.js} +4 -4
  75. package/dist/{MPagination-DdT1uNzD.js.map → MPagination-CTnaW5AW.js.map} +1 -1
  76. package/dist/MPagination-CZEJMJzZ.cjs +2 -0
  77. package/dist/{MPagination-73z0sQvf.cjs.map → MPagination-CZEJMJzZ.cjs.map} +1 -1
  78. package/dist/MPopover-B4IUb9f0.cjs +2 -0
  79. package/dist/{MPopover-BW23_1Dl.cjs.map → MPopover-B4IUb9f0.cjs.map} +1 -1
  80. package/dist/{MPopover-3tjz5lKh.js → MPopover-Cqz5TsHg.js} +3 -3
  81. package/dist/{MPopover-3tjz5lKh.js.map → MPopover-Cqz5TsHg.js.map} +1 -1
  82. package/dist/{MPortal-Dqlkh3hw.js → MPortal-Ba2Sxset.js} +1 -1
  83. package/dist/{MPortal-Dqlkh3hw.js.map → MPortal-Ba2Sxset.js.map} +1 -1
  84. package/dist/MPortal-Bi24xTGW.cjs +2 -0
  85. package/dist/{MPortal-DE3pL2Xl.cjs.map → MPortal-Bi24xTGW.cjs.map} +1 -1
  86. package/dist/MQrCode-ByfmG33y.cjs +2 -0
  87. package/dist/{MQrCode-CMoru4dD.cjs.map → MQrCode-ByfmG33y.cjs.map} +1 -1
  88. package/dist/{MQrCode-DK5-SBhN.js → MQrCode-CCtTkkv9.js} +4 -4
  89. package/dist/{MQrCode-DK5-SBhN.js.map → MQrCode-CCtTkkv9.js.map} +1 -1
  90. package/dist/MSkeleton-5j1h9s95.cjs +2 -0
  91. package/dist/{MSkeleton-B0Mxe3L7.cjs.map → MSkeleton-5j1h9s95.cjs.map} +1 -1
  92. package/dist/{MSkeleton-Bqq_XJn8.js → MSkeleton-DGhtNmpI.js} +4 -4
  93. package/dist/{MSkeleton-Bqq_XJn8.js.map → MSkeleton-DGhtNmpI.js.map} +1 -1
  94. package/dist/{MSlider-ByVuoFFc.js → MSlider-5141rKeH.js} +2 -2
  95. package/dist/{MSlider-ByVuoFFc.js.map → MSlider-5141rKeH.js.map} +1 -1
  96. package/dist/MSlider-Ch3VjAJC.cjs +2 -0
  97. package/dist/{MSlider-sH2Vt9Lw.cjs.map → MSlider-Ch3VjAJC.cjs.map} +1 -1
  98. package/dist/MSparkline-B6qpt5WM.cjs +2 -0
  99. package/dist/{MSparkline-B-ld7hJu.cjs.map → MSparkline-B6qpt5WM.cjs.map} +1 -1
  100. package/dist/{MSparkline-DbtdM0W6.js → MSparkline-voNWOLNz.js} +2 -2
  101. package/dist/{MSparkline-DbtdM0W6.js.map → MSparkline-voNWOLNz.js.map} +1 -1
  102. package/dist/MStack-Bh-R2opf.cjs +2 -0
  103. package/dist/{MStack-Cy2GplIA.cjs.map → MStack-Bh-R2opf.cjs.map} +1 -1
  104. package/dist/{MStack-BWarX5O9.js → MStack-CSaEbepM.js} +4 -4
  105. package/dist/{MStack-BWarX5O9.js.map → MStack-CSaEbepM.js.map} +1 -1
  106. package/dist/{MSubText-C9VizSn9.js → MSubText-BFdfBlpS.js} +4 -4
  107. package/dist/{MSubText-C9VizSn9.js.map → MSubText-BFdfBlpS.js.map} +1 -1
  108. package/dist/MSubText-C-70zn0m.cjs +2 -0
  109. package/dist/{MSubText-DP9WYlwz.cjs.map → MSubText-C-70zn0m.cjs.map} +1 -1
  110. package/dist/MSurface-CpiV1-7f.cjs +2 -0
  111. package/dist/{MSurface-C467dVMQ.cjs.map → MSurface-CpiV1-7f.cjs.map} +1 -1
  112. package/dist/{MSurface-DfZ1Zy1-.js → MSurface-DJYSftdM.js} +4 -4
  113. package/dist/{MSurface-DfZ1Zy1-.js.map → MSurface-DJYSftdM.js.map} +1 -1
  114. package/dist/{MTag-N-tYZ915.js → MTag-CH5nMbm7.js} +5 -5
  115. package/dist/{MTag-N-tYZ915.js.map → MTag-CH5nMbm7.js.map} +1 -1
  116. package/dist/MTag-Y4Tswmli.cjs +2 -0
  117. package/dist/{MTag-DXqkBvqx.cjs.map → MTag-Y4Tswmli.cjs.map} +1 -1
  118. package/dist/MText-DEJddMB5.cjs +2 -0
  119. package/dist/{MText-COzub3y4.cjs.map → MText-DEJddMB5.cjs.map} +1 -1
  120. package/dist/{MText-B7_HjPym.js → MText-DcB1GAt-.js} +4 -4
  121. package/dist/{MText-B7_HjPym.js.map → MText-DcB1GAt-.js.map} +1 -1
  122. package/dist/{MTimeAgo-D1G2yovw.js → MTimeAgo-C4p80NvI.js} +4 -4
  123. package/dist/{MTimeAgo-D1G2yovw.js.map → MTimeAgo-C4p80NvI.js.map} +1 -1
  124. package/dist/MTimeAgo-DxZGVo2Y.cjs +2 -0
  125. package/dist/{MTimeAgo-DWwXs48z.cjs.map → MTimeAgo-DxZGVo2Y.cjs.map} +1 -1
  126. package/dist/MToggle-C8vYRzpC.cjs +2 -0
  127. package/dist/{MToggle-Cm3f6gm4.cjs.map → MToggle-C8vYRzpC.cjs.map} +1 -1
  128. package/dist/{MToggle-D0DrQirB.js → MToggle-Dt1Ctr5e.js} +3 -3
  129. package/dist/{MToggle-D0DrQirB.js.map → MToggle-Dt1Ctr5e.js.map} +1 -1
  130. package/dist/{MTooltip-w6Aj044c.js → MTooltip-C43aUKMP.js} +3 -3
  131. package/dist/{MTooltip-w6Aj044c.js.map → MTooltip-C43aUKMP.js.map} +1 -1
  132. package/dist/MTooltip-kSTMMpvu.cjs +2 -0
  133. package/dist/{MTooltip-C3PeHgV3.cjs.map → MTooltip-kSTMMpvu.cjs.map} +1 -1
  134. package/dist/arduino-CXUo7Bjy.cjs +2 -0
  135. package/dist/arduino-CXUo7Bjy.cjs.map +1 -0
  136. package/dist/arduino-Eif5KI8O.js +261 -0
  137. package/dist/arduino-Eif5KI8O.js.map +1 -0
  138. package/dist/bash-CCF_TYbb.js +171 -0
  139. package/dist/bash-CCF_TYbb.js.map +1 -0
  140. package/dist/bash-W4h3o_nx.cjs +2 -0
  141. package/dist/bash-W4h3o_nx.cjs.map +1 -0
  142. package/dist/c-DVgkp6T3.js +178 -0
  143. package/dist/c-DVgkp6T3.js.map +1 -0
  144. package/dist/c-Dm60JY-W.cjs +2 -0
  145. package/dist/c-Dm60JY-W.cjs.map +1 -0
  146. package/dist/cards-BiYdorB0.cjs +2 -0
  147. package/dist/{cards-B75QM9JW.cjs.map → cards-BiYdorB0.cjs.map} +1 -1
  148. package/dist/{cards-BKi8MxNx.js → cards-fn61xD_5.js} +17 -17
  149. package/dist/{cards-BKi8MxNx.js.map → cards-fn61xD_5.js.map} +1 -1
  150. package/dist/cards.cjs +1 -1
  151. package/dist/cards.js +2 -2
  152. package/dist/{cn-DYFxgzi2.cjs → cn-CU5TNITO.cjs} +1 -1
  153. package/dist/{cn-DYFxgzi2.cjs.map → cn-CU5TNITO.cjs.map} +1 -1
  154. package/dist/{cn-CUSXNnjF.js → cn-YER3QsV1.js} +1 -1
  155. package/dist/{cn-CUSXNnjF.js.map → cn-YER3QsV1.js.map} +1 -1
  156. package/dist/controls-C5PtrGZf.cjs +2 -0
  157. package/dist/{controls-B7wV_kjJ.cjs.map → controls-C5PtrGZf.cjs.map} +1 -1
  158. package/dist/{controls-BEi-0mf4.js → controls-DCtMOoQe.js} +6 -6
  159. package/dist/{controls-BEi-0mf4.js.map → controls-DCtMOoQe.js.map} +1 -1
  160. package/dist/controls.cjs +1 -1
  161. package/dist/controls.js +5 -5
  162. package/dist/cookie-consent-bootstrap.cjs +1 -1
  163. package/dist/cookie-consent-bootstrap.js +1 -1
  164. package/dist/core-AKWkE8Bx.cjs +4 -0
  165. package/dist/core-AKWkE8Bx.cjs.map +1 -0
  166. package/dist/core-CB9-PTLK.js +854 -0
  167. package/dist/core-CB9-PTLK.js.map +1 -0
  168. package/dist/cpp-DyKt1H8n.cjs +2 -0
  169. package/dist/cpp-DyKt1H8n.cjs.map +1 -0
  170. package/dist/cpp-OOenfB17.js +227 -0
  171. package/dist/cpp-OOenfB17.js.map +1 -0
  172. package/dist/{creditCards-BB11bW7D.js → creditCards-CCysEwry.js} +1 -1
  173. package/dist/{creditCards-BB11bW7D.js.map → creditCards-CCysEwry.js.map} +1 -1
  174. package/dist/{creditCards-198KJN0s.cjs → creditCards-ljs044xt.cjs} +1 -1
  175. package/dist/{creditCards-198KJN0s.cjs.map → creditCards-ljs044xt.cjs.map} +1 -1
  176. package/dist/css-DxVbPJLu.cjs +2 -0
  177. package/dist/css-DxVbPJLu.cjs.map +1 -0
  178. package/dist/css-u5LSEAra.js +142 -0
  179. package/dist/css-u5LSEAra.js.map +1 -0
  180. package/dist/data-Bw9FSZ80.cjs +2 -0
  181. package/dist/{data-DHkccnSN.cjs.map → data-Bw9FSZ80.cjs.map} +1 -1
  182. package/dist/{data-DKrj_Hx6.js → data-CMSIr_Ac.js} +24 -24
  183. package/dist/{data-DKrj_Hx6.js.map → data-CMSIr_Ac.js.map} +1 -1
  184. package/dist/data.cjs +1 -1
  185. package/dist/data.js +3 -3
  186. package/dist/{dateUtils-Ben8lfvV.js → dateUtils-CUY6CRCf.js} +1 -1
  187. package/dist/{dateUtils-Ben8lfvV.js.map → dateUtils-CUY6CRCf.js.map} +1 -1
  188. package/dist/{dateUtils-vT9rOf1J.cjs → dateUtils-Dq1vaA-D.cjs} +1 -1
  189. package/dist/{dateUtils-vT9rOf1J.cjs.map → dateUtils-Dq1vaA-D.cjs.map} +1 -1
  190. package/dist/display-BafEcBK_.cjs +3 -0
  191. package/dist/display-BafEcBK_.cjs.map +1 -0
  192. package/dist/{display-rQqBLjAN.js → display-Zxj9YHu_.js} +196 -179
  193. package/dist/display-Zxj9YHu_.js.map +1 -0
  194. package/dist/display.cjs +1 -1
  195. package/dist/display.js +3 -3
  196. package/dist/{dropdowns-BKnXb1XJ.js → dropdowns-Bw8obCYl.js} +15 -15
  197. package/dist/{dropdowns-BKnXb1XJ.js.map → dropdowns-Bw8obCYl.js.map} +1 -1
  198. package/dist/dropdowns-DN7j1HhE.cjs +2 -0
  199. package/dist/{dropdowns-cRrLY8FG.cjs.map → dropdowns-DN7j1HhE.cjs.map} +1 -1
  200. package/dist/dropdowns.cjs +1 -1
  201. package/dist/dropdowns.js +1 -1
  202. package/dist/{feedback-CIXmm0XT.js → feedback-8H3bmQw5.js} +18 -18
  203. package/dist/{feedback-CIXmm0XT.js.map → feedback-8H3bmQw5.js.map} +1 -1
  204. package/dist/feedback-Di0SEpRe.cjs +2 -0
  205. package/dist/{feedback-DiMptPJy.cjs.map → feedback-Di0SEpRe.cjs.map} +1 -1
  206. package/dist/feedback.cjs +1 -1
  207. package/dist/feedback.js +6 -6
  208. package/dist/form-BYz99Py5.cjs +2 -0
  209. package/dist/{form-DABPazeN.cjs.map → form-BYz99Py5.cjs.map} +1 -1
  210. package/dist/{form-DZJxDW59.js → form-JHlvtP9r.js} +2 -2
  211. package/dist/{form-DZJxDW59.js.map → form-JHlvtP9r.js.map} +1 -1
  212. package/dist/form.cjs +1 -1
  213. package/dist/form.js +1 -1
  214. package/dist/{formatters-CauWlsnM.cjs → formatters-CNjg_h7-.cjs} +1 -1
  215. package/dist/{formatters-CauWlsnM.cjs.map → formatters-CNjg_h7-.cjs.map} +1 -1
  216. package/dist/{formatters-Doqdu_w1.js → formatters-T0vvjMtB.js} +1 -1
  217. package/dist/{formatters-Doqdu_w1.js.map → formatters-T0vvjMtB.js.map} +1 -1
  218. package/dist/{frameworkTexts-DzujbRBe.js → frameworkTexts-CvxcWRXp.js} +2 -2
  219. package/dist/{frameworkTexts-DzujbRBe.js.map → frameworkTexts-CvxcWRXp.js.map} +1 -1
  220. package/dist/frameworkTexts-abkS5XZK.cjs +2 -0
  221. package/dist/{frameworkTexts-DPX5T2x3.cjs.map → frameworkTexts-abkS5XZK.cjs.map} +1 -1
  222. package/dist/i18n.cjs +1 -1
  223. package/dist/i18n.js +1 -1
  224. package/dist/{icons-DlNO04xH.js → icons-CfpYxnfg.js} +1 -1
  225. package/dist/{icons-DlNO04xH.js.map → icons-CfpYxnfg.js.map} +1 -1
  226. package/dist/icons-DWMgDKgt.cjs +2 -0
  227. package/dist/{icons-BJCV7W0L.cjs.map → icons-DWMgDKgt.cjs.map} +1 -1
  228. package/dist/icons.cjs +1 -1
  229. package/dist/icons.js +1 -1
  230. package/dist/illustrations.cjs +1 -1
  231. package/dist/illustrations.js +1 -1
  232. package/dist/index.cjs +1 -1
  233. package/dist/index.js +57 -57
  234. package/dist/{inputs-CmpB6eyB.js → inputs-Bcwd_UTr.js} +12 -12
  235. package/dist/{inputs-CmpB6eyB.js.map → inputs-Bcwd_UTr.js.map} +1 -1
  236. package/dist/inputs-FP545Yri.cjs +2 -0
  237. package/dist/{inputs-EZBwxk7j.cjs.map → inputs-FP545Yri.cjs.map} +1 -1
  238. package/dist/inputs.cjs +1 -1
  239. package/dist/inputs.js +4 -4
  240. package/dist/javascript-CXjsxb-I.js +438 -0
  241. package/dist/javascript-CXjsxb-I.js.map +1 -0
  242. package/dist/javascript-CzjCTQxn.cjs +2 -0
  243. package/dist/javascript-CzjCTQxn.cjs.map +1 -0
  244. package/dist/json-9Qq5guN0.cjs +2 -0
  245. package/dist/json-9Qq5guN0.cjs.map +1 -0
  246. package/dist/json-CyV5VF8D.js +38 -0
  247. package/dist/json-CyV5VF8D.js.map +1 -0
  248. package/dist/{layout-D72Y7VcW.js → layout-BpEnTocp.js} +11 -11
  249. package/dist/{layout-D72Y7VcW.js.map → layout-BpEnTocp.js.map} +1 -1
  250. package/dist/layout-rtlHrjDb.cjs +2 -0
  251. package/dist/{layout-DZiWboju.cjs.map → layout-rtlHrjDb.cjs.map} +1 -1
  252. package/dist/layout.cjs +1 -1
  253. package/dist/layout.js +5 -5
  254. package/dist/{layoutProps-Ck4VtGm9.cjs → layoutProps-B8y2XwHy.cjs} +1 -1
  255. package/dist/{layoutProps-Ck4VtGm9.cjs.map → layoutProps-B8y2XwHy.cjs.map} +1 -1
  256. package/dist/{layoutProps-Cl6d1KmH.js → layoutProps-CE5-ghKw.js} +1 -1
  257. package/dist/{layoutProps-Cl6d1KmH.js.map → layoutProps-CE5-ghKw.js.map} +1 -1
  258. package/dist/{licensing-Cbpi1toF.js → licensing-CwzqhHH9.js} +1 -1
  259. package/dist/{licensing-Cbpi1toF.js.map → licensing-CwzqhHH9.js.map} +1 -1
  260. package/dist/licensing-ezfo7ZTh.cjs +2 -0
  261. package/dist/{licensing-JchPJhVY.cjs.map → licensing-ezfo7ZTh.cjs.map} +1 -1
  262. package/dist/locale-CZyqh3ON.cjs +2 -0
  263. package/dist/{locale-DIwV_GfN.cjs.map → locale-CZyqh3ON.cjs.map} +1 -1
  264. package/dist/{locale-BNyzqXAU.js → locale-JX_gX03k.js} +1 -1
  265. package/dist/{locale-BNyzqXAU.js.map → locale-JX_gX03k.js.map} +1 -1
  266. package/dist/{media-BlGY91Na.js → media-C3M0npGW.js} +9 -9
  267. package/dist/{media-BlGY91Na.js.map → media-C3M0npGW.js.map} +1 -1
  268. package/dist/media-ClgUKDca.cjs +2 -0
  269. package/dist/{media-p643cb02.cjs.map → media-ClgUKDca.cjs.map} +1 -1
  270. package/dist/media.cjs +1 -1
  271. package/dist/media.js +3 -3
  272. package/dist/{overlays-51pBvlf9.js → overlays-CGlqD3rl.js} +7 -7
  273. package/dist/{overlays-51pBvlf9.js.map → overlays-CGlqD3rl.js.map} +1 -1
  274. package/dist/overlays-DrSGzbbA.cjs +2 -0
  275. package/dist/{overlays-8htlWp07.cjs.map → overlays-DrSGzbbA.cjs.map} +1 -1
  276. package/dist/overlays.cjs +1 -1
  277. package/dist/overlays.js +5 -5
  278. package/dist/php-Br75m0HU.cjs +3 -0
  279. package/dist/php-Br75m0HU.cjs.map +1 -0
  280. package/dist/php-deNqvHeU.js +296 -0
  281. package/dist/php-deNqvHeU.js.map +1 -0
  282. package/dist/primitives.cjs +1 -1
  283. package/dist/primitives.js +2 -2
  284. package/dist/{relativeTime-BqCuaBqb.js → relativeTime-Cr-NVzij.js} +1 -1
  285. package/dist/{relativeTime-BqCuaBqb.js.map → relativeTime-Cr-NVzij.js.map} +1 -1
  286. package/dist/{relativeTime-DUbW4O44.cjs → relativeTime-DgYBUaVm.cjs} +1 -1
  287. package/dist/{relativeTime-DUbW4O44.cjs.map → relativeTime-DgYBUaVm.cjs.map} +1 -1
  288. package/dist/style-runtime.cjs +1 -1
  289. package/dist/style-runtime.js +1 -1
  290. package/dist/styles.css +1 -1
  291. package/dist/theme-CgS-bND3.cjs +2 -0
  292. package/dist/{theme-Bnwe-wvr.cjs.map → theme-CgS-bND3.cjs.map} +1 -1
  293. package/dist/{theme-KYwqDZxJ.js → theme-D_f-cmSA.js} +1 -1
  294. package/dist/{theme-KYwqDZxJ.js.map → theme-D_f-cmSA.js.map} +1 -1
  295. package/dist/theme.cjs +1 -1
  296. package/dist/theme.js +1 -1
  297. package/dist/typescript-CRgqVaw_.cjs +2 -0
  298. package/dist/typescript-CRgqVaw_.cjs.map +1 -0
  299. package/dist/typescript-jNfCpQvl.js +523 -0
  300. package/dist/typescript-jNfCpQvl.js.map +1 -0
  301. package/dist/{typography-FCWA0UOB.js → typography-BSBsn0f8.js} +3 -3
  302. package/dist/{typography-FCWA0UOB.js.map → typography-BSBsn0f8.js.map} +1 -1
  303. package/dist/typography-Zo4Usx9I.cjs +2 -0
  304. package/dist/{typography-D1s-QFlb.cjs.map → typography-Zo4Usx9I.cjs.map} +1 -1
  305. package/dist/typography.cjs +1 -1
  306. package/dist/typography.js +5 -5
  307. package/dist/{useGhostText-BJZKdZpw.js → useGhostText-DG0bzcao.js} +1 -1
  308. package/dist/{useGhostText-BJZKdZpw.js.map → useGhostText-DG0bzcao.js.map} +1 -1
  309. package/dist/useGhostText-tv1LiSPs.cjs +2 -0
  310. package/dist/{useGhostText-D1DbIs-n.cjs.map → useGhostText-tv1LiSPs.cjs.map} +1 -1
  311. package/dist/useInteractionEffect-D1ZdNbKU.cjs +2 -0
  312. package/dist/{useInteractionEffect-CYHGHV1e.cjs.map → useInteractionEffect-D1ZdNbKU.cjs.map} +1 -1
  313. package/dist/{useInteractionEffect-ClkU3aH5.js → useInteractionEffect-DtpbVd77.js} +1 -1
  314. package/dist/{useInteractionEffect-ClkU3aH5.js.map → useInteractionEffect-DtpbVd77.js.map} +1 -1
  315. package/dist/useKeyboardNav-CkIlAagq.cjs +2 -0
  316. package/dist/{useKeyboardNav-BoibrRUF.cjs.map → useKeyboardNav-CkIlAagq.cjs.map} +1 -1
  317. package/dist/{useKeyboardNav-CBOdeTFM.js → useKeyboardNav-iEXOdEMB.js} +1 -1
  318. package/dist/{useKeyboardNav-CBOdeTFM.js.map → useKeyboardNav-iEXOdEMB.js.map} +1 -1
  319. package/dist/utils.cjs +1 -1
  320. package/dist/utils.js +10 -10
  321. package/dist/{validators-D4aTeaH0.cjs → validators-BeNTD8mf.cjs} +1 -1
  322. package/dist/{validators-D4aTeaH0.cjs.map → validators-BeNTD8mf.cjs.map} +1 -1
  323. package/dist/{validators-YZyyyLvE.js → validators-H8tNxb8O.js} +1 -1
  324. package/dist/{validators-YZyyyLvE.js.map → validators-H8tNxb8O.js.map} +1 -1
  325. package/dist/xml-0Th6YIDv.js +168 -0
  326. package/dist/xml-0Th6YIDv.js.map +1 -0
  327. package/dist/xml-C_ksWBRH.cjs +2 -0
  328. package/dist/xml-C_ksWBRH.cjs.map +1 -0
  329. package/package.json +2 -2
  330. package/dist/MAvatar-DGEQqUss.cjs +0 -2
  331. package/dist/MBadge-DcIPfPH1.cjs +0 -2
  332. package/dist/MButton-LUNWBBOV.cjs +0 -2
  333. package/dist/MCheckbox-PzknJeM2.cjs +0 -2
  334. package/dist/MDataTable-Bq6UoNJX.cjs +0 -2
  335. package/dist/MDrawer-DRqMsjMt.cjs +0 -2
  336. package/dist/MDropdownMenu-CymCQqyP.cjs +0 -2
  337. package/dist/MGalleryIllustration-BHtRFizZ.cjs +0 -2
  338. package/dist/MHeading-DHT1gORD.cjs +0 -2
  339. package/dist/MI18nProvider-Bml7Vs2-.cjs +0 -2
  340. package/dist/MImage-CxeuH-cT.cjs +0 -2
  341. package/dist/MInline-D9p9Sazp.cjs +0 -2
  342. package/dist/MInput-DDZ71Qqn.cjs +0 -2
  343. package/dist/MInputCVC-Sp2uZ5aO.cjs +0 -2
  344. package/dist/MInputSearch-30o4bcDC.cjs +0 -2
  345. package/dist/MLink-U_wAUuz1.cjs +0 -2
  346. package/dist/MModal-Czy-rR--.cjs +0 -2
  347. package/dist/MPagination-73z0sQvf.cjs +0 -2
  348. package/dist/MPopover-BW23_1Dl.cjs +0 -2
  349. package/dist/MPortal-DE3pL2Xl.cjs +0 -2
  350. package/dist/MQrCode-CMoru4dD.cjs +0 -2
  351. package/dist/MSkeleton-B0Mxe3L7.cjs +0 -2
  352. package/dist/MSlider-sH2Vt9Lw.cjs +0 -2
  353. package/dist/MSparkline-B-ld7hJu.cjs +0 -2
  354. package/dist/MStack-Cy2GplIA.cjs +0 -2
  355. package/dist/MSubText-DP9WYlwz.cjs +0 -2
  356. package/dist/MSurface-C467dVMQ.cjs +0 -2
  357. package/dist/MTag-DXqkBvqx.cjs +0 -2
  358. package/dist/MText-COzub3y4.cjs +0 -2
  359. package/dist/MTimeAgo-DWwXs48z.cjs +0 -2
  360. package/dist/MToggle-Cm3f6gm4.cjs +0 -2
  361. package/dist/MTooltip-C3PeHgV3.cjs +0 -2
  362. package/dist/cards-B75QM9JW.cjs +0 -2
  363. package/dist/chunk-350yNsax.cjs +0 -1
  364. package/dist/chunk-efA98nb6.js +0 -13
  365. package/dist/controls-B7wV_kjJ.cjs +0 -2
  366. package/dist/data-DHkccnSN.cjs +0 -2
  367. package/dist/display-DKJ6Hp3A.cjs +0 -3
  368. package/dist/display-DKJ6Hp3A.cjs.map +0 -1
  369. package/dist/display-rQqBLjAN.js.map +0 -1
  370. package/dist/dropdowns-cRrLY8FG.cjs +0 -2
  371. package/dist/feedback-DiMptPJy.cjs +0 -2
  372. package/dist/form-DABPazeN.cjs +0 -2
  373. package/dist/frameworkTexts-DPX5T2x3.cjs +0 -2
  374. package/dist/icons-BJCV7W0L.cjs +0 -2
  375. package/dist/inputs-EZBwxk7j.cjs +0 -2
  376. package/dist/layout-DZiWboju.cjs +0 -2
  377. package/dist/licensing-JchPJhVY.cjs +0 -2
  378. package/dist/locale-DIwV_GfN.cjs +0 -2
  379. package/dist/media-p643cb02.cjs +0 -2
  380. package/dist/overlays-8htlWp07.cjs +0 -2
  381. package/dist/prism-bash-DSVvpDwH.cjs +0 -2
  382. package/dist/prism-bash-DSVvpDwH.cjs.map +0 -1
  383. package/dist/prism-bash-GQKgVScr.js +0 -177
  384. package/dist/prism-bash-GQKgVScr.js.map +0 -1
  385. package/dist/prism-c-DBlZetAm.js +0 -56
  386. package/dist/prism-c-DBlZetAm.js.map +0 -1
  387. package/dist/prism-c-DwJ0sL1f.cjs +0 -2
  388. package/dist/prism-c-DwJ0sL1f.cjs.map +0 -1
  389. package/dist/prism-clike-BHy7LBAZ.cjs +0 -2
  390. package/dist/prism-clike-BHy7LBAZ.cjs.map +0 -1
  391. package/dist/prism-clike-CrtZga9r.js +0 -30
  392. package/dist/prism-clike-CrtZga9r.js.map +0 -1
  393. package/dist/prism-core-DsZQ3wSm.js +0 -299
  394. package/dist/prism-core-DsZQ3wSm.js.map +0 -1
  395. package/dist/prism-core-Z2NDHfPM.cjs +0 -2
  396. package/dist/prism-core-Z2NDHfPM.cjs.map +0 -1
  397. package/dist/prism-cpp-CXyjGEks.cjs +0 -2
  398. package/dist/prism-cpp-CXyjGEks.cjs.map +0 -1
  399. package/dist/prism-cpp-DerVaWjZ.js +0 -65
  400. package/dist/prism-cpp-DerVaWjZ.js.map +0 -1
  401. package/dist/prism-css-Bx_bUmkm.js +0 -57
  402. package/dist/prism-css-Bx_bUmkm.js.map +0 -1
  403. package/dist/prism-css-q8i9Tl0Y.cjs +0 -2
  404. package/dist/prism-css-q8i9Tl0Y.cjs.map +0 -1
  405. package/dist/prism-javascript-CC_WcCH4.cjs +0 -2
  406. package/dist/prism-javascript-CC_WcCH4.cjs.map +0 -1
  407. package/dist/prism-javascript-uSHTlCK6.js +0 -103
  408. package/dist/prism-javascript-uSHTlCK6.js.map +0 -1
  409. package/dist/prism-json-CRpBxccA.js +0 -27
  410. package/dist/prism-json-CRpBxccA.js.map +0 -1
  411. package/dist/prism-json-CvwHQDim.cjs +0 -2
  412. package/dist/prism-json-CvwHQDim.cjs.map +0 -1
  413. package/dist/prism-jsx-CSsxTxi5.js +0 -48
  414. package/dist/prism-jsx-CSsxTxi5.js.map +0 -1
  415. package/dist/prism-jsx-ZJAX6mJe.cjs +0 -2
  416. package/dist/prism-jsx-ZJAX6mJe.cjs.map +0 -1
  417. package/dist/prism-markup-Cc4COxfn.js +0 -118
  418. package/dist/prism-markup-Cc4COxfn.js.map +0 -1
  419. package/dist/prism-markup-RTw80xRC.cjs +0 -2
  420. package/dist/prism-markup-RTw80xRC.cjs.map +0 -1
  421. package/dist/prism-markup-templating-CylI3Gpj.cjs +0 -2
  422. package/dist/prism-markup-templating-CylI3Gpj.cjs.map +0 -1
  423. package/dist/prism-markup-templating-D4w8OHUw.js +0 -41
  424. package/dist/prism-markup-templating-D4w8OHUw.js.map +0 -1
  425. package/dist/prism-php-CMZ7fRp0.cjs +0 -2
  426. package/dist/prism-php-CMZ7fRp0.cjs.map +0 -1
  427. package/dist/prism-php-nJ_CzHXP.js +0 -279
  428. package/dist/prism-php-nJ_CzHXP.js.map +0 -1
  429. package/dist/prism-tsx-CvHlXV3S.cjs +0 -2
  430. package/dist/prism-tsx-CvHlXV3S.cjs.map +0 -1
  431. package/dist/prism-tsx-UlwV29L3.js +0 -10
  432. package/dist/prism-tsx-UlwV29L3.js.map +0 -1
  433. package/dist/prism-typescript-BA7hsZPZ.js +0 -40
  434. package/dist/prism-typescript-BA7hsZPZ.js.map +0 -1
  435. package/dist/prism-typescript-CDAVIXup.cjs +0 -2
  436. package/dist/prism-typescript-CDAVIXup.cjs.map +0 -1
  437. package/dist/theme-Bnwe-wvr.cjs +0 -2
  438. package/dist/typography-D1s-QFlb.cjs +0 -2
  439. package/dist/useGhostText-D1DbIs-n.cjs +0 -2
  440. package/dist/useInteractionEffect-CYHGHV1e.cjs +0 -2
  441. package/dist/useKeyboardNav-BoibrRUF.cjs +0 -2
@@ -1 +1 @@
1
- {"version":3,"file":"dropdowns-cRrLY8FG.cjs","names":[],"sources":["../src/components/dropdowns/MSelect/MSelect.tsx","../src/components/dropdowns/MAutocomplete/MAutocomplete.tsx","../src/utils/colorRgbVar.ts","../src/components/dropdowns/MDatePicker/MDatePicker.tsx","../src/components/dropdowns/MTimePicker/MTimePicker.tsx","../src/components/dropdowns/MDateRangePicker/MDateRangePicker.tsx"],"sourcesContent":["import {useState, useRef, useCallback, useMemo} from 'react'\nimport type * as React from 'react'\nimport type {MSelectProps, MSelectOption} from './MSelect.types'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useKeyboardNav} from '../../../utils/useKeyboardNav'\nimport {MCheckbox} from '../../controls'\nimport {MSpinner, MTag} from '../../feedback'\nimport {MChevronDownIcon, MCloseIcon} from '../../../icons'\nimport './MSelect.css'\n\n// Render a selectable list with optional search, grouping and multi-select tags.\nexport function MSelect({\n options,\n value,\n defaultValue,\n onChange,\n multiple = false,\n searchable = false,\n placeholder = 'MSelect...',\n disabled = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n fullWidth = false,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n loading = false,\n clearable = false,\n maxHeight = 300,\n noOptionsText = 'No options',\n renderOption,\n renderValue,\n className,\n style,\n}: MSelectProps) {\n const [open, setOpen] = useState(false)\n const [internalValue, setInternalValue] = useState<string | string[]>(defaultValue ?? (multiple ? [] : ''))\n const [search, setSearch] = useState('')\n const triggerRef = useRef<HTMLDivElement>(null)\n\n const currentValue = value !== undefined ? value : internalValue\n const hasError = error || !!errorText\n\n // Normalize the public value into a string array for rendering and selection logic.\n const selectedValues = useMemo(() => {\n if (Array.isArray(currentValue)) return currentValue\n return currentValue ? [currentValue] : []\n }, [currentValue])\n\n const selectedOptions = useMemo(\n () => options.filter((o) => selectedValues.includes(o.value)),\n [options, selectedValues]\n )\n\n // Filter options locally when the searchable mode is active.\n const filteredOptions = useMemo(() => {\n if (!searchable || !search) return options\n const lower = search.toLowerCase()\n return options.filter((o) => o.label.toLowerCase().includes(lower))\n }, [options, searchable, search])\n\n // Group options\n // Preserve group headers without changing the flat keyboard navigation index map.\n const groupedOptions = useMemo(() => {\n const groups = new Map<string, MSelectOption[]>()\n for (const opt of filteredOptions) {\n const key = opt.group ?? ''\n if (!groups.has(key)) groups.set(key, [])\n groups.get(key)!.push(opt)\n }\n return groups\n }, [filteredOptions])\n\n const flatFiltered = filteredOptions\n\n // MToggle or replace the current selection depending on the mode.\n const handleSelect = useCallback(\n (index: number) => {\n const opt = flatFiltered[index]\n if (!opt || opt.disabled) return\n\n if (multiple) {\n const arr = Array.isArray(currentValue) ? currentValue : []\n const newVal = arr.includes(opt.value) ? arr.filter((v) => v !== opt.value) : [...arr, opt.value]\n if (value === undefined) setInternalValue(newVal)\n onChange?.(newVal)\n } else {\n if (value === undefined) setInternalValue(opt.value)\n onChange?.(opt.value)\n setOpen(false)\n setSearch('')\n }\n },\n [flatFiltered, multiple, currentValue, value, onChange]\n )\n\n const {activeIndex, setActiveIndex, resetIndex, onKeyDown} = useKeyboardNav({\n itemCount: flatFiltered.length,\n onSelect: handleSelect,\n onClose: () => {\n setOpen(false)\n setSearch('')\n },\n isOpen: open,\n })\n\n // Open the popover and reset keyboard navigation when the trigger is used.\n const handleTriggerClick = useCallback(() => {\n if (disabled) return\n setOpen((v) => !v)\n resetIndex()\n }, [disabled, resetIndex])\n\n // Reset the current selection without closing the outer field wrapper.\n const handleClear = useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation()\n const empty = multiple ? [] : ''\n if (value === undefined) setInternalValue(empty)\n onChange?.(empty)\n },\n [multiple, value, onChange]\n )\n\n // Render tags, labels or the placeholder based on the current selection state.\n const displayValue = useMemo(() => {\n if (renderValue && selectedOptions.length > 0) {\n return renderValue(multiple ? selectedOptions : selectedOptions[0])\n }\n if (multiple && selectedOptions.length > 0) {\n return (\n <span className=\"tags\">\n {selectedOptions.map((o) => (\n <MTag key={o.value} label={o.label} color={color} size={size} variant=\"solid\" />\n ))}\n </span>\n )\n }\n if (!multiple && selectedOptions.length > 0) {\n return selectedOptions[0].label\n }\n return <span className=\"placeholder\">{placeholder}</span>\n }, [selectedOptions, multiple, renderValue, placeholder, color, size])\n\n return (\n <div className={cn('select', color && `color-${color}`, fullWidth && 'full-width', className)} style={style}>\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={triggerRef}\n className={cn(\n 'trigger',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={handleTriggerClick}\n onKeyDown={onKeyDown as unknown as React.KeyboardEventHandler}\n tabIndex={disabled ? -1 : 0}\n role=\"combobox\"\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-invalid={hasError || undefined}\n id={id}\n >\n <span className=\"value\">{displayValue}</span>\n\n {loading && <MSpinner size=\"sm\" color={color} />}\n\n {clearable && selectedValues.length > 0 && !loading && !disabled && (\n <button\n type=\"button\"\n className=\"clear-btn clear-btn-base\"\n onClick={handleClear}\n tabIndex={-1}\n aria-label=\"Clear selection\"\n >\n <MCloseIcon />\n </button>\n )}\n\n <span className={cn('arrow', open && 'open')} aria-hidden=\"true\">\n <MChevronDownIcon />\n </span>\n </div>\n\n {/* Hidden input for form submission */}\n {name && (\n <input\n type=\"hidden\"\n name={name}\n value={Array.isArray(currentValue) ? currentValue.join(',') : currentValue}\n />\n )}\n\n <MPopover\n className={'select-popover'}\n open={open}\n anchorRef={triggerRef}\n onClose={() => {\n setOpen(false)\n setSearch('')\n }}\n matchWidth\n placement=\"bottom-start\"\n >\n <div style={{maxHeight}} className=\"dropdown\">\n {searchable && (\n <div className=\"search-box\">\n <input\n type=\"text\"\n className=\"search-input\"\n placeholder=\"Search...\"\n value={search}\n onChange={(e) => {\n setSearch(e.target.value)\n setActiveIndex(0)\n }}\n onKeyDown={onKeyDown as unknown as React.KeyboardEventHandler}\n autoFocus\n />\n </div>\n )}\n\n {flatFiltered.length === 0 ? (\n <div className=\"no-options\">{noOptionsText}</div>\n ) : (\n <div className=\"options-list\" role=\"listbox\">\n {[...groupedOptions.entries()].map(([group, opts]) => (\n <div key={group}>\n {group && <div className=\"group-header\">{group}</div>}\n {opts.map((opt) => {\n const flatIndex = flatFiltered.indexOf(opt)\n const isActive = flatIndex === activeIndex\n const isSelected = selectedValues.includes(opt.value)\n return (\n <div\n key={opt.value}\n className={cn(\n 'option',\n isActive && 'active',\n isSelected && 'selected',\n opt.disabled && 'disabled'\n )}\n onClick={() => !opt.disabled && handleSelect(flatIndex)}\n onMouseEnter={() => setActiveIndex(flatIndex)}\n role=\"option\"\n aria-selected={isSelected}\n aria-disabled={opt.disabled}\n >\n {multiple && (\n <MCheckbox\n checked={isSelected}\n size=\"sm\"\n color={color}\n clickEffect=\"none\"\n className=\"select-check\"\n />\n )}\n {renderOption ? renderOption(opt, isActive, isSelected) : opt.label}\n </div>\n )\n })}\n </div>\n ))}\n </div>\n )}\n </div>\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"bottom-row\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"helper-text\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n","import {useState, useRef, useCallback, useMemo} from 'react'\nimport type * as React from 'react'\nimport type {MAutocompleteProps} from './MAutocomplete.types'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useKeyboardNav} from '../../../utils/useKeyboardNav'\nimport {useDebouncedCallback} from '../../../utils/useDebounce'\nimport {MSpinner, MTag} from '../../feedback'\nimport {MCloseIcon} from '../../../icons'\nimport './MAutocomplete.css'\n\n// Resolve labels for primitive string options without extra configuration.\nfunction defaultGetLabel<T>(option: T): string {\n if (typeof option === 'string') return option\n return String(option)\n}\n\n// Resolve values for primitive string options without extra configuration.\nfunction defaultGetValue<T>(option: T): string {\n if (typeof option === 'string') return option\n return String(option)\n}\n\n// Apply a basic case-insensitive filter when the caller does not provide one.\nfunction defaultFilter<T>(options: T[], input: string, getLabel: (o: T) => string): T[] {\n if (!input) return options\n const lower = input.toLowerCase()\n return options.filter((o) => getLabel(o).toLowerCase().includes(lower))\n}\n\n// Render a searchable suggestion list with optional multi-tag behavior.\nexport function MAutocomplete<T = string>({\n options,\n value,\n onChange,\n getOptionLabel = defaultGetLabel,\n getOptionValue = defaultGetValue,\n filterOptions,\n multiple = false,\n debounceMs = 0,\n onInputChange,\n loading = false,\n loadingText = 'Loading...',\n noOptionsText = 'No options',\n placeholder = 'Type to search...',\n disabled = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n fullWidth = false,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n maxHeight = 300,\n renderOption,\n renderTags,\n className,\n style,\n}: MAutocompleteProps<T>) {\n const [open, setOpen] = useState(false)\n const [inputValue, setInputValue] = useState('')\n const wrapperRef = useRef<HTMLDivElement>(null)\n const inputRef = useRef<HTMLInputElement>(null)\n\n const hasError = error || !!errorText\n\n // Normalize the public value into an array for tag and selection rendering.\n const selectedValues = useMemo(() => {\n if (value == null) return []\n return Array.isArray(value) ? value.filter((item) => item != null) : [value]\n }, [value])\n\n // Filter suggestions locally unless the caller owns that logic.\n const filtered = useMemo(() => {\n if (filterOptions) return filterOptions(options, inputValue)\n return defaultFilter(options, inputValue, getOptionLabel)\n }, [options, inputValue, filterOptions, getOptionLabel])\n\n const debouncedInputChange = useDebouncedCallback((val: string) => onInputChange?.(val), debounceMs)\n\n // Update the visible query and optionally notify async search logic.\n const handleInputChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n setInputValue(e.target.value)\n debouncedInputChange(e.target.value)\n if (!open) setOpen(true)\n },\n [open, debouncedInputChange]\n )\n\n // Apply a selected option to single or multiple value modes.\n const handleSelect = useCallback(\n (index: number) => {\n const opt = filtered[index]\n if (!opt) return\n\n if (multiple) {\n const arr = [...selectedValues]\n const val = getOptionValue(opt)\n const existIdx = arr.findIndex((v) => getOptionValue(v) === val)\n if (existIdx >= 0) {\n arr.splice(existIdx, 1)\n } else {\n arr.push(opt)\n }\n onChange?.(arr)\n setInputValue('')\n inputRef.current?.focus()\n } else {\n onChange?.(opt)\n setInputValue(getOptionLabel(opt))\n setOpen(false)\n }\n },\n [filtered, multiple, selectedValues, getOptionValue, getOptionLabel, onChange]\n )\n\n // Remove a selected tag by index in multiple mode.\n const handleRemoveTag = useCallback(\n (index: number) => {\n const arr = [...selectedValues]\n arr.splice(index, 1)\n onChange?.(multiple ? arr : (arr[0] ?? ('' as unknown as T)))\n },\n [selectedValues, onChange, multiple]\n )\n\n const {\n activeIndex,\n setActiveIndex,\n resetIndex,\n onKeyDown: navKeyDown,\n } = useKeyboardNav({\n itemCount: filtered.length,\n onSelect: handleSelect,\n onClose: () => setOpen(false),\n isOpen: open,\n })\n\n // Combine tag removal and list navigation.\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n // Backspace removes last tag in multiple\n if (e.key === 'Backspace' && multiple && !inputValue && selectedValues.length > 0) {\n handleRemoveTag(selectedValues.length - 1)\n return\n }\n navKeyDown(e as unknown as React.KeyboardEvent)\n },\n [inputValue, multiple, selectedValues, navKeyDown, handleRemoveTag]\n )\n\n // Clear the input query and the selected value(s) together.\n const handleClear = useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation()\n setInputValue('')\n onChange?.(multiple ? ([] as unknown as T) : ('' as unknown as T))\n inputRef.current?.focus()\n },\n [multiple, onChange]\n )\n\n return (\n <div\n className={cn('autocomplete', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={wrapperRef}\n className={cn(\n 'input-wrapper',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={() => inputRef.current?.focus()}\n >\n {multiple &&\n selectedValues.length > 0 &&\n (renderTags ? (\n renderTags(selectedValues, handleRemoveTag)\n ) : (\n <span className=\"tags\">\n {selectedValues.map((v, i) => (\n <MTag\n key={getOptionValue(v)}\n label={getOptionLabel(v)}\n color={color}\n size={size}\n variant=\"solid\"\n closable\n onClose={() => handleRemoveTag(i)}\n />\n ))}\n </span>\n ))}\n\n <input\n ref={inputRef}\n type=\"text\"\n className=\"input\"\n value={inputValue}\n onChange={handleInputChange}\n onFocus={() => {\n setOpen(true)\n resetIndex()\n }}\n onKeyDown={handleKeyDown}\n placeholder={selectedValues.length > 0 ? '' : placeholder}\n disabled={disabled}\n id={id}\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-invalid={hasError || undefined}\n autoComplete=\"off\"\n />\n\n {loading && <MSpinner size=\"sm\" color={color} />}\n\n {clearable && (selectedValues.length > 0 || inputValue) && !loading && !disabled && (\n <button type=\"button\" className=\"clear-btn clear-btn-base\" onClick={handleClear} tabIndex={-1}>\n <MCloseIcon />\n </button>\n )}\n </div>\n\n {name && <input type=\"hidden\" name={name} value={selectedValues.map(getOptionValue).join(',')} />}\n\n <MPopover\n className={cn('autocomplete-popover', color && `color-${color}`)}\n open={open && (filtered.length > 0 || loading || !!inputValue)}\n anchorRef={wrapperRef}\n onClose={() => setOpen(false)}\n matchWidth\n placement=\"bottom-start\"\n >\n <div style={{maxHeight}} className=\"dropdown\">\n {loading ? (\n <div className=\"loading-msg\">{loadingText}</div>\n ) : filtered.length === 0 ? (\n <div className=\"no-options\">{noOptionsText}</div>\n ) : (\n <div className=\"options-list\" role=\"listbox\">\n {filtered.map((opt, i) => {\n const isActive = i === activeIndex\n const isSelected = selectedValues.some((v) => getOptionValue(v) === getOptionValue(opt))\n return (\n <div\n key={getOptionValue(opt)}\n className={cn('option', isActive && 'active', isSelected && 'selected')}\n onClick={() => handleSelect(i)}\n onMouseEnter={() => setActiveIndex(i)}\n role=\"option\"\n aria-selected={isSelected}\n >\n {renderOption ? renderOption(opt, isActive) : getOptionLabel(opt)}\n </div>\n )\n })}\n </div>\n )}\n </div>\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"bottom-row\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"helper-text\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n","const COLOR_MAP: Record<string, string> = {\n primary: 'var(--mineral-primary-rgb)',\n neutral: 'var(--mineral-neutral-rgb)',\n success: 'var(--mineral-success-rgb)',\n error: 'var(--mineral-error-rgb)',\n warning: 'var(--mineral-warning-rgb)',\n info: 'var(--mineral-info-rgb)',\n light: 'var(--mineral-light-rgb)',\n dark: 'var(--mineral-dark-color-rgb)',\n news: 'var(--mineral-news-rgb)',\n}\n\nexport function colorRgbVar(color: string | undefined): string {\n return COLOR_MAP[color ?? 'primary'] ?? COLOR_MAP.primary\n}\n","import {useState, useRef, useCallback, useMemo, useEffect} from 'react'\nimport type * as React from 'react'\nimport type {MDatePickerProps} from './MDatePicker.types'\nimport type {MDateFormat} from '../../inputs'\nimport {MInput} from '../../inputs'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useMDatePickerTexts} from '../../../i18n/frameworkTexts'\nimport {useDocumentLocale} from '../../../utils/locale'\nimport type {ValidationResult} from '../../../utils/validators'\nimport {parseDateString, validateDate} from '../../../utils/validators'\nimport {stripNonDigits, formatDateInput} from '../../../utils/formatters'\nimport {colorRgbVar} from '../../../utils/colorRgbVar'\nimport {\n formatDate,\n daysInMonth,\n firstDayOfMonth,\n isSameDay,\n isDateInRange,\n getDayNames,\n getMonthNames,\n addMonths,\n stripTime,\n combineDateAndTime,\n formatHiddenDateValue,\n formatTimeWithFormat,\n parseTimeWithFormat,\n} from '../../../utils/dateUtils'\nimport {\n MCalendarIcon,\n MChevronLeftIcon as ChevronLeftGlyphIcon,\n MChevronRightIcon as ChevronRightGlyphIcon,\n} from '../../../icons'\nimport './MDatePicker.css'\n\nconst DATE_UNAVAILABLE_ERROR = 'Date is unavailable'\nconst INVALID_TIME_ERROR = 'Invalid time'\n\ntype Meridiem = 'AM' | 'PM'\n\ntype MDatePickerInputConfig = {\n inputFormat: MDateFormat\n separator: '/' | '.' | '-'\n}\n\ntype ParsedInputState =\n | {status: 'empty'}\n | {status: 'partial'; datePart: string; timePart: string}\n | {status: 'invalid'; datePart: string; timePart: string; result: ValidationResult}\n | {status: 'valid'; datePart: string; timePart: string; value: Date}\n\nfunction toDate(value: Date | string | undefined): Date | null {\n if (!value) return null\n if (value instanceof Date) return isNaN(value.getTime()) ? null : new Date(value.getTime())\n\n const date = new Date(value)\n return isNaN(date.getTime()) ? null : date\n}\n\nfunction normalizeDatePickerFormat(format: string): MDatePickerInputConfig {\n const normalizedFormat = format.replace(/DD/g, 'dd').replace(/YYYY/g, 'yyyy')\n const tokens = normalizedFormat.match(/dd|MM|yyyy/g)\n const detectedSeparator = normalizedFormat.match(/[^dMy]/)?.[0]\n const separator =\n detectedSeparator === '/' || detectedSeparator === '.' || detectedSeparator === '-' ? detectedSeparator : '.'\n const order = tokens?.join('/')\n\n switch (order) {\n case 'MM/dd/yyyy':\n return {inputFormat: 'MM/DD/YYYY', separator}\n case 'yyyy/MM/dd':\n return {inputFormat: 'YYYY/MM/DD', separator}\n case 'dd/MM/yyyy':\n default:\n return {inputFormat: 'DD/MM/YYYY', separator}\n }\n}\n\nfunction getDefaultTimePlaceholder(format: '24h' | '12h', showSeconds: boolean): string {\n if (format === '12h') {\n return showSeconds ? 'hh:mm:ss AM' : 'hh:mm AM'\n }\n\n return showSeconds ? 'HH:MM:SS' : 'HH:MM'\n}\n\nfunction getInputPlaceholder(\n basePlaceholder: string | undefined,\n dateFormat: string,\n withTime: boolean,\n timeFormat: '24h' | '12h',\n showSeconds: boolean,\n timePlaceholder?: string\n): string {\n if (basePlaceholder) {\n return basePlaceholder\n }\n\n if (!withTime) {\n return dateFormat\n }\n\n return `${dateFormat} ${timePlaceholder ?? getDefaultTimePlaceholder(timeFormat, showSeconds)}`\n}\n\nfunction formatDisplayValue(\n date: Date | null,\n options: {\n format: string\n withTime: boolean\n timeFormat: '24h' | '12h'\n showSeconds: boolean\n }\n): string {\n if (!date) return ''\n\n const datePart = formatDate(stripTime(date), options.format)\n\n if (!options.withTime) {\n return datePart\n }\n\n return `${datePart} ${formatTimeWithFormat(\n date.getHours(),\n date.getMinutes(),\n date.getSeconds(),\n options.showSeconds,\n options.timeFormat\n )}`\n}\n\nfunction formatTimeDraft(digits: string, showSeconds: boolean): string {\n if (!digits) return ''\n\n if (digits.length <= 2) return digits\n if (digits.length <= 4) return `${digits.slice(0, 2)}:${digits.slice(2)}`\n if (!showSeconds) return `${digits.slice(0, 2)}:${digits.slice(2, 4)}`\n return `${digits.slice(0, 2)}:${digits.slice(2, 4)}:${digits.slice(4, 6)}`\n}\n\nfunction normalizeMeridiemDraft(value: string): string {\n const letters = value.toUpperCase().replace(/[^APM]/g, '')\n\n if (!letters) return ''\n if (letters.startsWith('AM')) return 'AM'\n if (letters.startsWith('PM')) return 'PM'\n if (letters.startsWith('A')) return 'A'\n if (letters.startsWith('P')) return 'P'\n\n return ''\n}\n\nfunction splitInputValue(value: string, withTime: boolean) {\n const trimmed = value.trim()\n\n if (!trimmed) {\n return {datePart: '', timePart: ''}\n }\n\n if (!withTime) {\n return {datePart: trimmed, timePart: ''}\n }\n\n const firstSpaceIndex = trimmed.indexOf(' ')\n\n if (firstSpaceIndex === -1) {\n return {datePart: trimmed, timePart: ''}\n }\n\n return {\n datePart: trimmed.slice(0, firstSpaceIndex).trim(),\n timePart: trimmed.slice(firstSpaceIndex + 1).trim(),\n }\n}\n\nfunction formatTypedInput(\n rawValue: string,\n options: {\n inputFormat: MDateFormat\n separator: '/' | '.' | '-'\n withTime: boolean\n timeFormat: '24h' | '12h'\n showSeconds: boolean\n }\n) {\n const normalizedValue = rawValue.toUpperCase()\n const digits = stripNonDigits(normalizedValue)\n const dateDigits = digits.slice(0, 8)\n const timeDigits = options.withTime ? digits.slice(8, 8 + (options.showSeconds ? 6 : 4)) : ''\n const datePart = formatDateInput(dateDigits, options.inputFormat, options.separator)\n\n if (!options.withTime) {\n return {formatted: datePart, datePart, timePart: ''}\n }\n\n const timeBase = formatTimeDraft(timeDigits, options.showSeconds)\n const meridiem = options.timeFormat === '12h' ? normalizeMeridiemDraft(normalizedValue) : ''\n const timePart = `${timeBase}${meridiem ? `${timeBase ? ' ' : ''}${meridiem}` : ''}`.trim()\n\n if (!datePart) {\n return {formatted: timePart, datePart: '', timePart}\n }\n\n return {\n formatted: timePart ? `${datePart} ${timePart}` : datePart,\n datePart,\n timePart,\n }\n}\n\nfunction getTimeDraftFromDate(date: Date | null, showSeconds: boolean): string {\n if (!date) return ''\n return formatTimeWithFormat(date.getHours(), date.getMinutes(), date.getSeconds(), showSeconds, '24h')\n}\n\nfunction parseInputValue(\n value: string,\n options: {\n inputFormat: MDateFormat\n minDate: Date | null\n maxDate: Date | null\n withTime: boolean\n timeFormat: '24h' | '12h'\n showSeconds: boolean\n isDisabled: (date: Date) => boolean\n }\n): ParsedInputState {\n const {datePart, timePart} = splitInputValue(value, options.withTime)\n\n if (!datePart && !timePart) {\n return {status: 'empty'}\n }\n\n const validation = validateDate(datePart, {\n format: options.inputFormat,\n minDate: options.minDate ?? undefined,\n maxDate: options.maxDate ?? undefined,\n })\n\n if (!validation.valid) {\n return validation.error === 'Incomplete date'\n ? {status: 'partial', datePart, timePart}\n : {status: 'invalid', datePart, timePart, result: validation}\n }\n\n const parsedDate = parseDateString(datePart, options.inputFormat)\n\n if (!parsedDate) {\n return {status: 'invalid', datePart, timePart, result: {valid: false, error: 'Invalid date'}}\n }\n\n if (options.isDisabled(parsedDate)) {\n return {status: 'invalid', datePart, timePart, result: {valid: false, error: DATE_UNAVAILABLE_ERROR}}\n }\n\n if (!options.withTime) {\n return {status: 'valid', datePart, timePart: '', value: stripTime(parsedDate)}\n }\n\n if (!timePart) {\n return {\n status: 'valid',\n datePart,\n timePart: '',\n value: combineDateAndTime(parsedDate, '', {format: options.timeFormat, showSeconds: options.showSeconds}),\n }\n }\n\n const parsedTime = parseTimeWithFormat(timePart, options.timeFormat)\n\n if (!parsedTime) {\n return {status: 'invalid', datePart, timePart, result: {valid: false, error: INVALID_TIME_ERROR}}\n }\n\n return {\n status: 'valid',\n datePart,\n timePart,\n value: combineDateAndTime(parsedDate, timePart, {format: options.timeFormat, showSeconds: options.showSeconds}),\n }\n}\n\nfunction to12HourParts(value: {hours: number; minutes: number; seconds: number}) {\n const meridiem: Meridiem = value.hours >= 12 ? 'PM' : 'AM'\n const hours = value.hours % 12 || 12\n return {hours, minutes: value.minutes, seconds: value.seconds, meridiem}\n}\n\nfunction to24HourValue(hours: number, meridiem: Meridiem): number {\n if (meridiem === 'AM') {\n return hours === 12 ? 0 : hours\n }\n\n return hours === 12 ? 12 : hours + 12\n}\n\nexport function MDatePicker({\n value,\n defaultValue,\n onChange,\n format = 'dd.MM.yyyy',\n locale: localeOverride,\n min,\n max,\n disabledDates,\n placeholder,\n disabled = false,\n readOnly = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n withTime = false,\n validateOnBlur = true,\n validateOnChange = false,\n onValidationChange,\n timeFormat = '24h',\n showSeconds = false,\n minuteStep = 1,\n timePlaceholder,\n inline = false,\n showTodayButton = true,\n firstDayOfWeek = 1,\n fullWidth = false,\n className,\n style,\n}: MDatePickerProps) {\n const locale = useDocumentLocale(localeOverride)\n const texts = useMDatePickerTexts()\n const {inputFormat, separator} = useMemo(() => normalizeDatePickerFormat(format), [format])\n const [open, setOpen] = useState(false)\n const [internalValue, setInternalValue] = useState<Date | null>(() => toDate(defaultValue))\n const [validationState, setValidationState] = useState<ValidationResult>({valid: true})\n const [touched, setTouched] = useState(false)\n const selectedValue = value !== undefined ? toDate(value) : internalValue\n const [inputValue, setInputValue] = useState(() =>\n formatDisplayValue(selectedValue, {format, withTime, timeFormat, showSeconds})\n )\n const [draftTimeValue, setDraftTimeValue] = useState(() => getTimeDraftFromDate(selectedValue, showSeconds))\n const [viewDate, setViewDate] = useState(() => {\n const baseDate = selectedValue ? stripTime(selectedValue) : new Date()\n return new Date(baseDate.getFullYear(), baseDate.getMonth(), 1)\n })\n const [viewMode, setViewMode] = useState<'days' | 'months'>('days')\n const anchorRef = useRef<HTMLDivElement>(null)\n const selectedValueKey = selectedValue?.getTime() ?? null\n const minDate = toDate(min)\n const maxDate = toDate(max)\n const hasError = error || (touched && !validationState.valid)\n const resolvedErrorText = errorText || (touched && !validationState.valid ? validationState.error : undefined)\n const dayNames = getDayNames(locale, firstDayOfWeek)\n const monthNames = getMonthNames(locale)\n\n useEffect(() => {\n setInputValue(formatDisplayValue(selectedValue, {format, withTime, timeFormat, showSeconds}))\n setDraftTimeValue(getTimeDraftFromDate(selectedValue, showSeconds))\n if (selectedValue) {\n const normalizedDate = stripTime(selectedValue)\n setViewDate(new Date(normalizedDate.getFullYear(), normalizedDate.getMonth(), 1))\n }\n }, [format, selectedValueKey, showSeconds, timeFormat, withTime])\n\n const isDisabled = useCallback(\n (date: Date): boolean => {\n if (!isDateInRange(date, minDate, maxDate)) return true\n if (Array.isArray(disabledDates)) {\n return disabledDates.some((disabledDate) => isSameDay(disabledDate, date))\n }\n if (typeof disabledDates === 'function') {\n return disabledDates(date)\n }\n return false\n },\n [disabledDates, maxDate, minDate]\n )\n\n const emitValidation = useCallback(\n (result: ValidationResult) => {\n setValidationState(result)\n onValidationChange?.(result)\n },\n [onValidationChange]\n )\n\n const commitValue = useCallback(\n (nextValue: Date | null) => {\n if (value === undefined) {\n setInternalValue(nextValue)\n }\n\n onChange?.(nextValue)\n },\n [onChange, value]\n )\n\n const parsedInputState = useMemo(\n () =>\n parseInputValue(inputValue, {\n inputFormat,\n minDate,\n maxDate,\n withTime,\n timeFormat,\n showSeconds,\n isDisabled,\n }),\n [inputFormat, inputValue, isDisabled, maxDate, minDate, showSeconds, timeFormat, withTime]\n )\n\n const currentDateForPanel = useMemo(() => {\n if (parsedInputState.status === 'valid') {\n return stripTime(parsedInputState.value)\n }\n\n return selectedValue ? stripTime(selectedValue) : null\n }, [parsedInputState, selectedValue])\n\n const currentTimeForPanel = useMemo(() => {\n if (!withTime) return null\n\n const timeSource =\n parsedInputState.status !== 'empty' && parsedInputState.timePart\n ? parsedInputState.timePart\n : draftTimeValue || getTimeDraftFromDate(selectedValue, showSeconds)\n\n return parseTimeWithFormat(timeSource, timeFormat) ?? {hours: 0, minutes: 0, seconds: 0}\n }, [draftTimeValue, parsedInputState, selectedValue, showSeconds, timeFormat, withTime])\n\n const handleInputChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const nextTyped = formatTypedInput(event.target.value, {\n inputFormat,\n separator,\n withTime,\n timeFormat,\n showSeconds,\n })\n\n setInputValue(nextTyped.formatted)\n setDraftTimeValue(nextTyped.timePart)\n\n const nextParsedState = parseInputValue(nextTyped.formatted, {\n inputFormat,\n minDate,\n maxDate,\n withTime,\n timeFormat,\n showSeconds,\n isDisabled,\n })\n\n if (nextParsedState.status === 'empty') {\n emitValidation({valid: true})\n commitValue(null)\n return\n }\n\n if (nextParsedState.status === 'invalid' && validateOnChange) {\n emitValidation(nextParsedState.result)\n } else if (nextParsedState.status === 'valid') {\n emitValidation({valid: true})\n commitValue(nextParsedState.value)\n setViewDate(new Date(nextParsedState.value.getFullYear(), nextParsedState.value.getMonth(), 1))\n }\n },\n [\n commitValue,\n emitValidation,\n inputFormat,\n isDisabled,\n maxDate,\n minDate,\n separator,\n showSeconds,\n timeFormat,\n validateOnChange,\n withTime,\n ]\n )\n\n const handleInputBlur = useCallback(() => {\n setTouched(true)\n\n const nextParsedState = parseInputValue(inputValue, {\n inputFormat,\n minDate,\n maxDate,\n withTime,\n timeFormat,\n showSeconds,\n isDisabled,\n })\n\n if (nextParsedState.status === 'empty') {\n emitValidation({valid: true})\n return\n }\n\n if (nextParsedState.status === 'partial') {\n if (validateOnBlur) {\n emitValidation({valid: false, error: 'Incomplete date'})\n }\n return\n }\n\n if (nextParsedState.status === 'invalid') {\n if (validateOnBlur) {\n emitValidation(nextParsedState.result)\n }\n return\n }\n\n emitValidation({valid: true})\n setInputValue(formatDisplayValue(nextParsedState.value, {format, withTime, timeFormat, showSeconds}))\n setDraftTimeValue(getTimeDraftFromDate(nextParsedState.value, showSeconds))\n commitValue(nextParsedState.value)\n }, [\n commitValue,\n emitValidation,\n format,\n inputFormat,\n inputValue,\n isDisabled,\n maxDate,\n minDate,\n showSeconds,\n timeFormat,\n validateOnBlur,\n withTime,\n ])\n\n const handleInputKeyDown = useCallback(\n (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (['Backspace', 'Delete', 'Tab', 'ArrowLeft', 'ArrowRight', 'Home', 'End', 'Enter'].includes(event.key)) {\n return\n }\n\n if (event.ctrlKey || event.metaKey) {\n return\n }\n\n const allowCharacter = withTime ? /^[0-9\\s:./-APMapm]$/ : /^[0-9./-]$/\n\n if (!allowCharacter.test(event.key)) {\n event.preventDefault()\n }\n },\n [withTime]\n )\n\n const handleClear = useCallback(() => {\n setInputValue('')\n setDraftTimeValue('')\n setTouched(false)\n emitValidation({valid: true})\n commitValue(null)\n }, [commitValue, emitValidation])\n\n const handleTogglePopover = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault()\n event.stopPropagation()\n\n if (disabled || readOnly || inline) return\n\n setOpen((current) => !current)\n },\n [disabled, inline, readOnly]\n )\n\n const handleSelectDate = useCallback(\n (date: Date) => {\n if (isDisabled(date)) return\n\n const nextTime = withTime ? draftTimeValue || formatTimeWithFormat(0, 0, 0, showSeconds, timeFormat) : ''\n const nextValue = withTime\n ? combineDateAndTime(date, nextTime, {format: timeFormat, showSeconds})\n : stripTime(date)\n\n setTouched(true)\n emitValidation({valid: true})\n setDraftTimeValue(nextTime)\n setInputValue(formatDisplayValue(nextValue, {format, withTime, timeFormat, showSeconds}))\n setViewDate(new Date(date.getFullYear(), date.getMonth(), 1))\n commitValue(nextValue)\n\n if (!withTime && !inline) {\n setOpen(false)\n }\n },\n [commitValue, draftTimeValue, emitValidation, format, inline, isDisabled, showSeconds, timeFormat, withTime]\n )\n\n const handleToday = useCallback(() => {\n const today = stripTime(new Date())\n\n if (isDisabled(today)) return\n\n handleSelectDate(today)\n }, [handleSelectDate, isDisabled])\n\n const hours = useMemo(() => {\n if (!withTime) return []\n\n const items: number[] = []\n const maxHour = timeFormat === '12h' ? 12 : 23\n const startHour = timeFormat === '12h' ? 1 : 0\n\n for (let index = startHour; index <= maxHour; index += 1) {\n items.push(index)\n }\n\n return items\n }, [timeFormat, withTime])\n\n const minutes = useMemo(() => {\n if (!withTime) return []\n\n const items: number[] = []\n\n for (let index = 0; index < 60; index += minuteStep) {\n items.push(index)\n }\n\n return items\n }, [minuteStep, withTime])\n\n const seconds = useMemo(() => {\n if (!withTime || !showSeconds) return []\n\n const items: number[] = []\n\n for (let index = 0; index < 60; index += 1) {\n items.push(index)\n }\n\n return items\n }, [showSeconds, withTime])\n\n const handleTimeSelection = useCallback(\n (hoursValue: number, minutesValue: number, secondsValue: number = 0) => {\n const formattedTime = formatTimeWithFormat(hoursValue, minutesValue, secondsValue, showSeconds, timeFormat)\n const nextDate = currentDateForPanel\n\n setTouched(true)\n setDraftTimeValue(formattedTime)\n\n if (!nextDate) {\n setInputValue(formattedTime)\n return\n }\n\n const nextValue = combineDateAndTime(nextDate, formattedTime, {format: timeFormat, showSeconds})\n\n emitValidation({valid: true})\n setInputValue(formatDisplayValue(nextValue, {format, withTime, timeFormat, showSeconds}))\n commitValue(nextValue)\n },\n [commitValue, currentDateForPanel, emitValidation, format, showSeconds, timeFormat, withTime]\n )\n\n const handleMeridiemChange = useCallback(\n (meridiem: Meridiem) => {\n const currentHours = currentTimeForPanel ? to12HourParts(currentTimeForPanel).hours : 12\n const nextHours = to24HourValue(currentHours, meridiem)\n\n handleTimeSelection(nextHours, currentTimeForPanel?.minutes ?? 0, currentTimeForPanel?.seconds ?? 0)\n },\n [currentTimeForPanel, handleTimeSelection]\n )\n\n const calendarDays = useMemo(() => {\n const year = viewDate.getFullYear()\n const month = viewDate.getMonth()\n const totalDays = daysInMonth(year, month)\n let startDay = firstDayOfMonth(year, month)\n\n if (firstDayOfWeek === 1) {\n startDay = startDay === 0 ? 6 : startDay - 1\n }\n\n const days: Array<{date: Date; currentMonth: boolean}> = []\n const prevMonth = month === 0 ? 11 : month - 1\n const prevYear = month === 0 ? year - 1 : year\n const prevDays = daysInMonth(prevYear, prevMonth)\n\n for (let index = startDay - 1; index >= 0; index -= 1) {\n days.push({date: new Date(prevYear, prevMonth, prevDays - index), currentMonth: false})\n }\n\n for (let day = 1; day <= totalDays; day += 1) {\n days.push({date: new Date(year, month, day), currentMonth: true})\n }\n\n const remaining = 42 - days.length\n const nextMonth = month === 11 ? 0 : month + 1\n const nextYear = month === 11 ? year + 1 : year\n\n for (let day = 1; day <= remaining; day += 1) {\n days.push({date: new Date(nextYear, nextMonth, day), currentMonth: false})\n }\n\n return days\n }, [firstDayOfWeek, viewDate])\n\n const today = stripTime(new Date())\n const selectedDate = selectedValue ? stripTime(selectedValue) : currentDateForPanel\n\n const renderCalendar = () => (\n <div className=\"calendar\">\n <div className=\"calendar-header\">\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, -1))}\n aria-label={texts.previousMonth}\n >\n <ChevronLeftGlyphIcon />\n </button>\n <button\n type=\"button\"\n className=\"header-title\"\n onClick={() => setViewMode((current) => (current === 'days' ? 'months' : 'days'))}\n >\n {monthNames[viewDate.getMonth()]} {viewDate.getFullYear()}\n </button>\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, 1))}\n aria-label={texts.nextMonth}\n >\n <ChevronRightGlyphIcon />\n </button>\n </div>\n\n {viewMode === 'days' ? (\n <>\n <div className=\"day-names\">\n {dayNames.map((dayName) => (\n <span key={dayName} className=\"day-name\">\n {dayName}\n </span>\n ))}\n </div>\n\n <div className=\"day-grid\">\n {calendarDays.map(({date, currentMonth}, index) => {\n const isSelected = selectedDate ? isSameDay(date, selectedDate) : false\n const isToday = isSameDay(date, today)\n const disabledDay = isDisabled(date)\n\n return (\n <button\n key={`${date.toISOString()}-${index}`}\n type=\"button\"\n className={cn(\n 'day',\n !currentMonth && 'other-month',\n isToday && 'today',\n isSelected && 'selected',\n disabledDay && 'disabled'\n )}\n onClick={() => handleSelectDate(date)}\n disabled={disabledDay}\n tabIndex={-1}\n >\n {date.getDate()}\n </button>\n )\n })}\n </div>\n </>\n ) : (\n <div className=\"month-grid\">\n {monthNames.map((monthName, index) => (\n <button\n key={monthName}\n type=\"button\"\n className={cn('month-cell', viewDate.getMonth() === index && 'selected')}\n onClick={() => {\n setViewDate(new Date(viewDate.getFullYear(), index, 1))\n setViewMode('days')\n }}\n >\n {monthName.slice(0, 3)}\n </button>\n ))}\n </div>\n )}\n\n {showTodayButton && (\n <div className=\"footer\">\n <button type=\"button\" className=\"today-btn\" onClick={handleToday}>\n {texts.today}\n </button>\n </div>\n )}\n </div>\n )\n\n const renderTimePanel = () => {\n if (!withTime) return null\n\n const displayTime = currentTimeForPanel ? to12HourParts(currentTimeForPanel) : null\n\n return (\n <div className=\"date-picker-time-panel\">\n <div className=\"date-picker-time-header\">Time</div>\n <div className=\"date-picker-time-columns\">\n <TimeColumn\n items={hours}\n selected={timeFormat === '12h' ? displayTime?.hours : currentTimeForPanel?.hours}\n onSelect={(hoursValue) =>\n handleTimeSelection(\n timeFormat === '12h'\n ? to24HourValue(hoursValue, displayTime?.meridiem ?? 'AM')\n : hoursValue,\n currentTimeForPanel?.minutes ?? 0,\n currentTimeForPanel?.seconds ?? 0\n )\n }\n label=\"Hr\"\n />\n <TimeColumn\n items={minutes}\n selected={currentTimeForPanel?.minutes}\n onSelect={(minutesValue) =>\n handleTimeSelection(\n currentTimeForPanel?.hours ?? 0,\n minutesValue,\n currentTimeForPanel?.seconds ?? 0\n )\n }\n label=\"Min\"\n />\n {showSeconds && (\n <TimeColumn\n items={seconds}\n selected={currentTimeForPanel?.seconds}\n onSelect={(secondsValue) =>\n handleTimeSelection(\n currentTimeForPanel?.hours ?? 0,\n currentTimeForPanel?.minutes ?? 0,\n secondsValue\n )\n }\n label=\"Sec\"\n />\n )}\n {timeFormat === '12h' && (\n <TimeColumn\n items={['AM', 'PM']}\n selected={displayTime?.meridiem}\n onSelect={handleMeridiemChange}\n label=\"AM/PM\"\n />\n )}\n </div>\n </div>\n )\n }\n\n const renderPopoverContent = () => (\n <div className={cn('date-picker-popover-content', withTime && 'with-time')}>\n {renderCalendar()}\n {renderTimePanel()}\n </div>\n )\n\n const maxLength = withTime ? (timeFormat === '12h' ? (showSeconds ? 22 : 19) : showSeconds ? 19 : 16) : 10\n const inputPlaceholder = getInputPlaceholder(\n placeholder,\n format,\n withTime,\n timeFormat,\n showSeconds,\n timePlaceholder\n )\n\n if (inline) {\n return (\n <div\n className={cn('date-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n <MInput\n value={inputValue}\n onChange={handleInputChange}\n onBlur={handleInputBlur}\n onKeyDown={handleInputKeyDown}\n onClear={handleClear}\n type=\"text\"\n inputMode={withTime ? 'text' : 'numeric'}\n autoComplete=\"off\"\n maxLength={maxLength}\n placeholder={inputPlaceholder}\n disabled={disabled}\n readOnly={readOnly}\n id={id}\n variant={variant}\n size={size}\n color={color}\n label={label}\n helperText={helperText}\n error={hasError}\n errorText={resolvedErrorText}\n required={required}\n clearable={clearable}\n fullWidth={fullWidth}\n />\n {renderPopoverContent()}\n {name && selectedValue && (\n <input\n type=\"hidden\"\n name={name}\n value={formatHiddenDateValue(selectedValue, withTime, showSeconds)}\n />\n )}\n </div>\n )\n }\n\n return (\n <div\n className={cn('date-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n <div ref={anchorRef} className=\"date-picker-input-anchor\">\n <MInput\n value={inputValue}\n onChange={handleInputChange}\n onBlur={handleInputBlur}\n onKeyDown={handleInputKeyDown}\n onClear={handleClear}\n type=\"text\"\n inputMode={withTime ? 'text' : 'numeric'}\n autoComplete=\"off\"\n maxLength={maxLength}\n placeholder={inputPlaceholder}\n disabled={disabled}\n readOnly={readOnly}\n id={id}\n variant={variant}\n size={size}\n color={color}\n label={label}\n helperText={helperText}\n error={hasError}\n errorText={resolvedErrorText}\n required={required}\n clearable={clearable}\n fullWidth={fullWidth}\n endIcon={\n <button\n type=\"button\"\n className=\"date-picker-toggle\"\n onMouseDown={(event) => event.preventDefault()}\n onClick={handleTogglePopover}\n aria-label=\"Open calendar\"\n disabled={disabled || readOnly}\n >\n <MCalendarIcon />\n </button>\n }\n />\n </div>\n\n {name && selectedValue && (\n <input type=\"hidden\" name={name} value={formatHiddenDateValue(selectedValue, withTime, showSeconds)} />\n )}\n\n <MPopover\n className=\"date-picker-popover\"\n style={{'--color-rgb': colorRgbVar(color)} as React.CSSProperties}\n open={open}\n anchorRef={anchorRef}\n onClose={() => setOpen(false)}\n placement=\"bottom-start\"\n >\n {renderPopoverContent()}\n </MPopover>\n </div>\n )\n}\n\nfunction TimeColumn<T extends number | Meridiem>({\n items,\n selected,\n onSelect,\n label,\n}: {\n items: T[]\n selected?: T\n onSelect: (value: T) => void\n label: string\n}) {\n const listRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n if (selected === undefined || !listRef.current) return\n\n const element = listRef.current.querySelector(`[data-value=\"${selected}\"]`) as HTMLElement | null\n\n if (element) {\n const list = listRef.current\n list.scrollTop = element.offsetTop - list.clientHeight / 2 + element.offsetHeight / 2\n }\n }, [selected])\n\n const renderValue = (value: T) => (typeof value === 'number' ? value.toString().padStart(2, '0') : value)\n\n return (\n <div className=\"date-picker-time-column\">\n <div className=\"date-picker-time-column-label\">{label}</div>\n <div ref={listRef} className=\"date-picker-time-column-list\">\n {items.map((item) => (\n <button\n key={item}\n type=\"button\"\n data-value={item}\n className={cn('date-picker-time-column-item', item === selected && 'selected')}\n onClick={() => onSelect(item)}\n >\n {renderValue(item)}\n </button>\n ))}\n </div>\n </div>\n )\n}\n","import {useState, useRef, useCallback, useMemo, useEffect} from 'react'\nimport type * as React from 'react'\nimport type {MTimePickerProps} from './MTimePicker.types'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {MClockIcon, MCloseIcon} from '../../../icons'\nimport {formatTime, parseTime} from '../../../utils/dateUtils'\nimport './MTimePicker.css'\n\ntype ParsedTimeValue = {hours: number; minutes: number; seconds: number}\ntype Meridiem = 'AM' | 'PM'\n\nfunction to12HourParts(value: ParsedTimeValue) {\n const meridiem: Meridiem = value.hours >= 12 ? 'PM' : 'AM'\n const hours = value.hours % 12 || 12\n return {hours, minutes: value.minutes, seconds: value.seconds, meridiem}\n}\n\nfunction to24HourValue(hours: number, meridiem: Meridiem): number {\n if (meridiem === 'AM') {\n return hours === 12 ? 0 : hours\n }\n return hours === 12 ? 12 : hours + 12\n}\n\nfunction formatTimeValue(\n hours: number,\n minutes: number,\n seconds: number,\n showSeconds: boolean,\n format: '24h' | '12h'\n): string {\n if (format === '24h') {\n return formatTime(hours, minutes, seconds, showSeconds)\n }\n\n const parts = to12HourParts({hours, minutes, seconds})\n const base = `${parts.hours.toString().padStart(2, '0')}:${parts.minutes.toString().padStart(2, '0')}`\n const withSeconds = showSeconds ? `${base}:${parts.seconds.toString().padStart(2, '0')}` : base\n return `${withSeconds} ${parts.meridiem}`\n}\n\nfunction parseTimeValue(value: string, format: '24h' | '12h'): ParsedTimeValue | null {\n if (format === '24h') {\n return parseTime(value)\n }\n\n const normalized = value.trim().toUpperCase()\n const match = normalized.match(/^(\\d{1,2}):(\\d{2})(?::(\\d{2}))?\\s*(AM|PM)$/)\n if (match) {\n const hours = parseInt(match[1], 10)\n const minutes = parseInt(match[2], 10)\n const seconds = match[3] ? parseInt(match[3], 10) : 0\n const meridiem = match[4] as Meridiem\n\n if (hours < 1 || hours > 12 || minutes > 59 || seconds > 59) {\n return null\n }\n\n return {hours: to24HourValue(hours, meridiem), minutes, seconds}\n }\n\n return parseTime(value)\n}\n\n// Compare time tuples so min/max checks can stay string-format agnostic.\nfunction compareTimeParts(\n left: {hours: number; minutes: number; seconds: number},\n right: {hours: number; minutes: number; seconds: number}\n): number {\n if (left.hours !== right.hours) return left.hours - right.hours\n if (left.minutes !== right.minutes) return left.minutes - right.minutes\n return left.seconds - right.seconds\n}\n\n// Check whether a time falls within optional min and max boundaries.\nfunction isTimeInRange(\n value: {hours: number; minutes: number; seconds: number},\n min?: {hours: number; minutes: number; seconds: number} | null,\n max?: {hours: number; minutes: number; seconds: number} | null\n): boolean {\n return (!min || compareTimeParts(value, min) >= 0) && (!max || compareTimeParts(value, max) <= 0)\n}\n\n// Render a time input backed by scrollable hour, minute and second columns.\nexport function MTimePicker({\n value,\n defaultValue,\n onChange,\n format = '24h',\n showSeconds = false,\n minuteStep = 1,\n min,\n max,\n placeholder,\n disabled = false,\n readOnly = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n fullWidth = false,\n className,\n style,\n}: MTimePickerProps) {\n const [open, setOpen] = useState(false)\n const [internalValue, setInternalValue] = useState(defaultValue ?? '')\n const triggerRef = useRef<HTMLDivElement>(null)\n\n const currentValue = value !== undefined ? value : internalValue\n const hasError = error || !!errorText\n const parsed = parseTimeValue(currentValue, format)\n const minTime = parseTimeValue(min ?? '', format)\n const maxTime = parseTimeValue(max ?? '', format)\n const displayTime = parsed ? to12HourParts(parsed) : null\n const displayValue = parsed\n ? formatTimeValue(parsed.hours, parsed.minutes, parsed.seconds, showSeconds, format)\n : currentValue\n\n // Build the visible hour list based on the selected time format.\n const hours = useMemo(() => {\n const items: number[] = []\n const maxHour = format === '12h' ? 12 : 23\n const startHour = format === '12h' ? 1 : 0\n for (let index = startHour; index <= maxHour; index++) {\n items.push(index)\n }\n return items\n }, [format])\n\n // Build the minute list using the configured step size.\n const minutes = useMemo(() => {\n const items: number[] = []\n for (let index = 0; index < 60; index += minuteStep) {\n items.push(index)\n }\n return items\n }, [minuteStep])\n\n // Build the seconds list only when the picker exposes seconds.\n const seconds = useMemo(() => {\n if (!showSeconds) return []\n const items: number[] = []\n for (let index = 0; index < 60; index++) {\n items.push(index)\n }\n return items\n }, [showSeconds])\n\n // Reuse range validation for list rendering and direct text input.\n const isSelectable = useCallback(\n (hoursValue: number, minutesValue: number, secondsValue: number = 0) => {\n return isTimeInRange({hours: hoursValue, minutes: minutesValue, seconds: secondsValue}, minTime, maxTime)\n },\n [maxTime, minTime]\n )\n\n // Apply the selected time and keep uncontrolled usage in sync.\n const handleSelect = useCallback(\n (hoursValue: number, minutesValue: number, secondsValue: number = 0) => {\n if (!isSelectable(hoursValue, minutesValue, secondsValue)) return\n const time = formatTimeValue(hoursValue, minutesValue, secondsValue, showSeconds, format)\n if (value === undefined) setInternalValue(time)\n onChange?.(time)\n },\n [format, isSelectable, onChange, showSeconds, value]\n )\n\n const handleInputChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const raw = event.target.value\n if (value === undefined) setInternalValue(raw)\n },\n [value]\n )\n\n // Normalize manual input once the user leaves the field.\n const handleInputBlur = useCallback(() => {\n const nextValue = parseTimeValue(currentValue, format)\n if (nextValue && isTimeInRange(nextValue, minTime, maxTime)) {\n const time = formatTimeValue(nextValue.hours, nextValue.minutes, nextValue.seconds, showSeconds, format)\n if (value === undefined) setInternalValue(time)\n onChange?.(time)\n }\n }, [currentValue, format, maxTime, minTime, onChange, showSeconds, value])\n\n const handleMeridiemChange = useCallback(\n (meridiem: Meridiem) => {\n const currentHours = displayTime?.hours ?? 12\n const minutesValue = parsed?.minutes ?? 0\n const secondsValue = parsed?.seconds ?? 0\n const nextHours = to24HourValue(currentHours, meridiem)\n handleSelect(nextHours, minutesValue, secondsValue)\n },\n [displayTime?.hours, handleSelect, parsed?.minutes, parsed?.seconds]\n )\n\n // Clear the current time without closing the trigger first.\n const handleClear = useCallback(\n (event: React.MouseEvent) => {\n event.stopPropagation()\n if (value === undefined) setInternalValue('')\n onChange?.('')\n },\n [onChange, value]\n )\n\n return (\n <div\n className={cn('time picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={triggerRef}\n className={cn(\n 'time trigger',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={() => !disabled && !readOnly && setOpen(true)}\n >\n <span className=\"time icon\">\n <MClockIcon />\n </span>\n <input\n type=\"text\"\n className=\"time input\"\n value={displayValue}\n onChange={handleInputChange}\n onBlur={handleInputBlur}\n placeholder={\n placeholder ??\n (format === '12h'\n ? showSeconds\n ? 'hh:mm:ss AM'\n : 'hh:mm AM'\n : showSeconds\n ? 'HH:MM:SS'\n : 'HH:MM')\n }\n disabled={disabled}\n readOnly={readOnly}\n id={id}\n aria-invalid={hasError || undefined}\n />\n {clearable && currentValue && !disabled && (\n <button\n type=\"button\"\n className=\"time clear clear-btn-base\"\n onClick={handleClear}\n tabIndex={-1}\n aria-label=\"Clear time\"\n >\n <MCloseIcon />\n </button>\n )}\n </div>\n\n {name && <input type=\"hidden\" name={name} value={displayValue} />}\n\n <MPopover\n className=\"time picker popover\"\n open={open}\n anchorRef={triggerRef}\n onClose={() => setOpen(false)}\n placement=\"bottom-start\"\n >\n <div className=\"time columns\">\n <TimeColumn\n items={hours}\n selected={format === '12h' ? displayTime?.hours : parsed?.hours}\n onSelect={(hoursValue) =>\n handleSelect(\n format === '12h'\n ? to24HourValue(hoursValue, displayTime?.meridiem ?? 'AM')\n : hoursValue,\n parsed?.minutes ?? 0,\n parsed?.seconds ?? 0\n )\n }\n isDisabled={(hoursValue) =>\n !isSelectable(\n format === '12h'\n ? to24HourValue(hoursValue, displayTime?.meridiem ?? 'AM')\n : hoursValue,\n parsed?.minutes ?? 0,\n parsed?.seconds ?? 0\n )\n }\n label=\"Hr\"\n />\n <TimeColumn\n items={minutes}\n selected={parsed?.minutes}\n onSelect={(minutesValue) =>\n handleSelect(parsed?.hours ?? 0, minutesValue, parsed?.seconds ?? 0)\n }\n isDisabled={(minutesValue) =>\n !isSelectable(parsed?.hours ?? 0, minutesValue, parsed?.seconds ?? 0)\n }\n label=\"Min\"\n />\n {showSeconds && (\n <TimeColumn\n items={seconds}\n selected={parsed?.seconds}\n onSelect={(secondsValue) =>\n handleSelect(parsed?.hours ?? 0, parsed?.minutes ?? 0, secondsValue)\n }\n isDisabled={(secondsValue) =>\n !isSelectable(parsed?.hours ?? 0, parsed?.minutes ?? 0, secondsValue)\n }\n label=\"Sec\"\n />\n )}\n {format === '12h' && (\n <TimeColumn\n items={['AM', 'PM']}\n selected={displayTime?.meridiem}\n onSelect={handleMeridiemChange}\n label=\"AM/PM\"\n />\n )}\n </div>\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"time bottom\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"time helper\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n\n// Render one scrollable time column and keep the selected value centered.\nfunction TimeColumn<T extends number | Meridiem>({\n items,\n selected,\n onSelect,\n isDisabled,\n label,\n}: {\n items: T[]\n selected?: T\n onSelect: (value: T) => void\n isDisabled?: (value: T) => boolean\n label: string\n}) {\n const listRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n if (selected === undefined || !listRef.current) return\n const element = listRef.current.querySelector(`[data-value=\"${selected}\"]`) as HTMLElement | null\n if (element) {\n const list = listRef.current\n list.scrollTop = element.offsetTop - list.clientHeight / 2 + element.offsetHeight / 2\n }\n }, [selected])\n\n const renderValue = (value: T) => (typeof value === 'number' ? value.toString().padStart(2, '0') : value)\n\n return (\n <div className=\"time column\">\n <div className=\"time column label\">{label}</div>\n <div ref={listRef} className=\"time column list\">\n {items.map((item) => {\n const disabled = isDisabled?.(item) ?? false\n return (\n <button\n key={item}\n type=\"button\"\n data-value={item}\n className={cn('time column item', item === selected && 'selected', disabled && 'disabled')}\n onClick={() => onSelect(item)}\n disabled={disabled}\n >\n {renderValue(item)}\n </button>\n )\n })}\n </div>\n </div>\n )\n}\n","import {useCallback, useEffect, useMemo, useRef, useState} from 'react'\nimport type * as React from 'react'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useMDateRangePickerTexts} from '../../../i18n/frameworkTexts'\nimport {useDocumentLocale} from '../../../utils/locale'\nimport {MCalendarIcon, MChevronLeftIcon, MChevronRightIcon, MCloseIcon} from '../../../icons'\nimport {\n addMonths,\n daysInMonth,\n firstDayOfMonth,\n formatDate,\n getDayNames,\n getMonthNames,\n isDateInRange,\n isSameDay,\n stripTime,\n} from '../../../utils/dateUtils'\nimport type {MDateRangePickerProps, MDateRangePreset} from './MDateRangePicker.types'\nimport {colorRgbVar} from '../../../utils/colorRgbVar'\nimport './MDateRangePicker.css'\n\nfunction toDate(value: Date | string | null | undefined): Date | null {\n if (!value) return null\n if (value instanceof Date) return stripTime(value)\n const date = new Date(value)\n return isNaN(date.getTime()) ? null : stripTime(date)\n}\n\nfunction sortRange(start: Date, end: Date) {\n return start.getTime() <= end.getTime() ? {start, end} : {start: end, end: start}\n}\n\nfunction isBetween(date: Date, start: Date | null, end: Date | null) {\n if (!start || !end) return false\n const time = date.getTime()\n return time > start.getTime() && time < end.getTime()\n}\n\nfunction formatRangeLabel(start: Date | null, end: Date | null, format: string) {\n if (start && end) {\n return `${formatDate(start, format)} - ${formatDate(end, format)}`\n }\n\n if (start) {\n return `${formatDate(start, format)} - ...`\n }\n\n return ''\n}\n\nfunction startOfMonth(date: Date) {\n return new Date(date.getFullYear(), date.getMonth(), 1)\n}\n\nfunction endOfMonth(date: Date) {\n return new Date(date.getFullYear(), date.getMonth() + 1, 0)\n}\n\nfunction daysAgo(days: number): Date {\n const date = stripTime(new Date())\n date.setDate(date.getDate() - (days - 1))\n return date\n}\n\nfunction monthsAgo(months: number): Date {\n const today = stripTime(new Date())\n return new Date(today.getFullYear(), today.getMonth() - months, today.getDate())\n}\n\nfunction getDefaultPresets(texts: ReturnType<typeof useMDateRangePickerTexts>): MDateRangePreset[] {\n const today = stripTime(new Date())\n const previousMonthDate = new Date(today.getFullYear(), today.getMonth() - 1, 1)\n\n return [\n {label: texts.presets.today, value: {start: today, end: today}},\n {label: texts.presets.days2, value: {start: daysAgo(2), end: today}},\n {label: texts.presets.days3, value: {start: daysAgo(3), end: today}},\n {label: texts.presets.days7, value: {start: daysAgo(7), end: today}},\n {label: texts.presets.days14, value: {start: daysAgo(14), end: today}},\n {label: texts.presets.days31, value: {start: daysAgo(31), end: today}},\n {label: texts.presets.thisMonth, value: {start: startOfMonth(today), end: endOfMonth(today)}},\n {\n label: texts.presets.previousMonth,\n value: {start: startOfMonth(previousMonthDate), end: endOfMonth(previousMonthDate)},\n },\n {label: texts.presets.months2, value: {start: monthsAgo(2), end: today}},\n {label: texts.presets.months3, value: {start: monthsAgo(3), end: today}},\n {label: texts.presets.months6, value: {start: monthsAgo(6), end: today}},\n {label: texts.presets.year1, value: {start: monthsAgo(12), end: today}},\n ]\n}\n\nfunction buildCalendarDays(viewDate: Date, firstDayOfWeek: 0 | 1) {\n const year = viewDate.getFullYear()\n const month = viewDate.getMonth()\n const totalDays = daysInMonth(year, month)\n let startDay = firstDayOfMonth(year, month)\n\n if (firstDayOfWeek === 1) {\n startDay = startDay === 0 ? 6 : startDay - 1\n }\n\n const days = [] as Array<{date: Date; currentMonth: boolean}>\n\n const previousMonth = month === 0 ? 11 : month - 1\n const previousYear = month === 0 ? year - 1 : year\n const previousMonthDays = daysInMonth(previousYear, previousMonth)\n\n for (let index = startDay - 1; index >= 0; index -= 1) {\n days.push({date: new Date(previousYear, previousMonth, previousMonthDays - index), currentMonth: false})\n }\n\n for (let day = 1; day <= totalDays; day += 1) {\n days.push({date: new Date(year, month, day), currentMonth: true})\n }\n\n const remaining = 42 - days.length\n const nextMonth = month === 11 ? 0 : month + 1\n const nextYear = month === 11 ? year + 1 : year\n\n for (let day = 1; day <= remaining; day += 1) {\n days.push({date: new Date(nextYear, nextMonth, day), currentMonth: false})\n }\n\n return days\n}\n\n// Render a single control for start and end date selection inside one calendar popover.\nexport function MDateRangePicker({\n value,\n defaultValue,\n onChange,\n format = 'dd.MM.yyyy',\n locale: localeOverride,\n min,\n max,\n disabledDates,\n placeholder,\n disabled = false,\n readOnly = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n inline = false,\n showTodayButton = true,\n presets = false,\n presetsSidebar = false,\n firstDayOfWeek = 1,\n fullWidth = false,\n allowSameDay = true,\n className,\n style,\n}: MDateRangePickerProps) {\n const locale = useDocumentLocale(localeOverride)\n const controlledRange = value\n ? {\n start: toDate(value.start),\n end: toDate(value.end),\n }\n : null\n const [internalRange, setInternalRange] = useState(() => ({\n start: toDate(defaultValue?.start),\n end: toDate(defaultValue?.end),\n }))\n const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n const [open, setOpen] = useState(false)\n const triggerRef = useRef<HTMLDivElement>(null)\n\n const selectedRange = controlledRange ?? internalRange\n const startDate = selectedRange.start\n const endDate = selectedRange.end\n const minDate = toDate(min)\n const maxDate = toDate(max)\n const hasError = error || !!errorText\n const texts = useMDateRangePickerTexts()\n const dayNames = getDayNames(locale, firstDayOfWeek)\n const monthNames = getMonthNames(locale)\n const availablePresets = useMemo(() => {\n if (presets === true || (presetsSidebar && !presets)) {\n return getDefaultPresets(texts)\n }\n\n if (Array.isArray(presets)) {\n return presets\n }\n\n return []\n }, [presets, presetsSidebar, texts])\n\n const [viewDate, setViewDate] = useState(() => {\n const baseDate = startDate ?? new Date()\n return new Date(baseDate.getFullYear(), baseDate.getMonth(), 1)\n })\n\n const startTime = startDate?.getTime() ?? null\n useEffect(() => {\n if (!startTime) return\n const d = new Date(startTime)\n setViewDate(new Date(d.getFullYear(), d.getMonth(), 1))\n }, [startTime])\n\n const isDisabled = useCallback(\n (date: Date): boolean => {\n if (!isDateInRange(date, minDate, maxDate)) return true\n if (Array.isArray(disabledDates)) {\n return disabledDates.some((disabledDate) => isSameDay(disabledDate, date))\n }\n if (typeof disabledDates === 'function') {\n return disabledDates(date)\n }\n return false\n },\n [disabledDates, maxDate, minDate]\n )\n\n const commitRange = useCallback(\n (nextRange: {start: Date | null; end: Date | null}) => {\n if (value === undefined) {\n setInternalRange(nextRange)\n }\n onChange?.(nextRange)\n },\n [onChange, value]\n )\n\n const handleDayClick = useCallback(\n (date: Date) => {\n if (isDisabled(date)) return\n\n if (!startDate || (startDate && endDate)) {\n commitRange({start: date, end: null})\n setHoveredDate(null)\n return\n }\n\n if (!allowSameDay && isSameDay(date, startDate)) {\n return\n }\n\n const orderedRange = sortRange(startDate, date)\n commitRange(orderedRange)\n setHoveredDate(null)\n\n if (!inline) {\n setOpen(false)\n }\n },\n [allowSameDay, commitRange, endDate, inline, isDisabled, startDate]\n )\n\n const handleClear = useCallback(\n (event: React.MouseEvent) => {\n event.stopPropagation()\n commitRange({start: null, end: null})\n setHoveredDate(null)\n },\n [commitRange]\n )\n\n const handleToday = useCallback(() => {\n const today = stripTime(new Date())\n if (isDisabled(today)) return\n commitRange({start: today, end: today})\n setViewDate(new Date(today.getFullYear(), today.getMonth(), 1))\n setHoveredDate(null)\n if (!inline) {\n setOpen(false)\n }\n }, [commitRange, inline, isDisabled])\n\n const handlePresetClick = useCallback(\n (preset: MDateRangePreset) => {\n const start = toDate(preset.value.start)\n const end = toDate(preset.value.end)\n\n if (!start || !end) {\n return\n }\n\n const orderedRange = sortRange(start, end)\n\n if (isDisabled(orderedRange.start) || isDisabled(orderedRange.end)) {\n return\n }\n\n commitRange(orderedRange)\n setViewDate(new Date(orderedRange.start.getFullYear(), orderedRange.start.getMonth(), 1))\n setHoveredDate(null)\n\n if (!inline) {\n setOpen(false)\n }\n },\n [commitRange, inline, isDisabled]\n )\n\n const previewEnd = startDate && !endDate ? hoveredDate : null\n const firstMonth = viewDate\n const secondMonth = addMonths(viewDate, 1)\n const today = stripTime(new Date())\n\n const displayValue = useMemo(() => formatRangeLabel(startDate, endDate, format), [endDate, format, startDate])\n\n const calendarMonths = useMemo(\n () =>\n [firstMonth, secondMonth].map((monthDate) => ({\n monthDate,\n days: buildCalendarDays(monthDate, firstDayOfWeek),\n })),\n [firstDayOfWeek, firstMonth, secondMonth]\n )\n\n const summaryText =\n startDate && endDate\n ? `${formatDate(startDate, format)} - ${formatDate(endDate, format)}`\n : startDate\n ? `${formatDate(startDate, format)} - ...`\n : (placeholder ?? texts.defaultRangePlaceholder)\n\n const showSidebar = presetsSidebar && availablePresets.length > 0\n const showInlinePresets = !presetsSidebar && availablePresets.length > 0\n\n const renderPresetsSidebar = () => (\n <div className=\"presets-sidebar\">\n {availablePresets.map((preset) => (\n <button\n key={preset.label}\n type=\"button\"\n className=\"preset-sidebar-btn\"\n onClick={() => handlePresetClick(preset)}\n >\n {preset.label}\n </button>\n ))}\n </div>\n )\n\n const renderCalendarContent = () => (\n <div className=\"calendar-body\">\n <div className=\"calendar-top\">\n <div className=\"calendar-caption\">\n <span className=\"caption-title\">\n {monthNames[firstMonth.getMonth()]} {firstMonth.getFullYear()}\n </span>\n <span className=\"caption-subtitle\">{texts.rangeSubtitle}</span>\n </div>\n <div className=\"nav-actions\">\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, -1))}\n aria-label={texts.previousMonth}\n >\n <MChevronLeftIcon />\n </button>\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, 1))}\n aria-label={texts.nextMonth}\n >\n <MChevronRightIcon />\n </button>\n </div>\n </div>\n\n {showInlinePresets && (\n <div className=\"presets\">\n {availablePresets.map((preset) => (\n <button\n key={preset.label}\n type=\"button\"\n className=\"preset-btn\"\n onClick={() => handlePresetClick(preset)}\n >\n {preset.label}\n </button>\n ))}\n </div>\n )}\n\n <div className=\"months\">\n {calendarMonths.map(({monthDate, days}) => (\n <div key={monthDate.toISOString()} className=\"month-panel\">\n <div className=\"month-title\">\n {monthNames[monthDate.getMonth()]} {monthDate.getFullYear()}\n </div>\n <div className=\"day-names\">\n {dayNames.map((dayName) => (\n <span key={`${monthDate.toISOString()}-${dayName}`} className=\"day-name\">\n {dayName}\n </span>\n ))}\n </div>\n <div className=\"day-grid\">\n {days.map(({date, currentMonth}, index) => {\n const disabledDay = isDisabled(date)\n const selectedStart = startDate ? isSameDay(date, startDate) : false\n const selectedEnd = endDate ? isSameDay(date, endDate) : false\n const inRange = isBetween(date, startDate, endDate)\n const previewRangeData =\n !endDate && startDate && previewEnd ? sortRange(startDate, previewEnd) : null\n const previewRange = previewRangeData\n ? isBetween(date, previewRangeData.start, previewRangeData.end)\n : false\n const previewEdge = previewRangeData\n ? isSameDay(date, previewRangeData.start) || isSameDay(date, previewRangeData.end)\n : false\n\n return (\n <button\n key={`${monthDate.toISOString()}-${index}`}\n type=\"button\"\n className={cn(\n 'day',\n !currentMonth && 'other-month',\n isSameDay(date, today) && 'today',\n selectedStart && 'range-start selected',\n selectedEnd && 'range-end selected',\n inRange && 'in-range',\n previewRange && !previewEdge && 'preview-range',\n disabledDay && 'disabled'\n )}\n onClick={() => handleDayClick(date)}\n onMouseEnter={() => startDate && !endDate && setHoveredDate(date)}\n onFocus={() => startDate && !endDate && setHoveredDate(date)}\n disabled={disabledDay}\n tabIndex={-1}\n >\n {date.getDate()}\n </button>\n )\n })}\n </div>\n </div>\n ))}\n </div>\n\n <div className=\"footer\">\n <span className=\"summary\">{summaryText}</span>\n <div className=\"footer-actions\">\n {clearable && (startDate || endDate) && (\n <button\n type=\"button\"\n className=\"footer-btn\"\n onClick={(event) => {\n event.preventDefault()\n commitRange({start: null, end: null})\n setHoveredDate(null)\n }}\n >\n {texts.clear}\n </button>\n )}\n {showTodayButton && (\n <button type=\"button\" className=\"footer-btn\" onClick={handleToday}>\n {texts.today}\n </button>\n )}\n </div>\n </div>\n </div>\n )\n\n const renderCalendar = () => (\n <div className={cn('date-range-calendar', showSidebar && 'with-sidebar')}>\n {showSidebar && renderPresetsSidebar()}\n {renderCalendarContent()}\n </div>\n )\n\n if (inline) {\n return (\n <div\n className={cn('date-range-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label className={cn('field-label', hasError && 'error', required && 'required')}>{label}</label>\n )}\n {renderCalendar()}\n </div>\n )\n }\n\n return (\n <div\n className={cn('date-range-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={triggerRef}\n className={cn(\n 'trigger',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={() => !disabled && !readOnly && setOpen(true)}\n >\n <span className=\"icon\">\n <MCalendarIcon />\n </span>\n <input\n type=\"text\"\n className=\"input\"\n value={displayValue}\n placeholder={placeholder ?? texts.defaultRangePlaceholder}\n disabled={disabled}\n readOnly\n id={id}\n aria-invalid={hasError || undefined}\n />\n {clearable && (startDate || endDate) && !disabled && (\n <button\n type=\"button\"\n className=\"clear-btn clear-btn-base\"\n onClick={handleClear}\n tabIndex={-1}\n aria-label={texts.clear}\n >\n <MCloseIcon />\n </button>\n )}\n </div>\n\n {name && startDate && endDate && (\n <input\n type=\"hidden\"\n name={name}\n value={`${startDate.toISOString().split('T')[0]}:${endDate.toISOString().split('T')[0]}`}\n />\n )}\n\n <MPopover\n className={'date-range-picker-popover'}\n style={{'--color-rgb': colorRgbVar(color)} as React.CSSProperties}\n open={open}\n anchorRef={triggerRef}\n onClose={() => {\n setOpen(false)\n setHoveredDate(null)\n }}\n placement=\"bottom-start\"\n >\n {renderCalendar()}\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"bottom-row\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"helper-text\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"dropdowns-DN7j1HhE.cjs","names":[],"sources":["../src/components/dropdowns/MSelect/MSelect.tsx","../src/components/dropdowns/MAutocomplete/MAutocomplete.tsx","../src/utils/colorRgbVar.ts","../src/components/dropdowns/MDatePicker/MDatePicker.tsx","../src/components/dropdowns/MTimePicker/MTimePicker.tsx","../src/components/dropdowns/MDateRangePicker/MDateRangePicker.tsx"],"sourcesContent":["import {useState, useRef, useCallback, useMemo} from 'react'\nimport type * as React from 'react'\nimport type {MSelectProps, MSelectOption} from './MSelect.types'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useKeyboardNav} from '../../../utils/useKeyboardNav'\nimport {MCheckbox} from '../../controls'\nimport {MSpinner, MTag} from '../../feedback'\nimport {MChevronDownIcon, MCloseIcon} from '../../../icons'\nimport './MSelect.css'\n\n// Render a selectable list with optional search, grouping and multi-select tags.\nexport function MSelect({\n options,\n value,\n defaultValue,\n onChange,\n multiple = false,\n searchable = false,\n placeholder = 'MSelect...',\n disabled = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n fullWidth = false,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n loading = false,\n clearable = false,\n maxHeight = 300,\n noOptionsText = 'No options',\n renderOption,\n renderValue,\n className,\n style,\n}: MSelectProps) {\n const [open, setOpen] = useState(false)\n const [internalValue, setInternalValue] = useState<string | string[]>(defaultValue ?? (multiple ? [] : ''))\n const [search, setSearch] = useState('')\n const triggerRef = useRef<HTMLDivElement>(null)\n\n const currentValue = value !== undefined ? value : internalValue\n const hasError = error || !!errorText\n\n // Normalize the public value into a string array for rendering and selection logic.\n const selectedValues = useMemo(() => {\n if (Array.isArray(currentValue)) return currentValue\n return currentValue ? [currentValue] : []\n }, [currentValue])\n\n const selectedOptions = useMemo(\n () => options.filter((o) => selectedValues.includes(o.value)),\n [options, selectedValues]\n )\n\n // Filter options locally when the searchable mode is active.\n const filteredOptions = useMemo(() => {\n if (!searchable || !search) return options\n const lower = search.toLowerCase()\n return options.filter((o) => o.label.toLowerCase().includes(lower))\n }, [options, searchable, search])\n\n // Group options\n // Preserve group headers without changing the flat keyboard navigation index map.\n const groupedOptions = useMemo(() => {\n const groups = new Map<string, MSelectOption[]>()\n for (const opt of filteredOptions) {\n const key = opt.group ?? ''\n if (!groups.has(key)) groups.set(key, [])\n groups.get(key)!.push(opt)\n }\n return groups\n }, [filteredOptions])\n\n const flatFiltered = filteredOptions\n\n // MToggle or replace the current selection depending on the mode.\n const handleSelect = useCallback(\n (index: number) => {\n const opt = flatFiltered[index]\n if (!opt || opt.disabled) return\n\n if (multiple) {\n const arr = Array.isArray(currentValue) ? currentValue : []\n const newVal = arr.includes(opt.value) ? arr.filter((v) => v !== opt.value) : [...arr, opt.value]\n if (value === undefined) setInternalValue(newVal)\n onChange?.(newVal)\n } else {\n if (value === undefined) setInternalValue(opt.value)\n onChange?.(opt.value)\n setOpen(false)\n setSearch('')\n }\n },\n [flatFiltered, multiple, currentValue, value, onChange]\n )\n\n const {activeIndex, setActiveIndex, resetIndex, onKeyDown} = useKeyboardNav({\n itemCount: flatFiltered.length,\n onSelect: handleSelect,\n onClose: () => {\n setOpen(false)\n setSearch('')\n },\n isOpen: open,\n })\n\n // Open the popover and reset keyboard navigation when the trigger is used.\n const handleTriggerClick = useCallback(() => {\n if (disabled) return\n setOpen((v) => !v)\n resetIndex()\n }, [disabled, resetIndex])\n\n // Reset the current selection without closing the outer field wrapper.\n const handleClear = useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation()\n const empty = multiple ? [] : ''\n if (value === undefined) setInternalValue(empty)\n onChange?.(empty)\n },\n [multiple, value, onChange]\n )\n\n // Render tags, labels or the placeholder based on the current selection state.\n const displayValue = useMemo(() => {\n if (renderValue && selectedOptions.length > 0) {\n return renderValue(multiple ? selectedOptions : selectedOptions[0])\n }\n if (multiple && selectedOptions.length > 0) {\n return (\n <span className=\"tags\">\n {selectedOptions.map((o) => (\n <MTag key={o.value} label={o.label} color={color} size={size} variant=\"solid\" />\n ))}\n </span>\n )\n }\n if (!multiple && selectedOptions.length > 0) {\n return selectedOptions[0].label\n }\n return <span className=\"placeholder\">{placeholder}</span>\n }, [selectedOptions, multiple, renderValue, placeholder, color, size])\n\n return (\n <div className={cn('select', color && `color-${color}`, fullWidth && 'full-width', className)} style={style}>\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={triggerRef}\n className={cn(\n 'trigger',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={handleTriggerClick}\n onKeyDown={onKeyDown as unknown as React.KeyboardEventHandler}\n tabIndex={disabled ? -1 : 0}\n role=\"combobox\"\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-invalid={hasError || undefined}\n id={id}\n >\n <span className=\"value\">{displayValue}</span>\n\n {loading && <MSpinner size=\"sm\" color={color} />}\n\n {clearable && selectedValues.length > 0 && !loading && !disabled && (\n <button\n type=\"button\"\n className=\"clear-btn clear-btn-base\"\n onClick={handleClear}\n tabIndex={-1}\n aria-label=\"Clear selection\"\n >\n <MCloseIcon />\n </button>\n )}\n\n <span className={cn('arrow', open && 'open')} aria-hidden=\"true\">\n <MChevronDownIcon />\n </span>\n </div>\n\n {/* Hidden input for form submission */}\n {name && (\n <input\n type=\"hidden\"\n name={name}\n value={Array.isArray(currentValue) ? currentValue.join(',') : currentValue}\n />\n )}\n\n <MPopover\n className={'select-popover'}\n open={open}\n anchorRef={triggerRef}\n onClose={() => {\n setOpen(false)\n setSearch('')\n }}\n matchWidth\n placement=\"bottom-start\"\n >\n <div style={{maxHeight}} className=\"dropdown\">\n {searchable && (\n <div className=\"search-box\">\n <input\n type=\"text\"\n className=\"search-input\"\n placeholder=\"Search...\"\n value={search}\n onChange={(e) => {\n setSearch(e.target.value)\n setActiveIndex(0)\n }}\n onKeyDown={onKeyDown as unknown as React.KeyboardEventHandler}\n autoFocus\n />\n </div>\n )}\n\n {flatFiltered.length === 0 ? (\n <div className=\"no-options\">{noOptionsText}</div>\n ) : (\n <div className=\"options-list\" role=\"listbox\">\n {[...groupedOptions.entries()].map(([group, opts]) => (\n <div key={group}>\n {group && <div className=\"group-header\">{group}</div>}\n {opts.map((opt) => {\n const flatIndex = flatFiltered.indexOf(opt)\n const isActive = flatIndex === activeIndex\n const isSelected = selectedValues.includes(opt.value)\n return (\n <div\n key={opt.value}\n className={cn(\n 'option',\n isActive && 'active',\n isSelected && 'selected',\n opt.disabled && 'disabled'\n )}\n onClick={() => !opt.disabled && handleSelect(flatIndex)}\n onMouseEnter={() => setActiveIndex(flatIndex)}\n role=\"option\"\n aria-selected={isSelected}\n aria-disabled={opt.disabled}\n >\n {multiple && (\n <MCheckbox\n checked={isSelected}\n size=\"sm\"\n color={color}\n clickEffect=\"none\"\n className=\"select-check\"\n />\n )}\n {renderOption ? renderOption(opt, isActive, isSelected) : opt.label}\n </div>\n )\n })}\n </div>\n ))}\n </div>\n )}\n </div>\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"bottom-row\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"helper-text\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n","import {useState, useRef, useCallback, useMemo} from 'react'\nimport type * as React from 'react'\nimport type {MAutocompleteProps} from './MAutocomplete.types'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useKeyboardNav} from '../../../utils/useKeyboardNav'\nimport {useDebouncedCallback} from '../../../utils/useDebounce'\nimport {MSpinner, MTag} from '../../feedback'\nimport {MCloseIcon} from '../../../icons'\nimport './MAutocomplete.css'\n\n// Resolve labels for primitive string options without extra configuration.\nfunction defaultGetLabel<T>(option: T): string {\n if (typeof option === 'string') return option\n return String(option)\n}\n\n// Resolve values for primitive string options without extra configuration.\nfunction defaultGetValue<T>(option: T): string {\n if (typeof option === 'string') return option\n return String(option)\n}\n\n// Apply a basic case-insensitive filter when the caller does not provide one.\nfunction defaultFilter<T>(options: T[], input: string, getLabel: (o: T) => string): T[] {\n if (!input) return options\n const lower = input.toLowerCase()\n return options.filter((o) => getLabel(o).toLowerCase().includes(lower))\n}\n\n// Render a searchable suggestion list with optional multi-tag behavior.\nexport function MAutocomplete<T = string>({\n options,\n value,\n onChange,\n getOptionLabel = defaultGetLabel,\n getOptionValue = defaultGetValue,\n filterOptions,\n multiple = false,\n debounceMs = 0,\n onInputChange,\n loading = false,\n loadingText = 'Loading...',\n noOptionsText = 'No options',\n placeholder = 'Type to search...',\n disabled = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n fullWidth = false,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n maxHeight = 300,\n renderOption,\n renderTags,\n className,\n style,\n}: MAutocompleteProps<T>) {\n const [open, setOpen] = useState(false)\n const [inputValue, setInputValue] = useState('')\n const wrapperRef = useRef<HTMLDivElement>(null)\n const inputRef = useRef<HTMLInputElement>(null)\n\n const hasError = error || !!errorText\n\n // Normalize the public value into an array for tag and selection rendering.\n const selectedValues = useMemo(() => {\n if (value == null) return []\n return Array.isArray(value) ? value.filter((item) => item != null) : [value]\n }, [value])\n\n // Filter suggestions locally unless the caller owns that logic.\n const filtered = useMemo(() => {\n if (filterOptions) return filterOptions(options, inputValue)\n return defaultFilter(options, inputValue, getOptionLabel)\n }, [options, inputValue, filterOptions, getOptionLabel])\n\n const debouncedInputChange = useDebouncedCallback((val: string) => onInputChange?.(val), debounceMs)\n\n // Update the visible query and optionally notify async search logic.\n const handleInputChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n setInputValue(e.target.value)\n debouncedInputChange(e.target.value)\n if (!open) setOpen(true)\n },\n [open, debouncedInputChange]\n )\n\n // Apply a selected option to single or multiple value modes.\n const handleSelect = useCallback(\n (index: number) => {\n const opt = filtered[index]\n if (!opt) return\n\n if (multiple) {\n const arr = [...selectedValues]\n const val = getOptionValue(opt)\n const existIdx = arr.findIndex((v) => getOptionValue(v) === val)\n if (existIdx >= 0) {\n arr.splice(existIdx, 1)\n } else {\n arr.push(opt)\n }\n onChange?.(arr)\n setInputValue('')\n inputRef.current?.focus()\n } else {\n onChange?.(opt)\n setInputValue(getOptionLabel(opt))\n setOpen(false)\n }\n },\n [filtered, multiple, selectedValues, getOptionValue, getOptionLabel, onChange]\n )\n\n // Remove a selected tag by index in multiple mode.\n const handleRemoveTag = useCallback(\n (index: number) => {\n const arr = [...selectedValues]\n arr.splice(index, 1)\n onChange?.(multiple ? arr : (arr[0] ?? ('' as unknown as T)))\n },\n [selectedValues, onChange, multiple]\n )\n\n const {\n activeIndex,\n setActiveIndex,\n resetIndex,\n onKeyDown: navKeyDown,\n } = useKeyboardNav({\n itemCount: filtered.length,\n onSelect: handleSelect,\n onClose: () => setOpen(false),\n isOpen: open,\n })\n\n // Combine tag removal and list navigation.\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n // Backspace removes last tag in multiple\n if (e.key === 'Backspace' && multiple && !inputValue && selectedValues.length > 0) {\n handleRemoveTag(selectedValues.length - 1)\n return\n }\n navKeyDown(e as unknown as React.KeyboardEvent)\n },\n [inputValue, multiple, selectedValues, navKeyDown, handleRemoveTag]\n )\n\n // Clear the input query and the selected value(s) together.\n const handleClear = useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation()\n setInputValue('')\n onChange?.(multiple ? ([] as unknown as T) : ('' as unknown as T))\n inputRef.current?.focus()\n },\n [multiple, onChange]\n )\n\n return (\n <div\n className={cn('autocomplete', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={wrapperRef}\n className={cn(\n 'input-wrapper',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={() => inputRef.current?.focus()}\n >\n {multiple &&\n selectedValues.length > 0 &&\n (renderTags ? (\n renderTags(selectedValues, handleRemoveTag)\n ) : (\n <span className=\"tags\">\n {selectedValues.map((v, i) => (\n <MTag\n key={getOptionValue(v)}\n label={getOptionLabel(v)}\n color={color}\n size={size}\n variant=\"solid\"\n closable\n onClose={() => handleRemoveTag(i)}\n />\n ))}\n </span>\n ))}\n\n <input\n ref={inputRef}\n type=\"text\"\n className=\"input\"\n value={inputValue}\n onChange={handleInputChange}\n onFocus={() => {\n setOpen(true)\n resetIndex()\n }}\n onKeyDown={handleKeyDown}\n placeholder={selectedValues.length > 0 ? '' : placeholder}\n disabled={disabled}\n id={id}\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-invalid={hasError || undefined}\n autoComplete=\"off\"\n />\n\n {loading && <MSpinner size=\"sm\" color={color} />}\n\n {clearable && (selectedValues.length > 0 || inputValue) && !loading && !disabled && (\n <button type=\"button\" className=\"clear-btn clear-btn-base\" onClick={handleClear} tabIndex={-1}>\n <MCloseIcon />\n </button>\n )}\n </div>\n\n {name && <input type=\"hidden\" name={name} value={selectedValues.map(getOptionValue).join(',')} />}\n\n <MPopover\n className={cn('autocomplete-popover', color && `color-${color}`)}\n open={open && (filtered.length > 0 || loading || !!inputValue)}\n anchorRef={wrapperRef}\n onClose={() => setOpen(false)}\n matchWidth\n placement=\"bottom-start\"\n >\n <div style={{maxHeight}} className=\"dropdown\">\n {loading ? (\n <div className=\"loading-msg\">{loadingText}</div>\n ) : filtered.length === 0 ? (\n <div className=\"no-options\">{noOptionsText}</div>\n ) : (\n <div className=\"options-list\" role=\"listbox\">\n {filtered.map((opt, i) => {\n const isActive = i === activeIndex\n const isSelected = selectedValues.some((v) => getOptionValue(v) === getOptionValue(opt))\n return (\n <div\n key={getOptionValue(opt)}\n className={cn('option', isActive && 'active', isSelected && 'selected')}\n onClick={() => handleSelect(i)}\n onMouseEnter={() => setActiveIndex(i)}\n role=\"option\"\n aria-selected={isSelected}\n >\n {renderOption ? renderOption(opt, isActive) : getOptionLabel(opt)}\n </div>\n )\n })}\n </div>\n )}\n </div>\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"bottom-row\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"helper-text\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n","const COLOR_MAP: Record<string, string> = {\n primary: 'var(--mineral-primary-rgb)',\n neutral: 'var(--mineral-neutral-rgb)',\n success: 'var(--mineral-success-rgb)',\n error: 'var(--mineral-error-rgb)',\n warning: 'var(--mineral-warning-rgb)',\n info: 'var(--mineral-info-rgb)',\n light: 'var(--mineral-light-rgb)',\n dark: 'var(--mineral-dark-color-rgb)',\n news: 'var(--mineral-news-rgb)',\n}\n\nexport function colorRgbVar(color: string | undefined): string {\n return COLOR_MAP[color ?? 'primary'] ?? COLOR_MAP.primary\n}\n","import {useState, useRef, useCallback, useMemo, useEffect} from 'react'\nimport type * as React from 'react'\nimport type {MDatePickerProps} from './MDatePicker.types'\nimport type {MDateFormat} from '../../inputs'\nimport {MInput} from '../../inputs'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useMDatePickerTexts} from '../../../i18n/frameworkTexts'\nimport {useDocumentLocale} from '../../../utils/locale'\nimport type {ValidationResult} from '../../../utils/validators'\nimport {parseDateString, validateDate} from '../../../utils/validators'\nimport {stripNonDigits, formatDateInput} from '../../../utils/formatters'\nimport {colorRgbVar} from '../../../utils/colorRgbVar'\nimport {\n formatDate,\n daysInMonth,\n firstDayOfMonth,\n isSameDay,\n isDateInRange,\n getDayNames,\n getMonthNames,\n addMonths,\n stripTime,\n combineDateAndTime,\n formatHiddenDateValue,\n formatTimeWithFormat,\n parseTimeWithFormat,\n} from '../../../utils/dateUtils'\nimport {\n MCalendarIcon,\n MChevronLeftIcon as ChevronLeftGlyphIcon,\n MChevronRightIcon as ChevronRightGlyphIcon,\n} from '../../../icons'\nimport './MDatePicker.css'\n\nconst DATE_UNAVAILABLE_ERROR = 'Date is unavailable'\nconst INVALID_TIME_ERROR = 'Invalid time'\n\ntype Meridiem = 'AM' | 'PM'\n\ntype MDatePickerInputConfig = {\n inputFormat: MDateFormat\n separator: '/' | '.' | '-'\n}\n\ntype ParsedInputState =\n | {status: 'empty'}\n | {status: 'partial'; datePart: string; timePart: string}\n | {status: 'invalid'; datePart: string; timePart: string; result: ValidationResult}\n | {status: 'valid'; datePart: string; timePart: string; value: Date}\n\nfunction toDate(value: Date | string | undefined): Date | null {\n if (!value) return null\n if (value instanceof Date) return isNaN(value.getTime()) ? null : new Date(value.getTime())\n\n const date = new Date(value)\n return isNaN(date.getTime()) ? null : date\n}\n\nfunction normalizeDatePickerFormat(format: string): MDatePickerInputConfig {\n const normalizedFormat = format.replace(/DD/g, 'dd').replace(/YYYY/g, 'yyyy')\n const tokens = normalizedFormat.match(/dd|MM|yyyy/g)\n const detectedSeparator = normalizedFormat.match(/[^dMy]/)?.[0]\n const separator =\n detectedSeparator === '/' || detectedSeparator === '.' || detectedSeparator === '-' ? detectedSeparator : '.'\n const order = tokens?.join('/')\n\n switch (order) {\n case 'MM/dd/yyyy':\n return {inputFormat: 'MM/DD/YYYY', separator}\n case 'yyyy/MM/dd':\n return {inputFormat: 'YYYY/MM/DD', separator}\n case 'dd/MM/yyyy':\n default:\n return {inputFormat: 'DD/MM/YYYY', separator}\n }\n}\n\nfunction getDefaultTimePlaceholder(format: '24h' | '12h', showSeconds: boolean): string {\n if (format === '12h') {\n return showSeconds ? 'hh:mm:ss AM' : 'hh:mm AM'\n }\n\n return showSeconds ? 'HH:MM:SS' : 'HH:MM'\n}\n\nfunction getInputPlaceholder(\n basePlaceholder: string | undefined,\n dateFormat: string,\n withTime: boolean,\n timeFormat: '24h' | '12h',\n showSeconds: boolean,\n timePlaceholder?: string\n): string {\n if (basePlaceholder) {\n return basePlaceholder\n }\n\n if (!withTime) {\n return dateFormat\n }\n\n return `${dateFormat} ${timePlaceholder ?? getDefaultTimePlaceholder(timeFormat, showSeconds)}`\n}\n\nfunction formatDisplayValue(\n date: Date | null,\n options: {\n format: string\n withTime: boolean\n timeFormat: '24h' | '12h'\n showSeconds: boolean\n }\n): string {\n if (!date) return ''\n\n const datePart = formatDate(stripTime(date), options.format)\n\n if (!options.withTime) {\n return datePart\n }\n\n return `${datePart} ${formatTimeWithFormat(\n date.getHours(),\n date.getMinutes(),\n date.getSeconds(),\n options.showSeconds,\n options.timeFormat\n )}`\n}\n\nfunction formatTimeDraft(digits: string, showSeconds: boolean): string {\n if (!digits) return ''\n\n if (digits.length <= 2) return digits\n if (digits.length <= 4) return `${digits.slice(0, 2)}:${digits.slice(2)}`\n if (!showSeconds) return `${digits.slice(0, 2)}:${digits.slice(2, 4)}`\n return `${digits.slice(0, 2)}:${digits.slice(2, 4)}:${digits.slice(4, 6)}`\n}\n\nfunction normalizeMeridiemDraft(value: string): string {\n const letters = value.toUpperCase().replace(/[^APM]/g, '')\n\n if (!letters) return ''\n if (letters.startsWith('AM')) return 'AM'\n if (letters.startsWith('PM')) return 'PM'\n if (letters.startsWith('A')) return 'A'\n if (letters.startsWith('P')) return 'P'\n\n return ''\n}\n\nfunction splitInputValue(value: string, withTime: boolean) {\n const trimmed = value.trim()\n\n if (!trimmed) {\n return {datePart: '', timePart: ''}\n }\n\n if (!withTime) {\n return {datePart: trimmed, timePart: ''}\n }\n\n const firstSpaceIndex = trimmed.indexOf(' ')\n\n if (firstSpaceIndex === -1) {\n return {datePart: trimmed, timePart: ''}\n }\n\n return {\n datePart: trimmed.slice(0, firstSpaceIndex).trim(),\n timePart: trimmed.slice(firstSpaceIndex + 1).trim(),\n }\n}\n\nfunction formatTypedInput(\n rawValue: string,\n options: {\n inputFormat: MDateFormat\n separator: '/' | '.' | '-'\n withTime: boolean\n timeFormat: '24h' | '12h'\n showSeconds: boolean\n }\n) {\n const normalizedValue = rawValue.toUpperCase()\n const digits = stripNonDigits(normalizedValue)\n const dateDigits = digits.slice(0, 8)\n const timeDigits = options.withTime ? digits.slice(8, 8 + (options.showSeconds ? 6 : 4)) : ''\n const datePart = formatDateInput(dateDigits, options.inputFormat, options.separator)\n\n if (!options.withTime) {\n return {formatted: datePart, datePart, timePart: ''}\n }\n\n const timeBase = formatTimeDraft(timeDigits, options.showSeconds)\n const meridiem = options.timeFormat === '12h' ? normalizeMeridiemDraft(normalizedValue) : ''\n const timePart = `${timeBase}${meridiem ? `${timeBase ? ' ' : ''}${meridiem}` : ''}`.trim()\n\n if (!datePart) {\n return {formatted: timePart, datePart: '', timePart}\n }\n\n return {\n formatted: timePart ? `${datePart} ${timePart}` : datePart,\n datePart,\n timePart,\n }\n}\n\nfunction getTimeDraftFromDate(date: Date | null, showSeconds: boolean): string {\n if (!date) return ''\n return formatTimeWithFormat(date.getHours(), date.getMinutes(), date.getSeconds(), showSeconds, '24h')\n}\n\nfunction parseInputValue(\n value: string,\n options: {\n inputFormat: MDateFormat\n minDate: Date | null\n maxDate: Date | null\n withTime: boolean\n timeFormat: '24h' | '12h'\n showSeconds: boolean\n isDisabled: (date: Date) => boolean\n }\n): ParsedInputState {\n const {datePart, timePart} = splitInputValue(value, options.withTime)\n\n if (!datePart && !timePart) {\n return {status: 'empty'}\n }\n\n const validation = validateDate(datePart, {\n format: options.inputFormat,\n minDate: options.minDate ?? undefined,\n maxDate: options.maxDate ?? undefined,\n })\n\n if (!validation.valid) {\n return validation.error === 'Incomplete date'\n ? {status: 'partial', datePart, timePart}\n : {status: 'invalid', datePart, timePart, result: validation}\n }\n\n const parsedDate = parseDateString(datePart, options.inputFormat)\n\n if (!parsedDate) {\n return {status: 'invalid', datePart, timePart, result: {valid: false, error: 'Invalid date'}}\n }\n\n if (options.isDisabled(parsedDate)) {\n return {status: 'invalid', datePart, timePart, result: {valid: false, error: DATE_UNAVAILABLE_ERROR}}\n }\n\n if (!options.withTime) {\n return {status: 'valid', datePart, timePart: '', value: stripTime(parsedDate)}\n }\n\n if (!timePart) {\n return {\n status: 'valid',\n datePart,\n timePart: '',\n value: combineDateAndTime(parsedDate, '', {format: options.timeFormat, showSeconds: options.showSeconds}),\n }\n }\n\n const parsedTime = parseTimeWithFormat(timePart, options.timeFormat)\n\n if (!parsedTime) {\n return {status: 'invalid', datePart, timePart, result: {valid: false, error: INVALID_TIME_ERROR}}\n }\n\n return {\n status: 'valid',\n datePart,\n timePart,\n value: combineDateAndTime(parsedDate, timePart, {format: options.timeFormat, showSeconds: options.showSeconds}),\n }\n}\n\nfunction to12HourParts(value: {hours: number; minutes: number; seconds: number}) {\n const meridiem: Meridiem = value.hours >= 12 ? 'PM' : 'AM'\n const hours = value.hours % 12 || 12\n return {hours, minutes: value.minutes, seconds: value.seconds, meridiem}\n}\n\nfunction to24HourValue(hours: number, meridiem: Meridiem): number {\n if (meridiem === 'AM') {\n return hours === 12 ? 0 : hours\n }\n\n return hours === 12 ? 12 : hours + 12\n}\n\nexport function MDatePicker({\n value,\n defaultValue,\n onChange,\n format = 'dd.MM.yyyy',\n locale: localeOverride,\n min,\n max,\n disabledDates,\n placeholder,\n disabled = false,\n readOnly = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n withTime = false,\n validateOnBlur = true,\n validateOnChange = false,\n onValidationChange,\n timeFormat = '24h',\n showSeconds = false,\n minuteStep = 1,\n timePlaceholder,\n inline = false,\n showTodayButton = true,\n firstDayOfWeek = 1,\n fullWidth = false,\n className,\n style,\n}: MDatePickerProps) {\n const locale = useDocumentLocale(localeOverride)\n const texts = useMDatePickerTexts()\n const {inputFormat, separator} = useMemo(() => normalizeDatePickerFormat(format), [format])\n const [open, setOpen] = useState(false)\n const [internalValue, setInternalValue] = useState<Date | null>(() => toDate(defaultValue))\n const [validationState, setValidationState] = useState<ValidationResult>({valid: true})\n const [touched, setTouched] = useState(false)\n const selectedValue = value !== undefined ? toDate(value) : internalValue\n const [inputValue, setInputValue] = useState(() =>\n formatDisplayValue(selectedValue, {format, withTime, timeFormat, showSeconds})\n )\n const [draftTimeValue, setDraftTimeValue] = useState(() => getTimeDraftFromDate(selectedValue, showSeconds))\n const [viewDate, setViewDate] = useState(() => {\n const baseDate = selectedValue ? stripTime(selectedValue) : new Date()\n return new Date(baseDate.getFullYear(), baseDate.getMonth(), 1)\n })\n const [viewMode, setViewMode] = useState<'days' | 'months'>('days')\n const anchorRef = useRef<HTMLDivElement>(null)\n const selectedValueKey = selectedValue?.getTime() ?? null\n const minDate = toDate(min)\n const maxDate = toDate(max)\n const hasError = error || (touched && !validationState.valid)\n const resolvedErrorText = errorText || (touched && !validationState.valid ? validationState.error : undefined)\n const dayNames = getDayNames(locale, firstDayOfWeek)\n const monthNames = getMonthNames(locale)\n\n useEffect(() => {\n setInputValue(formatDisplayValue(selectedValue, {format, withTime, timeFormat, showSeconds}))\n setDraftTimeValue(getTimeDraftFromDate(selectedValue, showSeconds))\n if (selectedValue) {\n const normalizedDate = stripTime(selectedValue)\n setViewDate(new Date(normalizedDate.getFullYear(), normalizedDate.getMonth(), 1))\n }\n }, [format, selectedValueKey, showSeconds, timeFormat, withTime])\n\n const isDisabled = useCallback(\n (date: Date): boolean => {\n if (!isDateInRange(date, minDate, maxDate)) return true\n if (Array.isArray(disabledDates)) {\n return disabledDates.some((disabledDate) => isSameDay(disabledDate, date))\n }\n if (typeof disabledDates === 'function') {\n return disabledDates(date)\n }\n return false\n },\n [disabledDates, maxDate, minDate]\n )\n\n const emitValidation = useCallback(\n (result: ValidationResult) => {\n setValidationState(result)\n onValidationChange?.(result)\n },\n [onValidationChange]\n )\n\n const commitValue = useCallback(\n (nextValue: Date | null) => {\n if (value === undefined) {\n setInternalValue(nextValue)\n }\n\n onChange?.(nextValue)\n },\n [onChange, value]\n )\n\n const parsedInputState = useMemo(\n () =>\n parseInputValue(inputValue, {\n inputFormat,\n minDate,\n maxDate,\n withTime,\n timeFormat,\n showSeconds,\n isDisabled,\n }),\n [inputFormat, inputValue, isDisabled, maxDate, minDate, showSeconds, timeFormat, withTime]\n )\n\n const currentDateForPanel = useMemo(() => {\n if (parsedInputState.status === 'valid') {\n return stripTime(parsedInputState.value)\n }\n\n return selectedValue ? stripTime(selectedValue) : null\n }, [parsedInputState, selectedValue])\n\n const currentTimeForPanel = useMemo(() => {\n if (!withTime) return null\n\n const timeSource =\n parsedInputState.status !== 'empty' && parsedInputState.timePart\n ? parsedInputState.timePart\n : draftTimeValue || getTimeDraftFromDate(selectedValue, showSeconds)\n\n return parseTimeWithFormat(timeSource, timeFormat) ?? {hours: 0, minutes: 0, seconds: 0}\n }, [draftTimeValue, parsedInputState, selectedValue, showSeconds, timeFormat, withTime])\n\n const handleInputChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const nextTyped = formatTypedInput(event.target.value, {\n inputFormat,\n separator,\n withTime,\n timeFormat,\n showSeconds,\n })\n\n setInputValue(nextTyped.formatted)\n setDraftTimeValue(nextTyped.timePart)\n\n const nextParsedState = parseInputValue(nextTyped.formatted, {\n inputFormat,\n minDate,\n maxDate,\n withTime,\n timeFormat,\n showSeconds,\n isDisabled,\n })\n\n if (nextParsedState.status === 'empty') {\n emitValidation({valid: true})\n commitValue(null)\n return\n }\n\n if (nextParsedState.status === 'invalid' && validateOnChange) {\n emitValidation(nextParsedState.result)\n } else if (nextParsedState.status === 'valid') {\n emitValidation({valid: true})\n commitValue(nextParsedState.value)\n setViewDate(new Date(nextParsedState.value.getFullYear(), nextParsedState.value.getMonth(), 1))\n }\n },\n [\n commitValue,\n emitValidation,\n inputFormat,\n isDisabled,\n maxDate,\n minDate,\n separator,\n showSeconds,\n timeFormat,\n validateOnChange,\n withTime,\n ]\n )\n\n const handleInputBlur = useCallback(() => {\n setTouched(true)\n\n const nextParsedState = parseInputValue(inputValue, {\n inputFormat,\n minDate,\n maxDate,\n withTime,\n timeFormat,\n showSeconds,\n isDisabled,\n })\n\n if (nextParsedState.status === 'empty') {\n emitValidation({valid: true})\n return\n }\n\n if (nextParsedState.status === 'partial') {\n if (validateOnBlur) {\n emitValidation({valid: false, error: 'Incomplete date'})\n }\n return\n }\n\n if (nextParsedState.status === 'invalid') {\n if (validateOnBlur) {\n emitValidation(nextParsedState.result)\n }\n return\n }\n\n emitValidation({valid: true})\n setInputValue(formatDisplayValue(nextParsedState.value, {format, withTime, timeFormat, showSeconds}))\n setDraftTimeValue(getTimeDraftFromDate(nextParsedState.value, showSeconds))\n commitValue(nextParsedState.value)\n }, [\n commitValue,\n emitValidation,\n format,\n inputFormat,\n inputValue,\n isDisabled,\n maxDate,\n minDate,\n showSeconds,\n timeFormat,\n validateOnBlur,\n withTime,\n ])\n\n const handleInputKeyDown = useCallback(\n (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (['Backspace', 'Delete', 'Tab', 'ArrowLeft', 'ArrowRight', 'Home', 'End', 'Enter'].includes(event.key)) {\n return\n }\n\n if (event.ctrlKey || event.metaKey) {\n return\n }\n\n const allowCharacter = withTime ? /^[0-9\\s:./-APMapm]$/ : /^[0-9./-]$/\n\n if (!allowCharacter.test(event.key)) {\n event.preventDefault()\n }\n },\n [withTime]\n )\n\n const handleClear = useCallback(() => {\n setInputValue('')\n setDraftTimeValue('')\n setTouched(false)\n emitValidation({valid: true})\n commitValue(null)\n }, [commitValue, emitValidation])\n\n const handleTogglePopover = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault()\n event.stopPropagation()\n\n if (disabled || readOnly || inline) return\n\n setOpen((current) => !current)\n },\n [disabled, inline, readOnly]\n )\n\n const handleSelectDate = useCallback(\n (date: Date) => {\n if (isDisabled(date)) return\n\n const nextTime = withTime ? draftTimeValue || formatTimeWithFormat(0, 0, 0, showSeconds, timeFormat) : ''\n const nextValue = withTime\n ? combineDateAndTime(date, nextTime, {format: timeFormat, showSeconds})\n : stripTime(date)\n\n setTouched(true)\n emitValidation({valid: true})\n setDraftTimeValue(nextTime)\n setInputValue(formatDisplayValue(nextValue, {format, withTime, timeFormat, showSeconds}))\n setViewDate(new Date(date.getFullYear(), date.getMonth(), 1))\n commitValue(nextValue)\n\n if (!withTime && !inline) {\n setOpen(false)\n }\n },\n [commitValue, draftTimeValue, emitValidation, format, inline, isDisabled, showSeconds, timeFormat, withTime]\n )\n\n const handleToday = useCallback(() => {\n const today = stripTime(new Date())\n\n if (isDisabled(today)) return\n\n handleSelectDate(today)\n }, [handleSelectDate, isDisabled])\n\n const hours = useMemo(() => {\n if (!withTime) return []\n\n const items: number[] = []\n const maxHour = timeFormat === '12h' ? 12 : 23\n const startHour = timeFormat === '12h' ? 1 : 0\n\n for (let index = startHour; index <= maxHour; index += 1) {\n items.push(index)\n }\n\n return items\n }, [timeFormat, withTime])\n\n const minutes = useMemo(() => {\n if (!withTime) return []\n\n const items: number[] = []\n\n for (let index = 0; index < 60; index += minuteStep) {\n items.push(index)\n }\n\n return items\n }, [minuteStep, withTime])\n\n const seconds = useMemo(() => {\n if (!withTime || !showSeconds) return []\n\n const items: number[] = []\n\n for (let index = 0; index < 60; index += 1) {\n items.push(index)\n }\n\n return items\n }, [showSeconds, withTime])\n\n const handleTimeSelection = useCallback(\n (hoursValue: number, minutesValue: number, secondsValue: number = 0) => {\n const formattedTime = formatTimeWithFormat(hoursValue, minutesValue, secondsValue, showSeconds, timeFormat)\n const nextDate = currentDateForPanel\n\n setTouched(true)\n setDraftTimeValue(formattedTime)\n\n if (!nextDate) {\n setInputValue(formattedTime)\n return\n }\n\n const nextValue = combineDateAndTime(nextDate, formattedTime, {format: timeFormat, showSeconds})\n\n emitValidation({valid: true})\n setInputValue(formatDisplayValue(nextValue, {format, withTime, timeFormat, showSeconds}))\n commitValue(nextValue)\n },\n [commitValue, currentDateForPanel, emitValidation, format, showSeconds, timeFormat, withTime]\n )\n\n const handleMeridiemChange = useCallback(\n (meridiem: Meridiem) => {\n const currentHours = currentTimeForPanel ? to12HourParts(currentTimeForPanel).hours : 12\n const nextHours = to24HourValue(currentHours, meridiem)\n\n handleTimeSelection(nextHours, currentTimeForPanel?.minutes ?? 0, currentTimeForPanel?.seconds ?? 0)\n },\n [currentTimeForPanel, handleTimeSelection]\n )\n\n const calendarDays = useMemo(() => {\n const year = viewDate.getFullYear()\n const month = viewDate.getMonth()\n const totalDays = daysInMonth(year, month)\n let startDay = firstDayOfMonth(year, month)\n\n if (firstDayOfWeek === 1) {\n startDay = startDay === 0 ? 6 : startDay - 1\n }\n\n const days: Array<{date: Date; currentMonth: boolean}> = []\n const prevMonth = month === 0 ? 11 : month - 1\n const prevYear = month === 0 ? year - 1 : year\n const prevDays = daysInMonth(prevYear, prevMonth)\n\n for (let index = startDay - 1; index >= 0; index -= 1) {\n days.push({date: new Date(prevYear, prevMonth, prevDays - index), currentMonth: false})\n }\n\n for (let day = 1; day <= totalDays; day += 1) {\n days.push({date: new Date(year, month, day), currentMonth: true})\n }\n\n const remaining = 42 - days.length\n const nextMonth = month === 11 ? 0 : month + 1\n const nextYear = month === 11 ? year + 1 : year\n\n for (let day = 1; day <= remaining; day += 1) {\n days.push({date: new Date(nextYear, nextMonth, day), currentMonth: false})\n }\n\n return days\n }, [firstDayOfWeek, viewDate])\n\n const today = stripTime(new Date())\n const selectedDate = selectedValue ? stripTime(selectedValue) : currentDateForPanel\n\n const renderCalendar = () => (\n <div className=\"calendar\">\n <div className=\"calendar-header\">\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, -1))}\n aria-label={texts.previousMonth}\n >\n <ChevronLeftGlyphIcon />\n </button>\n <button\n type=\"button\"\n className=\"header-title\"\n onClick={() => setViewMode((current) => (current === 'days' ? 'months' : 'days'))}\n >\n {monthNames[viewDate.getMonth()]} {viewDate.getFullYear()}\n </button>\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, 1))}\n aria-label={texts.nextMonth}\n >\n <ChevronRightGlyphIcon />\n </button>\n </div>\n\n {viewMode === 'days' ? (\n <>\n <div className=\"day-names\">\n {dayNames.map((dayName) => (\n <span key={dayName} className=\"day-name\">\n {dayName}\n </span>\n ))}\n </div>\n\n <div className=\"day-grid\">\n {calendarDays.map(({date, currentMonth}, index) => {\n const isSelected = selectedDate ? isSameDay(date, selectedDate) : false\n const isToday = isSameDay(date, today)\n const disabledDay = isDisabled(date)\n\n return (\n <button\n key={`${date.toISOString()}-${index}`}\n type=\"button\"\n className={cn(\n 'day',\n !currentMonth && 'other-month',\n isToday && 'today',\n isSelected && 'selected',\n disabledDay && 'disabled'\n )}\n onClick={() => handleSelectDate(date)}\n disabled={disabledDay}\n tabIndex={-1}\n >\n {date.getDate()}\n </button>\n )\n })}\n </div>\n </>\n ) : (\n <div className=\"month-grid\">\n {monthNames.map((monthName, index) => (\n <button\n key={monthName}\n type=\"button\"\n className={cn('month-cell', viewDate.getMonth() === index && 'selected')}\n onClick={() => {\n setViewDate(new Date(viewDate.getFullYear(), index, 1))\n setViewMode('days')\n }}\n >\n {monthName.slice(0, 3)}\n </button>\n ))}\n </div>\n )}\n\n {showTodayButton && (\n <div className=\"footer\">\n <button type=\"button\" className=\"today-btn\" onClick={handleToday}>\n {texts.today}\n </button>\n </div>\n )}\n </div>\n )\n\n const renderTimePanel = () => {\n if (!withTime) return null\n\n const displayTime = currentTimeForPanel ? to12HourParts(currentTimeForPanel) : null\n\n return (\n <div className=\"date-picker-time-panel\">\n <div className=\"date-picker-time-header\">Time</div>\n <div className=\"date-picker-time-columns\">\n <TimeColumn\n items={hours}\n selected={timeFormat === '12h' ? displayTime?.hours : currentTimeForPanel?.hours}\n onSelect={(hoursValue) =>\n handleTimeSelection(\n timeFormat === '12h'\n ? to24HourValue(hoursValue, displayTime?.meridiem ?? 'AM')\n : hoursValue,\n currentTimeForPanel?.minutes ?? 0,\n currentTimeForPanel?.seconds ?? 0\n )\n }\n label=\"Hr\"\n />\n <TimeColumn\n items={minutes}\n selected={currentTimeForPanel?.minutes}\n onSelect={(minutesValue) =>\n handleTimeSelection(\n currentTimeForPanel?.hours ?? 0,\n minutesValue,\n currentTimeForPanel?.seconds ?? 0\n )\n }\n label=\"Min\"\n />\n {showSeconds && (\n <TimeColumn\n items={seconds}\n selected={currentTimeForPanel?.seconds}\n onSelect={(secondsValue) =>\n handleTimeSelection(\n currentTimeForPanel?.hours ?? 0,\n currentTimeForPanel?.minutes ?? 0,\n secondsValue\n )\n }\n label=\"Sec\"\n />\n )}\n {timeFormat === '12h' && (\n <TimeColumn\n items={['AM', 'PM']}\n selected={displayTime?.meridiem}\n onSelect={handleMeridiemChange}\n label=\"AM/PM\"\n />\n )}\n </div>\n </div>\n )\n }\n\n const renderPopoverContent = () => (\n <div className={cn('date-picker-popover-content', withTime && 'with-time')}>\n {renderCalendar()}\n {renderTimePanel()}\n </div>\n )\n\n const maxLength = withTime ? (timeFormat === '12h' ? (showSeconds ? 22 : 19) : showSeconds ? 19 : 16) : 10\n const inputPlaceholder = getInputPlaceholder(\n placeholder,\n format,\n withTime,\n timeFormat,\n showSeconds,\n timePlaceholder\n )\n\n if (inline) {\n return (\n <div\n className={cn('date-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n <MInput\n value={inputValue}\n onChange={handleInputChange}\n onBlur={handleInputBlur}\n onKeyDown={handleInputKeyDown}\n onClear={handleClear}\n type=\"text\"\n inputMode={withTime ? 'text' : 'numeric'}\n autoComplete=\"off\"\n maxLength={maxLength}\n placeholder={inputPlaceholder}\n disabled={disabled}\n readOnly={readOnly}\n id={id}\n variant={variant}\n size={size}\n color={color}\n label={label}\n helperText={helperText}\n error={hasError}\n errorText={resolvedErrorText}\n required={required}\n clearable={clearable}\n fullWidth={fullWidth}\n />\n {renderPopoverContent()}\n {name && selectedValue && (\n <input\n type=\"hidden\"\n name={name}\n value={formatHiddenDateValue(selectedValue, withTime, showSeconds)}\n />\n )}\n </div>\n )\n }\n\n return (\n <div\n className={cn('date-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n <div ref={anchorRef} className=\"date-picker-input-anchor\">\n <MInput\n value={inputValue}\n onChange={handleInputChange}\n onBlur={handleInputBlur}\n onKeyDown={handleInputKeyDown}\n onClear={handleClear}\n type=\"text\"\n inputMode={withTime ? 'text' : 'numeric'}\n autoComplete=\"off\"\n maxLength={maxLength}\n placeholder={inputPlaceholder}\n disabled={disabled}\n readOnly={readOnly}\n id={id}\n variant={variant}\n size={size}\n color={color}\n label={label}\n helperText={helperText}\n error={hasError}\n errorText={resolvedErrorText}\n required={required}\n clearable={clearable}\n fullWidth={fullWidth}\n endIcon={\n <button\n type=\"button\"\n className=\"date-picker-toggle\"\n onMouseDown={(event) => event.preventDefault()}\n onClick={handleTogglePopover}\n aria-label=\"Open calendar\"\n disabled={disabled || readOnly}\n >\n <MCalendarIcon />\n </button>\n }\n />\n </div>\n\n {name && selectedValue && (\n <input type=\"hidden\" name={name} value={formatHiddenDateValue(selectedValue, withTime, showSeconds)} />\n )}\n\n <MPopover\n className=\"date-picker-popover\"\n style={{'--color-rgb': colorRgbVar(color)} as React.CSSProperties}\n open={open}\n anchorRef={anchorRef}\n onClose={() => setOpen(false)}\n placement=\"bottom-start\"\n >\n {renderPopoverContent()}\n </MPopover>\n </div>\n )\n}\n\nfunction TimeColumn<T extends number | Meridiem>({\n items,\n selected,\n onSelect,\n label,\n}: {\n items: T[]\n selected?: T\n onSelect: (value: T) => void\n label: string\n}) {\n const listRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n if (selected === undefined || !listRef.current) return\n\n const element = listRef.current.querySelector(`[data-value=\"${selected}\"]`) as HTMLElement | null\n\n if (element) {\n const list = listRef.current\n list.scrollTop = element.offsetTop - list.clientHeight / 2 + element.offsetHeight / 2\n }\n }, [selected])\n\n const renderValue = (value: T) => (typeof value === 'number' ? value.toString().padStart(2, '0') : value)\n\n return (\n <div className=\"date-picker-time-column\">\n <div className=\"date-picker-time-column-label\">{label}</div>\n <div ref={listRef} className=\"date-picker-time-column-list\">\n {items.map((item) => (\n <button\n key={item}\n type=\"button\"\n data-value={item}\n className={cn('date-picker-time-column-item', item === selected && 'selected')}\n onClick={() => onSelect(item)}\n >\n {renderValue(item)}\n </button>\n ))}\n </div>\n </div>\n )\n}\n","import {useState, useRef, useCallback, useMemo, useEffect} from 'react'\nimport type * as React from 'react'\nimport type {MTimePickerProps} from './MTimePicker.types'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {MClockIcon, MCloseIcon} from '../../../icons'\nimport {formatTime, parseTime} from '../../../utils/dateUtils'\nimport './MTimePicker.css'\n\ntype ParsedTimeValue = {hours: number; minutes: number; seconds: number}\ntype Meridiem = 'AM' | 'PM'\n\nfunction to12HourParts(value: ParsedTimeValue) {\n const meridiem: Meridiem = value.hours >= 12 ? 'PM' : 'AM'\n const hours = value.hours % 12 || 12\n return {hours, minutes: value.minutes, seconds: value.seconds, meridiem}\n}\n\nfunction to24HourValue(hours: number, meridiem: Meridiem): number {\n if (meridiem === 'AM') {\n return hours === 12 ? 0 : hours\n }\n return hours === 12 ? 12 : hours + 12\n}\n\nfunction formatTimeValue(\n hours: number,\n minutes: number,\n seconds: number,\n showSeconds: boolean,\n format: '24h' | '12h'\n): string {\n if (format === '24h') {\n return formatTime(hours, minutes, seconds, showSeconds)\n }\n\n const parts = to12HourParts({hours, minutes, seconds})\n const base = `${parts.hours.toString().padStart(2, '0')}:${parts.minutes.toString().padStart(2, '0')}`\n const withSeconds = showSeconds ? `${base}:${parts.seconds.toString().padStart(2, '0')}` : base\n return `${withSeconds} ${parts.meridiem}`\n}\n\nfunction parseTimeValue(value: string, format: '24h' | '12h'): ParsedTimeValue | null {\n if (format === '24h') {\n return parseTime(value)\n }\n\n const normalized = value.trim().toUpperCase()\n const match = normalized.match(/^(\\d{1,2}):(\\d{2})(?::(\\d{2}))?\\s*(AM|PM)$/)\n if (match) {\n const hours = parseInt(match[1], 10)\n const minutes = parseInt(match[2], 10)\n const seconds = match[3] ? parseInt(match[3], 10) : 0\n const meridiem = match[4] as Meridiem\n\n if (hours < 1 || hours > 12 || minutes > 59 || seconds > 59) {\n return null\n }\n\n return {hours: to24HourValue(hours, meridiem), minutes, seconds}\n }\n\n return parseTime(value)\n}\n\n// Compare time tuples so min/max checks can stay string-format agnostic.\nfunction compareTimeParts(\n left: {hours: number; minutes: number; seconds: number},\n right: {hours: number; minutes: number; seconds: number}\n): number {\n if (left.hours !== right.hours) return left.hours - right.hours\n if (left.minutes !== right.minutes) return left.minutes - right.minutes\n return left.seconds - right.seconds\n}\n\n// Check whether a time falls within optional min and max boundaries.\nfunction isTimeInRange(\n value: {hours: number; minutes: number; seconds: number},\n min?: {hours: number; minutes: number; seconds: number} | null,\n max?: {hours: number; minutes: number; seconds: number} | null\n): boolean {\n return (!min || compareTimeParts(value, min) >= 0) && (!max || compareTimeParts(value, max) <= 0)\n}\n\n// Render a time input backed by scrollable hour, minute and second columns.\nexport function MTimePicker({\n value,\n defaultValue,\n onChange,\n format = '24h',\n showSeconds = false,\n minuteStep = 1,\n min,\n max,\n placeholder,\n disabled = false,\n readOnly = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n fullWidth = false,\n className,\n style,\n}: MTimePickerProps) {\n const [open, setOpen] = useState(false)\n const [internalValue, setInternalValue] = useState(defaultValue ?? '')\n const triggerRef = useRef<HTMLDivElement>(null)\n\n const currentValue = value !== undefined ? value : internalValue\n const hasError = error || !!errorText\n const parsed = parseTimeValue(currentValue, format)\n const minTime = parseTimeValue(min ?? '', format)\n const maxTime = parseTimeValue(max ?? '', format)\n const displayTime = parsed ? to12HourParts(parsed) : null\n const displayValue = parsed\n ? formatTimeValue(parsed.hours, parsed.minutes, parsed.seconds, showSeconds, format)\n : currentValue\n\n // Build the visible hour list based on the selected time format.\n const hours = useMemo(() => {\n const items: number[] = []\n const maxHour = format === '12h' ? 12 : 23\n const startHour = format === '12h' ? 1 : 0\n for (let index = startHour; index <= maxHour; index++) {\n items.push(index)\n }\n return items\n }, [format])\n\n // Build the minute list using the configured step size.\n const minutes = useMemo(() => {\n const items: number[] = []\n for (let index = 0; index < 60; index += minuteStep) {\n items.push(index)\n }\n return items\n }, [minuteStep])\n\n // Build the seconds list only when the picker exposes seconds.\n const seconds = useMemo(() => {\n if (!showSeconds) return []\n const items: number[] = []\n for (let index = 0; index < 60; index++) {\n items.push(index)\n }\n return items\n }, [showSeconds])\n\n // Reuse range validation for list rendering and direct text input.\n const isSelectable = useCallback(\n (hoursValue: number, minutesValue: number, secondsValue: number = 0) => {\n return isTimeInRange({hours: hoursValue, minutes: minutesValue, seconds: secondsValue}, minTime, maxTime)\n },\n [maxTime, minTime]\n )\n\n // Apply the selected time and keep uncontrolled usage in sync.\n const handleSelect = useCallback(\n (hoursValue: number, minutesValue: number, secondsValue: number = 0) => {\n if (!isSelectable(hoursValue, minutesValue, secondsValue)) return\n const time = formatTimeValue(hoursValue, minutesValue, secondsValue, showSeconds, format)\n if (value === undefined) setInternalValue(time)\n onChange?.(time)\n },\n [format, isSelectable, onChange, showSeconds, value]\n )\n\n const handleInputChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const raw = event.target.value\n if (value === undefined) setInternalValue(raw)\n },\n [value]\n )\n\n // Normalize manual input once the user leaves the field.\n const handleInputBlur = useCallback(() => {\n const nextValue = parseTimeValue(currentValue, format)\n if (nextValue && isTimeInRange(nextValue, minTime, maxTime)) {\n const time = formatTimeValue(nextValue.hours, nextValue.minutes, nextValue.seconds, showSeconds, format)\n if (value === undefined) setInternalValue(time)\n onChange?.(time)\n }\n }, [currentValue, format, maxTime, minTime, onChange, showSeconds, value])\n\n const handleMeridiemChange = useCallback(\n (meridiem: Meridiem) => {\n const currentHours = displayTime?.hours ?? 12\n const minutesValue = parsed?.minutes ?? 0\n const secondsValue = parsed?.seconds ?? 0\n const nextHours = to24HourValue(currentHours, meridiem)\n handleSelect(nextHours, minutesValue, secondsValue)\n },\n [displayTime?.hours, handleSelect, parsed?.minutes, parsed?.seconds]\n )\n\n // Clear the current time without closing the trigger first.\n const handleClear = useCallback(\n (event: React.MouseEvent) => {\n event.stopPropagation()\n if (value === undefined) setInternalValue('')\n onChange?.('')\n },\n [onChange, value]\n )\n\n return (\n <div\n className={cn('time picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={triggerRef}\n className={cn(\n 'time trigger',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={() => !disabled && !readOnly && setOpen(true)}\n >\n <span className=\"time icon\">\n <MClockIcon />\n </span>\n <input\n type=\"text\"\n className=\"time input\"\n value={displayValue}\n onChange={handleInputChange}\n onBlur={handleInputBlur}\n placeholder={\n placeholder ??\n (format === '12h'\n ? showSeconds\n ? 'hh:mm:ss AM'\n : 'hh:mm AM'\n : showSeconds\n ? 'HH:MM:SS'\n : 'HH:MM')\n }\n disabled={disabled}\n readOnly={readOnly}\n id={id}\n aria-invalid={hasError || undefined}\n />\n {clearable && currentValue && !disabled && (\n <button\n type=\"button\"\n className=\"time clear clear-btn-base\"\n onClick={handleClear}\n tabIndex={-1}\n aria-label=\"Clear time\"\n >\n <MCloseIcon />\n </button>\n )}\n </div>\n\n {name && <input type=\"hidden\" name={name} value={displayValue} />}\n\n <MPopover\n className=\"time picker popover\"\n open={open}\n anchorRef={triggerRef}\n onClose={() => setOpen(false)}\n placement=\"bottom-start\"\n >\n <div className=\"time columns\">\n <TimeColumn\n items={hours}\n selected={format === '12h' ? displayTime?.hours : parsed?.hours}\n onSelect={(hoursValue) =>\n handleSelect(\n format === '12h'\n ? to24HourValue(hoursValue, displayTime?.meridiem ?? 'AM')\n : hoursValue,\n parsed?.minutes ?? 0,\n parsed?.seconds ?? 0\n )\n }\n isDisabled={(hoursValue) =>\n !isSelectable(\n format === '12h'\n ? to24HourValue(hoursValue, displayTime?.meridiem ?? 'AM')\n : hoursValue,\n parsed?.minutes ?? 0,\n parsed?.seconds ?? 0\n )\n }\n label=\"Hr\"\n />\n <TimeColumn\n items={minutes}\n selected={parsed?.minutes}\n onSelect={(minutesValue) =>\n handleSelect(parsed?.hours ?? 0, minutesValue, parsed?.seconds ?? 0)\n }\n isDisabled={(minutesValue) =>\n !isSelectable(parsed?.hours ?? 0, minutesValue, parsed?.seconds ?? 0)\n }\n label=\"Min\"\n />\n {showSeconds && (\n <TimeColumn\n items={seconds}\n selected={parsed?.seconds}\n onSelect={(secondsValue) =>\n handleSelect(parsed?.hours ?? 0, parsed?.minutes ?? 0, secondsValue)\n }\n isDisabled={(secondsValue) =>\n !isSelectable(parsed?.hours ?? 0, parsed?.minutes ?? 0, secondsValue)\n }\n label=\"Sec\"\n />\n )}\n {format === '12h' && (\n <TimeColumn\n items={['AM', 'PM']}\n selected={displayTime?.meridiem}\n onSelect={handleMeridiemChange}\n label=\"AM/PM\"\n />\n )}\n </div>\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"time bottom\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"time helper\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n\n// Render one scrollable time column and keep the selected value centered.\nfunction TimeColumn<T extends number | Meridiem>({\n items,\n selected,\n onSelect,\n isDisabled,\n label,\n}: {\n items: T[]\n selected?: T\n onSelect: (value: T) => void\n isDisabled?: (value: T) => boolean\n label: string\n}) {\n const listRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n if (selected === undefined || !listRef.current) return\n const element = listRef.current.querySelector(`[data-value=\"${selected}\"]`) as HTMLElement | null\n if (element) {\n const list = listRef.current\n list.scrollTop = element.offsetTop - list.clientHeight / 2 + element.offsetHeight / 2\n }\n }, [selected])\n\n const renderValue = (value: T) => (typeof value === 'number' ? value.toString().padStart(2, '0') : value)\n\n return (\n <div className=\"time column\">\n <div className=\"time column label\">{label}</div>\n <div ref={listRef} className=\"time column list\">\n {items.map((item) => {\n const disabled = isDisabled?.(item) ?? false\n return (\n <button\n key={item}\n type=\"button\"\n data-value={item}\n className={cn('time column item', item === selected && 'selected', disabled && 'disabled')}\n onClick={() => onSelect(item)}\n disabled={disabled}\n >\n {renderValue(item)}\n </button>\n )\n })}\n </div>\n </div>\n )\n}\n","import {useCallback, useEffect, useMemo, useRef, useState} from 'react'\nimport type * as React from 'react'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useMDateRangePickerTexts} from '../../../i18n/frameworkTexts'\nimport {useDocumentLocale} from '../../../utils/locale'\nimport {MCalendarIcon, MChevronLeftIcon, MChevronRightIcon, MCloseIcon} from '../../../icons'\nimport {\n addMonths,\n daysInMonth,\n firstDayOfMonth,\n formatDate,\n getDayNames,\n getMonthNames,\n isDateInRange,\n isSameDay,\n stripTime,\n} from '../../../utils/dateUtils'\nimport type {MDateRangePickerProps, MDateRangePreset} from './MDateRangePicker.types'\nimport {colorRgbVar} from '../../../utils/colorRgbVar'\nimport './MDateRangePicker.css'\n\nfunction toDate(value: Date | string | null | undefined): Date | null {\n if (!value) return null\n if (value instanceof Date) return stripTime(value)\n const date = new Date(value)\n return isNaN(date.getTime()) ? null : stripTime(date)\n}\n\nfunction sortRange(start: Date, end: Date) {\n return start.getTime() <= end.getTime() ? {start, end} : {start: end, end: start}\n}\n\nfunction isBetween(date: Date, start: Date | null, end: Date | null) {\n if (!start || !end) return false\n const time = date.getTime()\n return time > start.getTime() && time < end.getTime()\n}\n\nfunction formatRangeLabel(start: Date | null, end: Date | null, format: string) {\n if (start && end) {\n return `${formatDate(start, format)} - ${formatDate(end, format)}`\n }\n\n if (start) {\n return `${formatDate(start, format)} - ...`\n }\n\n return ''\n}\n\nfunction startOfMonth(date: Date) {\n return new Date(date.getFullYear(), date.getMonth(), 1)\n}\n\nfunction endOfMonth(date: Date) {\n return new Date(date.getFullYear(), date.getMonth() + 1, 0)\n}\n\nfunction daysAgo(days: number): Date {\n const date = stripTime(new Date())\n date.setDate(date.getDate() - (days - 1))\n return date\n}\n\nfunction monthsAgo(months: number): Date {\n const today = stripTime(new Date())\n return new Date(today.getFullYear(), today.getMonth() - months, today.getDate())\n}\n\nfunction getDefaultPresets(texts: ReturnType<typeof useMDateRangePickerTexts>): MDateRangePreset[] {\n const today = stripTime(new Date())\n const previousMonthDate = new Date(today.getFullYear(), today.getMonth() - 1, 1)\n\n return [\n {label: texts.presets.today, value: {start: today, end: today}},\n {label: texts.presets.days2, value: {start: daysAgo(2), end: today}},\n {label: texts.presets.days3, value: {start: daysAgo(3), end: today}},\n {label: texts.presets.days7, value: {start: daysAgo(7), end: today}},\n {label: texts.presets.days14, value: {start: daysAgo(14), end: today}},\n {label: texts.presets.days31, value: {start: daysAgo(31), end: today}},\n {label: texts.presets.thisMonth, value: {start: startOfMonth(today), end: endOfMonth(today)}},\n {\n label: texts.presets.previousMonth,\n value: {start: startOfMonth(previousMonthDate), end: endOfMonth(previousMonthDate)},\n },\n {label: texts.presets.months2, value: {start: monthsAgo(2), end: today}},\n {label: texts.presets.months3, value: {start: monthsAgo(3), end: today}},\n {label: texts.presets.months6, value: {start: monthsAgo(6), end: today}},\n {label: texts.presets.year1, value: {start: monthsAgo(12), end: today}},\n ]\n}\n\nfunction buildCalendarDays(viewDate: Date, firstDayOfWeek: 0 | 1) {\n const year = viewDate.getFullYear()\n const month = viewDate.getMonth()\n const totalDays = daysInMonth(year, month)\n let startDay = firstDayOfMonth(year, month)\n\n if (firstDayOfWeek === 1) {\n startDay = startDay === 0 ? 6 : startDay - 1\n }\n\n const days = [] as Array<{date: Date; currentMonth: boolean}>\n\n const previousMonth = month === 0 ? 11 : month - 1\n const previousYear = month === 0 ? year - 1 : year\n const previousMonthDays = daysInMonth(previousYear, previousMonth)\n\n for (let index = startDay - 1; index >= 0; index -= 1) {\n days.push({date: new Date(previousYear, previousMonth, previousMonthDays - index), currentMonth: false})\n }\n\n for (let day = 1; day <= totalDays; day += 1) {\n days.push({date: new Date(year, month, day), currentMonth: true})\n }\n\n const remaining = 42 - days.length\n const nextMonth = month === 11 ? 0 : month + 1\n const nextYear = month === 11 ? year + 1 : year\n\n for (let day = 1; day <= remaining; day += 1) {\n days.push({date: new Date(nextYear, nextMonth, day), currentMonth: false})\n }\n\n return days\n}\n\n// Render a single control for start and end date selection inside one calendar popover.\nexport function MDateRangePicker({\n value,\n defaultValue,\n onChange,\n format = 'dd.MM.yyyy',\n locale: localeOverride,\n min,\n max,\n disabledDates,\n placeholder,\n disabled = false,\n readOnly = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n inline = false,\n showTodayButton = true,\n presets = false,\n presetsSidebar = false,\n firstDayOfWeek = 1,\n fullWidth = false,\n allowSameDay = true,\n className,\n style,\n}: MDateRangePickerProps) {\n const locale = useDocumentLocale(localeOverride)\n const controlledRange = value\n ? {\n start: toDate(value.start),\n end: toDate(value.end),\n }\n : null\n const [internalRange, setInternalRange] = useState(() => ({\n start: toDate(defaultValue?.start),\n end: toDate(defaultValue?.end),\n }))\n const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n const [open, setOpen] = useState(false)\n const triggerRef = useRef<HTMLDivElement>(null)\n\n const selectedRange = controlledRange ?? internalRange\n const startDate = selectedRange.start\n const endDate = selectedRange.end\n const minDate = toDate(min)\n const maxDate = toDate(max)\n const hasError = error || !!errorText\n const texts = useMDateRangePickerTexts()\n const dayNames = getDayNames(locale, firstDayOfWeek)\n const monthNames = getMonthNames(locale)\n const availablePresets = useMemo(() => {\n if (presets === true || (presetsSidebar && !presets)) {\n return getDefaultPresets(texts)\n }\n\n if (Array.isArray(presets)) {\n return presets\n }\n\n return []\n }, [presets, presetsSidebar, texts])\n\n const [viewDate, setViewDate] = useState(() => {\n const baseDate = startDate ?? new Date()\n return new Date(baseDate.getFullYear(), baseDate.getMonth(), 1)\n })\n\n const startTime = startDate?.getTime() ?? null\n useEffect(() => {\n if (!startTime) return\n const d = new Date(startTime)\n setViewDate(new Date(d.getFullYear(), d.getMonth(), 1))\n }, [startTime])\n\n const isDisabled = useCallback(\n (date: Date): boolean => {\n if (!isDateInRange(date, minDate, maxDate)) return true\n if (Array.isArray(disabledDates)) {\n return disabledDates.some((disabledDate) => isSameDay(disabledDate, date))\n }\n if (typeof disabledDates === 'function') {\n return disabledDates(date)\n }\n return false\n },\n [disabledDates, maxDate, minDate]\n )\n\n const commitRange = useCallback(\n (nextRange: {start: Date | null; end: Date | null}) => {\n if (value === undefined) {\n setInternalRange(nextRange)\n }\n onChange?.(nextRange)\n },\n [onChange, value]\n )\n\n const handleDayClick = useCallback(\n (date: Date) => {\n if (isDisabled(date)) return\n\n if (!startDate || (startDate && endDate)) {\n commitRange({start: date, end: null})\n setHoveredDate(null)\n return\n }\n\n if (!allowSameDay && isSameDay(date, startDate)) {\n return\n }\n\n const orderedRange = sortRange(startDate, date)\n commitRange(orderedRange)\n setHoveredDate(null)\n\n if (!inline) {\n setOpen(false)\n }\n },\n [allowSameDay, commitRange, endDate, inline, isDisabled, startDate]\n )\n\n const handleClear = useCallback(\n (event: React.MouseEvent) => {\n event.stopPropagation()\n commitRange({start: null, end: null})\n setHoveredDate(null)\n },\n [commitRange]\n )\n\n const handleToday = useCallback(() => {\n const today = stripTime(new Date())\n if (isDisabled(today)) return\n commitRange({start: today, end: today})\n setViewDate(new Date(today.getFullYear(), today.getMonth(), 1))\n setHoveredDate(null)\n if (!inline) {\n setOpen(false)\n }\n }, [commitRange, inline, isDisabled])\n\n const handlePresetClick = useCallback(\n (preset: MDateRangePreset) => {\n const start = toDate(preset.value.start)\n const end = toDate(preset.value.end)\n\n if (!start || !end) {\n return\n }\n\n const orderedRange = sortRange(start, end)\n\n if (isDisabled(orderedRange.start) || isDisabled(orderedRange.end)) {\n return\n }\n\n commitRange(orderedRange)\n setViewDate(new Date(orderedRange.start.getFullYear(), orderedRange.start.getMonth(), 1))\n setHoveredDate(null)\n\n if (!inline) {\n setOpen(false)\n }\n },\n [commitRange, inline, isDisabled]\n )\n\n const previewEnd = startDate && !endDate ? hoveredDate : null\n const firstMonth = viewDate\n const secondMonth = addMonths(viewDate, 1)\n const today = stripTime(new Date())\n\n const displayValue = useMemo(() => formatRangeLabel(startDate, endDate, format), [endDate, format, startDate])\n\n const calendarMonths = useMemo(\n () =>\n [firstMonth, secondMonth].map((monthDate) => ({\n monthDate,\n days: buildCalendarDays(monthDate, firstDayOfWeek),\n })),\n [firstDayOfWeek, firstMonth, secondMonth]\n )\n\n const summaryText =\n startDate && endDate\n ? `${formatDate(startDate, format)} - ${formatDate(endDate, format)}`\n : startDate\n ? `${formatDate(startDate, format)} - ...`\n : (placeholder ?? texts.defaultRangePlaceholder)\n\n const showSidebar = presetsSidebar && availablePresets.length > 0\n const showInlinePresets = !presetsSidebar && availablePresets.length > 0\n\n const renderPresetsSidebar = () => (\n <div className=\"presets-sidebar\">\n {availablePresets.map((preset) => (\n <button\n key={preset.label}\n type=\"button\"\n className=\"preset-sidebar-btn\"\n onClick={() => handlePresetClick(preset)}\n >\n {preset.label}\n </button>\n ))}\n </div>\n )\n\n const renderCalendarContent = () => (\n <div className=\"calendar-body\">\n <div className=\"calendar-top\">\n <div className=\"calendar-caption\">\n <span className=\"caption-title\">\n {monthNames[firstMonth.getMonth()]} {firstMonth.getFullYear()}\n </span>\n <span className=\"caption-subtitle\">{texts.rangeSubtitle}</span>\n </div>\n <div className=\"nav-actions\">\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, -1))}\n aria-label={texts.previousMonth}\n >\n <MChevronLeftIcon />\n </button>\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, 1))}\n aria-label={texts.nextMonth}\n >\n <MChevronRightIcon />\n </button>\n </div>\n </div>\n\n {showInlinePresets && (\n <div className=\"presets\">\n {availablePresets.map((preset) => (\n <button\n key={preset.label}\n type=\"button\"\n className=\"preset-btn\"\n onClick={() => handlePresetClick(preset)}\n >\n {preset.label}\n </button>\n ))}\n </div>\n )}\n\n <div className=\"months\">\n {calendarMonths.map(({monthDate, days}) => (\n <div key={monthDate.toISOString()} className=\"month-panel\">\n <div className=\"month-title\">\n {monthNames[monthDate.getMonth()]} {monthDate.getFullYear()}\n </div>\n <div className=\"day-names\">\n {dayNames.map((dayName) => (\n <span key={`${monthDate.toISOString()}-${dayName}`} className=\"day-name\">\n {dayName}\n </span>\n ))}\n </div>\n <div className=\"day-grid\">\n {days.map(({date, currentMonth}, index) => {\n const disabledDay = isDisabled(date)\n const selectedStart = startDate ? isSameDay(date, startDate) : false\n const selectedEnd = endDate ? isSameDay(date, endDate) : false\n const inRange = isBetween(date, startDate, endDate)\n const previewRangeData =\n !endDate && startDate && previewEnd ? sortRange(startDate, previewEnd) : null\n const previewRange = previewRangeData\n ? isBetween(date, previewRangeData.start, previewRangeData.end)\n : false\n const previewEdge = previewRangeData\n ? isSameDay(date, previewRangeData.start) || isSameDay(date, previewRangeData.end)\n : false\n\n return (\n <button\n key={`${monthDate.toISOString()}-${index}`}\n type=\"button\"\n className={cn(\n 'day',\n !currentMonth && 'other-month',\n isSameDay(date, today) && 'today',\n selectedStart && 'range-start selected',\n selectedEnd && 'range-end selected',\n inRange && 'in-range',\n previewRange && !previewEdge && 'preview-range',\n disabledDay && 'disabled'\n )}\n onClick={() => handleDayClick(date)}\n onMouseEnter={() => startDate && !endDate && setHoveredDate(date)}\n onFocus={() => startDate && !endDate && setHoveredDate(date)}\n disabled={disabledDay}\n tabIndex={-1}\n >\n {date.getDate()}\n </button>\n )\n })}\n </div>\n </div>\n ))}\n </div>\n\n <div className=\"footer\">\n <span className=\"summary\">{summaryText}</span>\n <div className=\"footer-actions\">\n {clearable && (startDate || endDate) && (\n <button\n type=\"button\"\n className=\"footer-btn\"\n onClick={(event) => {\n event.preventDefault()\n commitRange({start: null, end: null})\n setHoveredDate(null)\n }}\n >\n {texts.clear}\n </button>\n )}\n {showTodayButton && (\n <button type=\"button\" className=\"footer-btn\" onClick={handleToday}>\n {texts.today}\n </button>\n )}\n </div>\n </div>\n </div>\n )\n\n const renderCalendar = () => (\n <div className={cn('date-range-calendar', showSidebar && 'with-sidebar')}>\n {showSidebar && renderPresetsSidebar()}\n {renderCalendarContent()}\n </div>\n )\n\n if (inline) {\n return (\n <div\n className={cn('date-range-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label className={cn('field-label', hasError && 'error', required && 'required')}>{label}</label>\n )}\n {renderCalendar()}\n </div>\n )\n }\n\n return (\n <div\n className={cn('date-range-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={triggerRef}\n className={cn(\n 'trigger',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={() => !disabled && !readOnly && setOpen(true)}\n >\n <span className=\"icon\">\n <MCalendarIcon />\n </span>\n <input\n type=\"text\"\n className=\"input\"\n value={displayValue}\n placeholder={placeholder ?? texts.defaultRangePlaceholder}\n disabled={disabled}\n readOnly\n id={id}\n aria-invalid={hasError || undefined}\n />\n {clearable && (startDate || endDate) && !disabled && (\n <button\n type=\"button\"\n className=\"clear-btn clear-btn-base\"\n onClick={handleClear}\n tabIndex={-1}\n aria-label={texts.clear}\n >\n <MCloseIcon />\n </button>\n )}\n </div>\n\n {name && startDate && endDate && (\n <input\n type=\"hidden\"\n name={name}\n value={`${startDate.toISOString().split('T')[0]}:${endDate.toISOString().split('T')[0]}`}\n />\n )}\n\n <MPopover\n className={'date-range-picker-popover'}\n style={{'--color-rgb': colorRgbVar(color)} as React.CSSProperties}\n open={open}\n anchorRef={triggerRef}\n onClose={() => {\n setOpen(false)\n setHoveredDate(null)\n }}\n placement=\"bottom-start\"\n >\n {renderCalendar()}\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"bottom-row\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"helper-text\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n"],"mappings":"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"}