@banzamel/mineralui 1.8.0 → 1.9.0

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 (220) hide show
  1. package/README.md +1 -1
  2. package/dist/{MAvatar-BcayQCnp.js → MAvatar-D_dVAPaR.js} +3 -3
  3. package/dist/{MAvatar-BcayQCnp.js.map → MAvatar-D_dVAPaR.js.map} +1 -1
  4. package/dist/{MAvatar-BgevCYi3.cjs → MAvatar-DzZPRbot.cjs} +2 -2
  5. package/dist/{MAvatar-BgevCYi3.cjs.map → MAvatar-DzZPRbot.cjs.map} +1 -1
  6. package/dist/MAvatarStack-CrhkO_SO.js +330 -0
  7. package/dist/MAvatarStack-CrhkO_SO.js.map +1 -0
  8. package/dist/MAvatarStack-DN79aJo1.cjs +2 -0
  9. package/dist/MAvatarStack-DN79aJo1.cjs.map +1 -0
  10. package/dist/{MButton-DZLLrtQb.js → MButton-C1pnL4_j.js} +2 -2
  11. package/dist/{MButton-DZLLrtQb.js.map → MButton-C1pnL4_j.js.map} +1 -1
  12. package/dist/{MButton-8UCydOik.cjs → MButton-DFRHWHzh.cjs} +2 -2
  13. package/dist/{MButton-8UCydOik.cjs.map → MButton-DFRHWHzh.cjs.map} +1 -1
  14. package/dist/{MDataTable-95_Mb6jE.cjs → MDataTable-7nJuwzJR.cjs} +2 -2
  15. package/dist/{MDataTable-95_Mb6jE.cjs.map → MDataTable-7nJuwzJR.cjs.map} +1 -1
  16. package/dist/{MDataTable-DxDS5auV.js → MDataTable-CQt_pINO.js} +4 -4
  17. package/dist/{MDataTable-DxDS5auV.js.map → MDataTable-CQt_pINO.js.map} +1 -1
  18. package/dist/{MDrawer-CXNHYwPO.js → MDrawer-B83--EVv.js} +2 -2
  19. package/dist/{MDrawer-CXNHYwPO.js.map → MDrawer-B83--EVv.js.map} +1 -1
  20. package/dist/{MDrawer-DzqtHVeA.cjs → MDrawer-D6cy9K7J.cjs} +2 -2
  21. package/dist/{MDrawer-DzqtHVeA.cjs.map → MDrawer-D6cy9K7J.cjs.map} +1 -1
  22. package/dist/MGrid-B-fP4GME.cjs +2 -0
  23. package/dist/MGrid-B-fP4GME.cjs.map +1 -0
  24. package/dist/{MGrid-DR0fHItF.js → MGrid-DVluuula.js} +56 -56
  25. package/dist/MGrid-DVluuula.js.map +1 -0
  26. package/dist/{MHeading-MPh8Qm9q.js → MHeading-B7KgSP4T.js} +3 -3
  27. package/dist/{MHeading-MPh8Qm9q.js.map → MHeading-B7KgSP4T.js.map} +1 -1
  28. package/dist/{MHeading-CKe5lcM_.cjs → MHeading-f3hwkW3r.cjs} +2 -2
  29. package/dist/{MHeading-CKe5lcM_.cjs.map → MHeading-f3hwkW3r.cjs.map} +1 -1
  30. package/dist/{MInput-D_zaoWwX.cjs → MInput-BLGduKL_.cjs} +2 -2
  31. package/dist/{MInput-D_zaoWwX.cjs.map → MInput-BLGduKL_.cjs.map} +1 -1
  32. package/dist/{MInput-7i0Dy1t4.js → MInput-IsUELgN2.js} +2 -2
  33. package/dist/{MInput-7i0Dy1t4.js.map → MInput-IsUELgN2.js.map} +1 -1
  34. package/dist/{MInputExpDate-DhO5zN7L.js → MInputExpDate-CeCmw6fj.js} +2 -2
  35. package/dist/{MInputExpDate-DhO5zN7L.js.map → MInputExpDate-CeCmw6fj.js.map} +1 -1
  36. package/dist/{MInputExpDate-DWWwjMYK.cjs → MInputExpDate-DZ8JtSjs.cjs} +2 -2
  37. package/dist/{MInputExpDate-DWWwjMYK.cjs.map → MInputExpDate-DZ8JtSjs.cjs.map} +1 -1
  38. package/dist/{MInputSearch-CmzHPnmC.js → MInputSearch-BBxUF5pw.js} +2 -2
  39. package/dist/{MInputSearch-CmzHPnmC.js.map → MInputSearch-BBxUF5pw.js.map} +1 -1
  40. package/dist/{MInputSearch-DpHSVpmL.cjs → MInputSearch-_7jfFGr1.cjs} +2 -2
  41. package/dist/{MInputSearch-DpHSVpmL.cjs.map → MInputSearch-_7jfFGr1.cjs.map} +1 -1
  42. package/dist/{MLink-rFKN1mcM.js → MLink-Bd8fLH1N.js} +2 -2
  43. package/dist/{MLink-rFKN1mcM.js.map → MLink-Bd8fLH1N.js.map} +1 -1
  44. package/dist/{MLink-B3ImjkJV.cjs → MLink-CRK8YvR4.cjs} +2 -2
  45. package/dist/{MLink-B3ImjkJV.cjs.map → MLink-CRK8YvR4.cjs.map} +1 -1
  46. package/dist/{MModal-DGmeQlWo.js → MModal-DiTjBO8B.js} +2 -2
  47. package/dist/{MModal-DGmeQlWo.js.map → MModal-DiTjBO8B.js.map} +1 -1
  48. package/dist/{MModal-CP0e31pv.cjs → MModal-eJDG6riB.cjs} +2 -2
  49. package/dist/{MModal-CP0e31pv.cjs.map → MModal-eJDG6riB.cjs.map} +1 -1
  50. package/dist/{MPagination-CS62B9kZ.cjs → MPagination-D1hYqLDb.cjs} +2 -2
  51. package/dist/{MPagination-CS62B9kZ.cjs.map → MPagination-D1hYqLDb.cjs.map} +1 -1
  52. package/dist/{MPagination-Dr110are.js → MPagination-DvToi2cs.js} +2 -2
  53. package/dist/{MPagination-Dr110are.js.map → MPagination-DvToi2cs.js.map} +1 -1
  54. package/dist/{MQrCode-B0-Np-N3.cjs → MQrCode-HO2YIC7e.cjs} +2 -2
  55. package/dist/{MQrCode-B0-Np-N3.cjs.map → MQrCode-HO2YIC7e.cjs.map} +1 -1
  56. package/dist/{MQrCode-6ANDcExA.js → MQrCode-Kb997gaE.js} +5 -5
  57. package/dist/{MQrCode-6ANDcExA.js.map → MQrCode-Kb997gaE.js.map} +1 -1
  58. package/dist/{MSkeleton-BvXgnYs_.js → MSkeleton-CVofhuDp.js} +3 -3
  59. package/dist/{MSkeleton-BvXgnYs_.js.map → MSkeleton-CVofhuDp.js.map} +1 -1
  60. package/dist/{MSkeleton-BdwhPx-k.cjs → MSkeleton-CuYA8eN3.cjs} +2 -2
  61. package/dist/{MSkeleton-BdwhPx-k.cjs.map → MSkeleton-CuYA8eN3.cjs.map} +1 -1
  62. package/dist/{MStack-DFIc3S4_.js → MStack-C4Eocfb5.js} +2 -2
  63. package/dist/{MStack-DFIc3S4_.js.map → MStack-C4Eocfb5.js.map} +1 -1
  64. package/dist/{MStack-ByFYGSsy.cjs → MStack-w8XcuIJK.cjs} +2 -2
  65. package/dist/{MStack-ByFYGSsy.cjs.map → MStack-w8XcuIJK.cjs.map} +1 -1
  66. package/dist/{MSubText-BFdfBlpS.js → MSubText-C-N15d4Z.js} +3 -3
  67. package/dist/{MSubText-BFdfBlpS.js.map → MSubText-C-N15d4Z.js.map} +1 -1
  68. package/dist/{MSubText-1ilKSz8e.cjs → MSubText-CIMKPb8o.cjs} +2 -2
  69. package/dist/{MSubText-1ilKSz8e.cjs.map → MSubText-CIMKPb8o.cjs.map} +1 -1
  70. package/dist/{MSurface-CpAuwpHv.cjs → MSurface-KvAS2hkl.cjs} +2 -2
  71. package/dist/{MSurface-CpAuwpHv.cjs.map → MSurface-KvAS2hkl.cjs.map} +1 -1
  72. package/dist/{MSurface-CmVIQC1A.js → MSurface-odrvQXkb.js} +2 -2
  73. package/dist/{MSurface-CmVIQC1A.js.map → MSurface-odrvQXkb.js.map} +1 -1
  74. package/dist/{MTag-DwQ-j1sV.cjs → MTag-DZqV4S13.cjs} +2 -2
  75. package/dist/{MTag-DwQ-j1sV.cjs.map → MTag-DZqV4S13.cjs.map} +1 -1
  76. package/dist/{MTag-C4SUJly2.js → MTag-DgB6ukFJ.js} +3 -3
  77. package/dist/{MTag-C4SUJly2.js.map → MTag-DgB6ukFJ.js.map} +1 -1
  78. package/dist/{MText-D0fI_D_Q.cjs → MText-BHbI7KJO.cjs} +2 -2
  79. package/dist/{MText-D0fI_D_Q.cjs.map → MText-BHbI7KJO.cjs.map} +1 -1
  80. package/dist/{MText-DcB1GAt-.js → MText-CL-LPcXi.js} +2 -2
  81. package/dist/{MText-DcB1GAt-.js.map → MText-CL-LPcXi.js.map} +1 -1
  82. package/dist/{cards-D7oHIHmU.js → cards-C50fpYud.js} +20 -16
  83. package/dist/cards-C50fpYud.js.map +1 -0
  84. package/dist/cards-Ci1FoV9C.cjs +2 -0
  85. package/dist/cards-Ci1FoV9C.cjs.map +1 -0
  86. package/dist/cards.cjs +1 -1
  87. package/dist/cards.js +3 -3
  88. package/dist/components/cards/MCardGrid/MCardGrid.types.d.ts +40 -1
  89. package/dist/components/cards/MCardGrid/index.d.ts +1 -1
  90. package/dist/components/cards/MStatCard/MStatCard.d.ts +0 -1
  91. package/dist/components/cards/MStatCard/MStatCard.types.d.ts +0 -2
  92. package/dist/components/cards/MStatCard/index.d.ts +2 -2
  93. package/dist/components/cards/index.d.ts +3 -3
  94. package/dist/components/data/MTimelineCalendar/DayStrip.d.ts +11 -0
  95. package/dist/components/data/MTimelineCalendar/EventPopover.d.ts +18 -0
  96. package/dist/components/data/MTimelineCalendar/MTimelineCalendar.d.ts +2 -0
  97. package/dist/components/data/MTimelineCalendar/MTimelineCalendar.helpers.d.ts +55 -0
  98. package/dist/components/data/MTimelineCalendar/MTimelineCalendar.types.d.ts +89 -0
  99. package/dist/components/data/MTimelineCalendar/index.d.ts +2 -0
  100. package/dist/components/data/index.d.ts +4 -0
  101. package/dist/components/layout/MGrid/MGrid.d.ts +1 -1
  102. package/dist/components/layout/MNavbar/MNavbar.d.ts +1 -1
  103. package/dist/components/layout/MNavbar/MNavbar.types.d.ts +19 -0
  104. package/dist/components/layout/index.d.ts +0 -4
  105. package/dist/components/media/MAvatarStack/MAvatarStack.d.ts +1 -1
  106. package/dist/components/media/MAvatarStack/MAvatarStack.types.d.ts +14 -1
  107. package/dist/components/typography/MHeading/MHeading.d.ts +1 -562
  108. package/dist/{controls-BfV0vxeJ.cjs → controls-CYQxPd4U.cjs} +2 -2
  109. package/dist/{controls-BfV0vxeJ.cjs.map → controls-CYQxPd4U.cjs.map} +1 -1
  110. package/dist/{controls-BczTk73I.js → controls-CcbEqqWo.js} +3 -3
  111. package/dist/{controls-BczTk73I.js.map → controls-CcbEqqWo.js.map} +1 -1
  112. package/dist/controls.cjs +1 -1
  113. package/dist/controls.js +2 -2
  114. package/dist/data-DtShJEic.cjs +2 -0
  115. package/dist/data-DtShJEic.cjs.map +1 -0
  116. package/dist/data-RXuvb9VI.js +3454 -0
  117. package/dist/data-RXuvb9VI.js.map +1 -0
  118. package/dist/data.cjs +1 -1
  119. package/dist/data.js +3 -3
  120. package/dist/{display-Cw3-bTsm.cjs → display-96-TEGmZ.cjs} +2 -2
  121. package/dist/{display-Cw3-bTsm.cjs.map → display-96-TEGmZ.cjs.map} +1 -1
  122. package/dist/{display-DyC7084n.js → display-C7YRf4Ze.js} +5 -5
  123. package/dist/{display-DyC7084n.js.map → display-C7YRf4Ze.js.map} +1 -1
  124. package/dist/display.cjs +1 -1
  125. package/dist/display.js +2 -2
  126. package/dist/{dropdowns-6eO0b6eI.cjs → dropdowns-Ce3Pb2JM.cjs} +2 -2
  127. package/dist/{dropdowns-6eO0b6eI.cjs.map → dropdowns-Ce3Pb2JM.cjs.map} +1 -1
  128. package/dist/{dropdowns-zXgrjNXZ.js → dropdowns-DfXhVlWQ.js} +4 -4
  129. package/dist/{dropdowns-zXgrjNXZ.js.map → dropdowns-DfXhVlWQ.js.map} +1 -1
  130. package/dist/dropdowns.cjs +1 -1
  131. package/dist/dropdowns.js +1 -1
  132. package/dist/{feedback-DfBjzJAw.js → feedback-DGT28-Zx.js} +11 -11
  133. package/dist/{feedback-DfBjzJAw.js.map → feedback-DGT28-Zx.js.map} +1 -1
  134. package/dist/{feedback-BvRmoSzV.cjs → feedback-Dr7G3K_R.cjs} +2 -2
  135. package/dist/{feedback-BvRmoSzV.cjs.map → feedback-Dr7G3K_R.cjs.map} +1 -1
  136. package/dist/feedback.cjs +1 -1
  137. package/dist/feedback.js +4 -4
  138. package/dist/index.cjs +1 -1
  139. package/dist/index.cjs.map +1 -1
  140. package/dist/index.d.ts +2 -4
  141. package/dist/index.js +52 -52
  142. package/dist/index.js.map +1 -1
  143. package/dist/{inputs-C1I1SLZ8.cjs → inputs-BJMmyEdL.cjs} +2 -2
  144. package/dist/{inputs-C1I1SLZ8.cjs.map → inputs-BJMmyEdL.cjs.map} +1 -1
  145. package/dist/{inputs-Dy1WurNK.js → inputs-CNPeF6gb.js} +3 -3
  146. package/dist/{inputs-Dy1WurNK.js.map → inputs-CNPeF6gb.js.map} +1 -1
  147. package/dist/inputs.cjs +1 -1
  148. package/dist/inputs.js +4 -4
  149. package/dist/layout-dUrQeGc2.cjs +2 -0
  150. package/dist/layout-dUrQeGc2.cjs.map +1 -0
  151. package/dist/{layout-D1-mF4xn.js → layout-tIq6BGQK.js} +240 -301
  152. package/dist/layout-tIq6BGQK.js.map +1 -0
  153. package/dist/layout.cjs +1 -1
  154. package/dist/layout.js +8 -8
  155. package/dist/licensing-9sZ43Cif.cjs +2 -0
  156. package/dist/licensing-9sZ43Cif.cjs.map +1 -0
  157. package/dist/{licensing-ZFCUU4Z8.js → licensing-Bq78CLC_.js} +5 -5
  158. package/dist/licensing-Bq78CLC_.js.map +1 -0
  159. package/dist/media-BySr5LGc.cjs +2 -0
  160. package/dist/media-BySr5LGc.cjs.map +1 -0
  161. package/dist/media-IQ4iYTs-.js +391 -0
  162. package/dist/media-IQ4iYTs-.js.map +1 -0
  163. package/dist/media.cjs +1 -1
  164. package/dist/media.js +4 -4
  165. package/dist/{overlays-B0khU6Wb.js → overlays-BabXGLEM.js} +7 -7
  166. package/dist/{overlays-B0khU6Wb.js.map → overlays-BabXGLEM.js.map} +1 -1
  167. package/dist/{overlays-VAh5PqAe.cjs → overlays-CTR3n21O.cjs} +2 -2
  168. package/dist/{overlays-VAh5PqAe.cjs.map → overlays-CTR3n21O.cjs.map} +1 -1
  169. package/dist/overlays.cjs +1 -1
  170. package/dist/overlays.js +3 -3
  171. package/dist/style-runtime.cjs +1 -1
  172. package/dist/style-runtime.js +1 -1
  173. package/dist/styles.css +1 -1
  174. package/dist/theme/MTheme.types.d.ts +5 -0
  175. package/dist/theme/responsive.d.ts +1 -10
  176. package/dist/{theme-D_f-cmSA.js → theme-DAOU1aPs.js} +4 -3
  177. package/dist/{theme-D_f-cmSA.js.map → theme-DAOU1aPs.js.map} +1 -1
  178. package/dist/{theme-BaroO-OB.cjs → theme-DsTDooyX.cjs} +2 -2
  179. package/dist/{theme-BaroO-OB.cjs.map → theme-DsTDooyX.cjs.map} +1 -1
  180. package/dist/theme.cjs +1 -1
  181. package/dist/theme.js +1 -1
  182. package/dist/{typography-CldwDFse.js → typography-CAW17MDj.js} +2 -2
  183. package/dist/{typography-CldwDFse.js.map → typography-CAW17MDj.js.map} +1 -1
  184. package/dist/{typography-D7COsP1O.cjs → typography-sbLuXqFn.cjs} +2 -2
  185. package/dist/{typography-D7COsP1O.cjs.map → typography-sbLuXqFn.cjs.map} +1 -1
  186. package/dist/typography.cjs +1 -1
  187. package/dist/typography.js +5 -5
  188. package/dist/utils/commandPaletteFromNavGroups.d.ts +74 -0
  189. package/dist/utils/licensing.d.ts +4 -4
  190. package/dist/utils.cjs +1 -1
  191. package/dist/utils.js +1 -1
  192. package/package.json +1 -1
  193. package/dist/MGrid-C4kPZDSa.cjs +0 -2
  194. package/dist/MGrid-C4kPZDSa.cjs.map +0 -1
  195. package/dist/MGrid-DR0fHItF.js.map +0 -1
  196. package/dist/MImage-BZ6SrSao.cjs +0 -2
  197. package/dist/MImage-BZ6SrSao.cjs.map +0 -1
  198. package/dist/MImage-Btx_7g2Z.js +0 -257
  199. package/dist/MImage-Btx_7g2Z.js.map +0 -1
  200. package/dist/cards-B9g6Lf1n.cjs +0 -2
  201. package/dist/cards-B9g6Lf1n.cjs.map +0 -1
  202. package/dist/cards-D7oHIHmU.js.map +0 -1
  203. package/dist/components/layout/MAppMenu/MAppMenu.d.ts +0 -2
  204. package/dist/components/layout/MAppMenu/MAppMenu.types.d.ts +0 -63
  205. package/dist/components/layout/MAppMenu/index.d.ts +0 -2
  206. package/dist/data-7kG1MC1Z.cjs +0 -2
  207. package/dist/data-7kG1MC1Z.cjs.map +0 -1
  208. package/dist/data-z3e8XTSt.js +0 -2692
  209. package/dist/data-z3e8XTSt.js.map +0 -1
  210. package/dist/layout-D1-mF4xn.js.map +0 -1
  211. package/dist/layout-Op6GWQ8w.cjs +0 -2
  212. package/dist/layout-Op6GWQ8w.cjs.map +0 -1
  213. package/dist/licensing-DmF0ObpG.cjs +0 -2
  214. package/dist/licensing-DmF0ObpG.cjs.map +0 -1
  215. package/dist/licensing-ZFCUU4Z8.js.map +0 -1
  216. package/dist/media-DbToUupt.cjs +0 -2
  217. package/dist/media-DbToUupt.cjs.map +0 -1
  218. package/dist/media-DdChr0Cw.js +0 -431
  219. package/dist/media-DdChr0Cw.js.map +0 -1
  220. package/dist/utils/commandPaletteFromAppMenu.d.ts +0 -42
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cards-C50fpYud.js","names":[],"sources":["../src/components/cards/shared/MCardColor.utils.tsx","../src/components/cards/MCardActionArea/MCardActionArea.tsx","../src/components/cards/MCardPayment/MCardPayment.tsx","../src/components/cards/MCardPaymentMethod/MCardPaymentMethod.tsx","../src/utils/socialPlatforms.tsx","../src/components/cards/MCardBusiness/MCardBusiness.tsx","../src/components/cards/ServiceCardsShared/ServiceCardsShared.tsx","../src/components/cards/MCardOffer/MCardOffer.tsx","../src/components/cards/MCardCourse/MCardCourse.tsx","../src/components/cards/MCardTile/MCardTile.tsx","../src/components/cards/MCardProduct/MCardProduct.tsx","../src/components/cards/MCardEvent/MCardEvent.tsx","../src/components/cards/MCardWidget/MCardWidget.tsx","../src/components/cards/MStatCard/MStatCard.tsx","../src/components/cards/MCardGrid/MCardGrid.tsx","../src/components/cards/MCardFinance/MCardFinance.tsx","../src/components/cards/MCardDaySchedule/MCardDaySchedule.tsx","../src/components/cards/MCardDocumentTree/MCardDocumentTree.tsx"],"sourcesContent":["import {Children, cloneElement, isValidElement} from 'react'\nimport type {ReactElement, ReactNode} from 'react'\nimport type {MColor} from '../../../theme'\nimport {MButton} from '../../controls'\n\nfunction getElementTypeName(type: unknown) {\n if (typeof type === 'string') {\n return type\n }\n\n if (typeof type === 'function') {\n const component = type as {displayName?: string; name?: string}\n\n return component.displayName ?? component.name ?? ''\n }\n\n if (typeof type === 'object' && type !== null) {\n const maybeType = type as {\n displayName?: string\n render?: {displayName?: string; name?: string}\n }\n\n return maybeType.displayName ?? maybeType.render?.displayName ?? maybeType.render?.name ?? ''\n }\n\n return ''\n}\n\nfunction shouldInheritColor(element: ReactElement) {\n const props = element.props as {color?: unknown}\n\n if (props.color !== undefined) {\n return false\n }\n\n if (element.type === MButton) {\n return true\n }\n\n const typeName = getElementTypeName(element.type)\n\n return typeName.startsWith('M') && typeName.endsWith('Icon')\n}\n\nexport function tintCardChildren(children: ReactNode, color?: MColor): ReactNode {\n if (!color) {\n return children\n }\n\n return Children.map(children, (child) => {\n if (!isValidElement(child)) {\n return child\n }\n\n const element = child as ReactElement<{children?: ReactNode}>\n const props = element.props\n const tintedChildren = props.children ? tintCardChildren(props.children, color) : props.children\n const nextProps: Record<string, unknown> = {}\n\n if (tintedChildren !== props.children) {\n nextProps.children = tintedChildren\n }\n\n if (shouldInheritColor(element)) {\n nextProps.color = color\n }\n\n if (!Object.keys(nextProps).length) {\n return element\n }\n\n return cloneElement(element, nextProps)\n })\n}\n","import type {PointerEvent} from 'react'\nimport type {MCardActionAreaProps} from './MCardActionArea.types'\nimport {cn} from '../../../utils/cn'\nimport {useInteractionEffect} from '../../../utils/useInteractionEffect'\nimport {resolveMCardAction, tintCardChildren} from '../shared'\nimport './MCardActionArea.css'\n\nexport function MCardActionArea({\n component,\n to,\n href,\n target,\n rel,\n color,\n interactive = true,\n clickEffect,\n rippleColor,\n className,\n children,\n onPointerDown,\n type,\n ...rest\n}: MCardActionAreaProps) {\n const {\n component: Component,\n href: resolvedHref,\n to: resolvedTo,\n isInteractive,\n } = resolveMCardAction({\n component,\n href,\n to,\n interactive,\n hasClickHandler: Boolean(rest.onClick),\n hasPointerHandler: Boolean(onPointerDown),\n fallbackComponent: 'button',\n })\n const {effectClassName, effectLayer, handlePointerDown} = useInteractionEffect<HTMLElement>({\n effect: clickEffect ?? (isInteractive ? 'ripple' : 'none'),\n disabled: !isInteractive,\n color: rippleColor,\n })\n\n return (\n <Component\n href={Component === 'a' || component ? resolvedHref : undefined}\n to={resolvedTo}\n target={target}\n rel={rel}\n type={Component === 'button' ? (type ?? 'button') : undefined}\n className={cn(\n 'card-action-area',\n color && `color-${color}`,\n isInteractive && 'interactive',\n effectClassName,\n className\n )}\n onPointerDown={(event: PointerEvent<HTMLElement>) => {\n handlePointerDown(event)\n onPointerDown?.(event as PointerEvent<HTMLButtonElement>)\n }}\n {...rest}\n >\n {effectLayer}\n <span className=\"card-action-area-content\">{tintCardChildren(children, color)}</span>\n </Component>\n )\n}\n","import type {PointerEvent} from 'react'\nimport type {MCardPaymentProps} from './MCardPayment.types'\nimport {cn} from '../../../utils/cn'\nimport {creditCardBrands, detectCardBrand} from '../../../utils/creditCards'\nimport {useInteractionEffect} from '../../../utils/useInteractionEffect'\nimport {resolveMCardAction} from '../shared'\nimport './MCardPayment.css'\n\nfunction maskNumber(raw: string): string {\n const digits = raw.replace(/\\D/g, '')\n if (digits.length <= 4) return digits\n const last4 = digits.slice(-4)\n return `\\u2022\\u2022\\u2022\\u2022 \\u2022\\u2022\\u2022\\u2022 \\u2022\\u2022\\u2022\\u2022 ${last4}`\n}\n\n// Display-only payment card with balance, masked number, holder name and brand badge.\nexport function MCardPayment({\n component,\n to,\n href,\n target,\n rel,\n holder,\n number,\n expiry,\n brand,\n brandIcon,\n balance,\n balanceLabel = 'Current balance',\n color,\n interactive = false,\n clickEffect,\n rippleColor,\n className,\n onPointerDown,\n ...rest\n}: MCardPaymentProps) {\n const detectedDetails = detectCardBrand(number)\n const detected = brand ?? detectedDetails.brand\n const brandDetails = creditCardBrands.find((rule) => rule.brand === detected) ?? detectedDetails\n const masked = maskNumber(number)\n const brandLabel = brandDetails.iconLabel\n const {\n component: Component,\n href: resolvedHref,\n to: resolvedTo,\n isInteractive,\n } = resolveMCardAction({\n component,\n href,\n to,\n interactive,\n hasClickHandler: Boolean(rest.onClick),\n hasPointerHandler: Boolean(onPointerDown),\n })\n const {effectClassName, effectLayer, handlePointerDown} = useInteractionEffect<HTMLDivElement>({\n effect: clickEffect ?? (isInteractive ? 'ripple' : 'none'),\n disabled: !isInteractive,\n color: rippleColor,\n })\n\n return (\n <Component\n href={Component === 'a' || component ? resolvedHref : undefined}\n to={resolvedTo}\n target={target}\n rel={rel}\n className={cn(\n 'card-payment',\n color || 'primary',\n isInteractive && 'interactive',\n effectClassName,\n className\n )}\n onPointerDown={(event: PointerEvent<HTMLDivElement>) => {\n handlePointerDown(event)\n onPointerDown?.(event)\n }}\n {...rest}\n >\n {effectLayer}\n {balance !== undefined && (\n <div>\n <p className=\"cp-balance-label\">{balanceLabel}</p>\n <p className=\"cp-balance\">{balance}</p>\n </div>\n )}\n\n <div className=\"cp-row\">\n <span className={cn('cp-brand', !brandIcon && detected)}>{brandIcon ?? brandLabel}</span>\n <span className=\"cp-number\">{masked}</span>\n </div>\n\n <div className=\"cp-details\">\n <div>\n <p className=\"cp-field-label\">MCard holder</p>\n <p className=\"cp-field-value\">{holder}</p>\n </div>\n <div>\n <p className=\"cp-field-label\">Expiration date</p>\n <p className=\"cp-field-value\">{expiry}</p>\n </div>\n </div>\n </Component>\n )\n}\n","import type {MCardPaymentMethodProps} from './MCardPaymentMethod.types'\nimport {cn} from '../../../utils/cn'\nimport {creditCardBrands} from '../../../utils/creditCards'\nimport {MArrowRightIcon} from '../../../icons'\nimport {MBadge} from '../../feedback'\nimport {MInline} from '../../layout'\nimport {MLink, MText} from '../../typography'\nimport {MInputExpDate} from '../../inputs/MInputExpDate'\nimport {MInputCVC} from '../../inputs/MInputCVC'\nimport './MCardPaymentMethod.css'\n\nfunction resolveBrandLabel(brand: NonNullable<MCardPaymentMethodProps['brand']>) {\n return creditCardBrands.find((item) => item.brand === brand)?.iconLabel ?? 'CARD'\n}\n\nexport function MCardPaymentMethod({\n title = 'Your payment methods',\n actionLabel = 'Change',\n actionHref = '#',\n onAction,\n brand = 'visa',\n brandIcon,\n last4,\n badgeLabel,\n summary,\n helperText = 'All fields are required, unless stated otherwise.',\n expiryLabel = 'Expiration date',\n cvcLabel = 'Security code',\n expiryProps,\n cvcProps,\n color,\n className,\n ...rest\n}: MCardPaymentMethodProps) {\n const expirySummary = expiryProps?.value ?? expiryProps?.defaultValue\n const resolvedBadgeLabel = badgeLabel === undefined ? 'Default' : badgeLabel\n const derivedSummary = expirySummary\n ? `Credit card - Expiration date ${String(expirySummary).replace('/', '.')}`\n : 'Credit card'\n const resolvedSummary = summary === undefined ? derivedSummary : summary\n const brandLabel = resolveBrandLabel(brand)\n const resolvedExpiryProps = {\n clearable: true,\n ...expiryProps,\n }\n\n return (\n <div className={cn('card-payment-method', color || 'primary', className)} {...rest}>\n <div className={'cpm-header'}>\n <h3 className={'cpm-title'}>{title}</h3>\n <MLink\n href={actionHref}\n tone={'accent'}\n underline={'none'}\n className={'cpm-action'}\n onClick={(event) => {\n if (onAction) {\n event.preventDefault()\n onAction()\n }\n }}\n >\n {actionLabel}\n <MArrowRightIcon />\n </MLink>\n </div>\n\n <div className={'cpm-surface'}>\n <div className={'cpm-method'}>\n <MInline align={'center'} className={'cpm-method-row'}>\n <span className={cn('cpm-brand', !brandIcon && brand)}>{brandIcon ?? brandLabel}</span>\n <span className={'cpm-last4'}>{`\\u2022\\u2022\\u2022\\u2022 ${last4}`}</span>\n {resolvedBadgeLabel && <MBadge color={'info'}>{resolvedBadgeLabel}</MBadge>}\n </MInline>\n {resolvedSummary && (\n <MText tone={'muted'} className={'cpm-summary'}>\n {resolvedSummary}\n </MText>\n )}\n </div>\n\n {helperText && (\n <MText tone={'muted'} size={'sm'} className={'cpm-helper'}>\n {helperText}\n </MText>\n )}\n\n <div className={'cpm-fields'}>\n <MInputExpDate label={expiryLabel} placeholder={'MM/YYYY'} fullWidth {...resolvedExpiryProps} />\n <MInputCVC label={cvcLabel} placeholder={'123'} fullWidth {...cvcProps} />\n </div>\n </div>\n </div>\n )\n}\n","import type {ComponentType} from 'react'\nimport type {MIconProps} from '../icons'\nimport {\n MAppleColorIcon,\n MAppleIcon,\n MDiscordColorIcon,\n MDiscordIcon,\n MFacebookColorIcon,\n MFacebookIcon,\n MFigmaColorIcon,\n MFigmaIcon,\n MGitHubColorIcon,\n MGitHubIcon,\n MGoogleColorIcon,\n MGoogleIcon,\n MInstagramColorIcon,\n MInstagramIcon,\n MLinkedInColorIcon,\n MLinkedInIcon,\n MPinterestColorIcon,\n MPinterestIcon,\n MSlackColorIcon,\n MSlackIcon,\n MSpotifyColorIcon,\n MSpotifyIcon,\n MTumblrColorIcon,\n MTumblrIcon,\n MVimeoColorIcon,\n MVimeoIcon,\n MVkColorIcon,\n MVkIcon,\n MXColorIcon,\n MXIcon,\n MYouTubeColorIcon,\n MYouTubeIcon,\n} from '../icons'\n\nexport type MSocialPlatform =\n | 'apple'\n | 'discord'\n | 'facebook'\n | 'figma'\n | 'github'\n | 'google'\n | 'instagram'\n | 'linkedin'\n | 'pinterest'\n | 'slack'\n | 'spotify'\n | 'tumblr'\n | 'vimeo'\n | 'vk'\n | 'twitter'\n | 'x'\n | 'youtube'\n | (string & {})\n\ntype SocialEntry = {\n label: string\n icon: ComponentType<MIconProps>\n colorIcon: ComponentType<MIconProps>\n rgb: string\n}\n\nconst socialMap: Record<string, SocialEntry> = {\n apple: {label: 'Apple', icon: MAppleIcon, colorIcon: MAppleColorIcon, rgb: '24, 24, 27'},\n discord: {label: 'Discord', icon: MDiscordIcon, colorIcon: MDiscordColorIcon, rgb: '88, 101, 242'},\n facebook: {label: 'Facebook', icon: MFacebookIcon, colorIcon: MFacebookColorIcon, rgb: '24, 119, 242'},\n figma: {label: 'Figma', icon: MFigmaIcon, colorIcon: MFigmaColorIcon, rgb: '162, 89, 255'},\n github: {label: 'GitHub', icon: MGitHubIcon, colorIcon: MGitHubColorIcon, rgb: '24, 23, 23'},\n google: {label: 'Google', icon: MGoogleIcon, colorIcon: MGoogleColorIcon, rgb: '66, 133, 244'},\n instagram: {label: 'Instagram', icon: MInstagramIcon, colorIcon: MInstagramColorIcon, rgb: '225, 48, 108'},\n linkedin: {label: 'LinkedIn', icon: MLinkedInIcon, colorIcon: MLinkedInColorIcon, rgb: '10, 102, 194'},\n pinterest: {label: 'Pinterest', icon: MPinterestIcon, colorIcon: MPinterestColorIcon, rgb: '230, 0, 35'},\n slack: {label: 'Slack', icon: MSlackIcon, colorIcon: MSlackColorIcon, rgb: '74, 21, 75'},\n spotify: {label: 'Spotify', icon: MSpotifyIcon, colorIcon: MSpotifyColorIcon, rgb: '30, 215, 96'},\n tumblr: {label: 'Tumblr', icon: MTumblrIcon, colorIcon: MTumblrColorIcon, rgb: '0, 25, 53'},\n vimeo: {label: 'Vimeo', icon: MVimeoIcon, colorIcon: MVimeoColorIcon, rgb: '26, 183, 234'},\n vk: {label: 'VK', icon: MVkIcon, colorIcon: MVkColorIcon, rgb: '0, 119, 255'},\n x: {label: 'X', icon: MXIcon, colorIcon: MXColorIcon, rgb: '17, 17, 17'},\n youtube: {label: 'YouTube', icon: MYouTubeIcon, colorIcon: MYouTubeColorIcon, rgb: '255, 0, 0'},\n}\n\nexport function normalizeSocialPlatform(platform: string) {\n const normalized = platform\n .trim()\n .toLowerCase()\n .replace(/[\\s._-]+/g, '')\n\n if (normalized === 'twitter') {\n return 'x'\n }\n\n if (normalized === 'vkontakte') {\n return 'vk'\n }\n\n return normalized\n}\n\nexport function getSocialLabel(platform: MSocialPlatform) {\n const normalized = normalizeSocialPlatform(platform)\n return socialMap[normalized]?.label ?? platform\n}\n\nexport function getSocialIconComponent(platform: MSocialPlatform, brand = false) {\n const normalized = normalizeSocialPlatform(platform)\n const entry = socialMap[normalized]\n\n if (!entry) {\n return null\n }\n\n return brand ? entry.colorIcon : entry.icon\n}\n\nexport function getSocialBrandRgb(platform: MSocialPlatform) {\n const normalized = normalizeSocialPlatform(platform)\n return socialMap[normalized]?.rgb ?? '37, 99, 235'\n}\n","import type {MCardBusinessProps} from './MCardBusiness.types'\nimport {cn} from '../../../utils/cn'\nimport {MQrCode} from '../../display'\nimport {MAvatar} from '../../media'\nimport {MGlobeIcon, MMailIcon, MPhoneIcon, MPinIcon} from '../../../icons'\nimport {getSocialIconComponent, getSocialLabel} from '../../../utils/socialPlatforms'\nimport './MCardBusiness.css'\n\n// Join available address fields into one readable line.\nfunction formatAddress(address: MCardBusinessProps['address']): string | null {\n if (!address) return null\n\n return [address.street, [address.zip, address.city].filter(Boolean).join(' '), address.country]\n .filter(Boolean)\n .join(', ')\n}\n\n// Render a compact business card for a person or a company profile.\nexport function MCardBusiness({\n variant = 'user',\n name,\n title,\n avatar,\n address,\n contact,\n socials,\n online,\n lastActive,\n qrCode,\n qrValue,\n qrStatus,\n qrStatusLabel,\n color = 'primary',\n className,\n ...rest\n}: MCardBusinessProps) {\n const addr = formatAddress(address)\n\n return (\n <div className={cn('card-business', variant, `color-${color}`, className)} {...rest}>\n <div className=\"cb-header\">\n <div className=\"cb-avatar-wrap\">\n <MAvatar\n src={avatar}\n alt={name}\n name={name}\n size={56}\n shape={variant === 'company' ? 'rounded' : 'circle'}\n color={color}\n badge={online !== undefined ? true : undefined}\n badgeColor={online === undefined ? undefined : online ? 'success' : 'error'}\n badgePulsing={Boolean(online)}\n className={cn('cb-avatar', variant)}\n />\n </div>\n\n <div className=\"cb-info\">\n <h3 className=\"cb-name\">{name}</h3>\n {title && <p className=\"cb-title\">{title}</p>}\n {lastActive && <p className=\"cb-last-active\">{lastActive}</p>}\n </div>\n\n {(qrValue || qrCode) && (\n <div className=\"cb-qr\">\n {qrValue ? (\n <MQrCode\n value={qrValue}\n size={56}\n padding={3}\n status={qrStatus}\n statusLabel={qrStatusLabel}\n className=\"cb-qr-code\"\n />\n ) : (\n <img src={qrCode} alt=\"QR\" className=\"cb-qr-img\" />\n )}\n </div>\n )}\n </div>\n\n {(contact || addr) && (\n <div className=\"cb-details\">\n {contact?.email && (\n <div className=\"cb-detail\">\n <span className=\"cb-detail-icon\">\n <MMailIcon />\n </span>\n <a href={`mailto:${contact.email}`} className=\"cb-detail-value\">\n {contact.email}\n </a>\n </div>\n )}\n {contact?.phone && (\n <div className=\"cb-detail\">\n <span className=\"cb-detail-icon\">\n <MPhoneIcon />\n </span>\n <a href={`tel:${contact.phone}`} className=\"cb-detail-value\">\n {contact.phone}\n </a>\n </div>\n )}\n {contact?.website && (\n <div className=\"cb-detail\">\n <span className=\"cb-detail-icon\">\n <MGlobeIcon />\n </span>\n <a\n href={contact.website}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"cb-detail-value\"\n >\n {contact.website.replace(/^https?:\\/\\//, '')}\n </a>\n </div>\n )}\n {addr && (\n <div className=\"cb-detail\">\n <span className=\"cb-detail-icon\">\n <MPinIcon />\n </span>\n <span className=\"cb-detail-value\">{addr}</span>\n </div>\n )}\n </div>\n )}\n\n {socials && socials.length > 0 && (\n <div className=\"cb-socials\">\n {socials.map((item) =>\n (() => {\n const Icon = getSocialIconComponent(item.platform, true)\n\n return (\n <a\n key={item.platform}\n href={item.url}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"cb-social\"\n title={getSocialLabel(item.platform)}\n aria-label={getSocialLabel(item.platform)}\n >\n {item.icon ??\n (Icon ? <Icon /> : <span className=\"cb-social-text\">{item.platform}</span>)}\n </a>\n )\n })()\n )}\n </div>\n )}\n </div>\n )\n}\n","import {useEffect, useState} from 'react'\nimport type {SharedServiceCardProps} from './ServiceCardsShared.types'\nimport {cn} from '../../../utils/cn'\nimport {MClockIcon, MEllipsisVerticalIcon, MHeartFillIcon, MHeartIcon, MMinusIcon, MPlusIcon} from '../../../icons'\nimport {MButton} from '../../controls'\nimport {MBadge} from '../../feedback'\nimport {MAvatar} from '../../media'\nimport {MRating} from '../../display'\nimport {MDropdownItem, MDropdownMenu} from '../../overlays'\nimport './ServiceCardsShared.css'\n\nexport function SharedServiceCard({\n variant,\n title,\n description,\n price,\n currency = 'PLN',\n duration,\n available,\n image,\n gallery,\n galleryAutoPlay = false,\n rating,\n reviewCount,\n favorite,\n onFavorite,\n menuItems,\n onAddToCart,\n actionLabel,\n icon,\n color = 'primary',\n leader,\n participants,\n maxParticipants,\n quantity: controlledQty,\n onQuantityChange,\n date,\n location,\n status,\n className,\n ...rest\n}: SharedServiceCardProps) {\n const [galleryIdx, setGalleryIdx] = useState(0)\n const [isGalleryTransitioning, setIsGalleryTransitioning] = useState(false)\n const [internalQty, setInternalQty] = useState(1)\n\n const qty = controlledQty ?? internalQty\n const images = gallery && gallery.length > 0 ? gallery : image ? [image] : []\n\n useEffect(() => {\n if (galleryIdx >= images.length) {\n setGalleryIdx(0)\n }\n }, [galleryIdx, images.length])\n\n useEffect(() => {\n if (!isGalleryTransitioning) {\n return\n }\n\n const transitionId = window.setTimeout(() => {\n setIsGalleryTransitioning(false)\n }, 220)\n\n return () => window.clearTimeout(transitionId)\n }, [galleryIdx, isGalleryTransitioning])\n\n function changeGallery(nextIdx: number) {\n if (nextIdx === galleryIdx || nextIdx < 0 || nextIdx >= images.length) {\n return\n }\n\n if (images.length > 1) {\n setIsGalleryTransitioning(true)\n }\n\n setGalleryIdx(nextIdx)\n }\n\n useEffect(() => {\n if (!galleryAutoPlay || images.length <= 1) {\n return\n }\n\n const intervalId = window.setInterval(() => {\n setIsGalleryTransitioning(true)\n setGalleryIdx((current) => (current + 1) % images.length)\n }, 3500)\n\n return () => window.clearInterval(intervalId)\n }, [galleryAutoPlay, images.length])\n\n function changeQty(next: number) {\n const val = Math.max(1, next)\n if (onQuantityChange) onQuantityChange(val)\n else setInternalQty(val)\n }\n\n const availLabel =\n available === true\n ? 'Available'\n : available === false\n ? 'Unavailable'\n : typeof available === 'number'\n ? `${available} spots`\n : null\n\n const parsedDate = date ? (date instanceof Date ? date : new Date(date)) : null\n const dateDay = parsedDate ? parsedDate.getDate() : null\n const dateMonth = parsedDate ? parsedDate.toLocaleString('en', {month: 'short'}).toUpperCase() : null\n\n return (\n <div className={cn('card-service', variant, `color-${color}`, className)} {...rest}>\n {images.length > 0 && (\n <div className=\"cs-gallery\">\n <img\n src={images[galleryIdx]}\n alt={title}\n className={cn('cs-image', isGalleryTransitioning && 'is-transitioning')}\n />\n {images.length > 1 && (\n <div className=\"cs-gallery-dots\">\n {images.map((_, i) => (\n <button\n key={i}\n type=\"button\"\n className={cn('cs-dot', i === galleryIdx && 'active')}\n onClick={() => changeGallery(i)}\n aria-label={`Image ${i + 1}`}\n />\n ))}\n </div>\n )}\n\n {(onFavorite || (menuItems && menuItems.length > 0)) && (\n <div className=\"cs-gallery-actions\">\n {menuItems && menuItems.length > 0 && (\n <MDropdownMenu\n className=\"cs-menu-wrap\"\n trigger={\n <MButton\n variant=\"ghost\"\n iconOnly\n shape=\"circle\"\n aria-label=\"More options\"\n className=\"cs-overlay-btn\"\n >\n <MEllipsisVerticalIcon />\n </MButton>\n }\n placement=\"bottom-end\"\n >\n {menuItems.map((item, i) => (\n <MDropdownItem\n key={i}\n icon={item.icon}\n color={item.danger ? 'error' : undefined}\n label={item.label}\n onClick={item.onClick}\n />\n ))}\n </MDropdownMenu>\n )}\n {onFavorite && (\n <MButton\n variant=\"ghost\"\n iconOnly\n shape=\"circle\"\n onClick={onFavorite}\n aria-label={favorite ? 'Remove from favorites' : 'Add to favorites'}\n className={cn('cs-overlay-btn', favorite && 'cs-fav-active')}\n >\n {favorite ? <MHeartFillIcon /> : <MHeartIcon />}\n </MButton>\n )}\n </div>\n )}\n </div>\n )}\n\n <div className=\"cs-body\">\n {variant === 'event' && parsedDate && (\n <div className=\"cs-event-header\">\n <div className=\"cs-date-block\">\n <span className=\"cs-date-day\">{dateDay}</span>\n <span className=\"cs-date-month\">{dateMonth}</span>\n </div>\n <div className=\"cs-event-info\">\n <h3 className=\"cs-title\">{title}</h3>\n {description && <p className=\"cs-desc\">{description}</p>}\n </div>\n </div>\n )}\n\n {variant !== 'event' && (\n <>\n <div className=\"cs-top\">\n {icon && <span className=\"cs-icon\">{icon}</span>}\n <h3 className=\"cs-title\">{title}</h3>\n </div>\n {description && <p className=\"cs-desc\">{description}</p>}\n </>\n )}\n\n {variant === 'event' && !parsedDate && (\n <>\n <div className=\"cs-top\">\n {icon && <span className=\"cs-icon\">{icon}</span>}\n <h3 className=\"cs-title\">{title}</h3>\n </div>\n {description && <p className=\"cs-desc\">{description}</p>}\n </>\n )}\n\n {rating !== undefined && (\n <div className=\"cs-rating\">\n <MRating value={Math.round(rating)} size=\"sm\" color=\"warning\" readOnly className=\"cs-stars\" />\n <span className=\"cs-rating-value\">{rating.toFixed(1)}</span>\n {reviewCount !== undefined && <span className=\"cs-review-count\">({reviewCount})</span>}\n </div>\n )}\n\n {leader && (\n <div className=\"cs-leader\">\n <MAvatar src={leader.avatar} name={leader.name} size={28} color={color} />\n <span className=\"cs-leader-name\">{leader.name}</span>\n </div>\n )}\n\n {variant === 'course' && participants && (\n <div className=\"cs-participants\">\n <div className=\"cs-participants-avatars\">\n {participants.slice(0, 4).map((participant, index) => (\n <MAvatar\n key={`${participant.name}-${index}`}\n src={participant.avatar}\n name={participant.name}\n size={28}\n color={color}\n className=\"cs-participant-avatar\"\n />\n ))}\n </div>\n {maxParticipants && (\n <span className=\"cs-spots\">\n {participants.length}/{maxParticipants}\n </span>\n )}\n </div>\n )}\n\n <div className=\"cs-meta\">\n {variant === 'event' && location && (\n <MBadge size=\"xs\" color={color}>\n {location}\n </MBadge>\n )}\n {duration && (\n <MBadge size=\"xs\" color={color} icon={<MClockIcon />}>\n {duration}\n </MBadge>\n )}\n {variant === 'event' && status && (\n <MBadge size=\"xs\" color={status.toLowerCase() === 'sold out' ? 'error' : color}>\n {status}\n </MBadge>\n )}\n {availLabel && variant !== 'event' && (\n <MBadge size=\"xs\" color={available === false ? 'error' : color}>\n {availLabel}\n </MBadge>\n )}\n </div>\n </div>\n\n <div className=\"cs-footer\">\n {price !== undefined && (\n <span className=\"cs-price\">\n {typeof price === 'number' ? price.toFixed(2) : price}{' '}\n <span className=\"cs-currency\">{currency}</span>\n </span>\n )}\n\n <div className=\"cs-actions\">\n {variant === 'product' && onAddToCart && (\n <div className=\"cs-qty\">\n <MButton\n variant=\"ghost\"\n iconOnly\n size=\"sm\"\n onClick={() => changeQty(qty - 1)}\n aria-label=\"Decrease\"\n className=\"cs-qty-btn\"\n >\n <MMinusIcon />\n </MButton>\n <span className=\"cs-qty-value\">{qty}</span>\n <MButton\n variant=\"ghost\"\n iconOnly\n size=\"sm\"\n onClick={() => changeQty(qty + 1)}\n aria-label=\"Increase\"\n className=\"cs-qty-btn\"\n >\n <MPlusIcon />\n </MButton>\n </div>\n )}\n {onAddToCart && (\n <MButton\n variant=\"filled\"\n size=\"sm\"\n color={color}\n onClick={() => onAddToCart(qty)}\n disabled={available === false}\n className=\"cs-cart-btn\"\n >\n {actionLabel ?? (variant === 'event' ? 'Register' : 'Add to cart')}\n </MButton>\n )}\n </div>\n </div>\n </div>\n )\n}\n","import type {MCardOfferProps} from './MCardOffer.types'\nimport {SharedServiceCard} from '../ServiceCardsShared/ServiceCardsShared'\n\nexport function MCardOffer(props: MCardOfferProps) {\n const {onAction, actionLabel = 'Book now', ...rest} = props\n\n return (\n <SharedServiceCard\n variant=\"service\"\n onAddToCart={onAction ? () => onAction() : undefined}\n actionLabel={actionLabel}\n {...rest}\n />\n )\n}\n","import type {MCardCourseProps} from './MCardCourse.types'\nimport {SharedServiceCard} from '../ServiceCardsShared/ServiceCardsShared'\n\nexport function MCardCourse(props: MCardCourseProps) {\n const {onAction, actionLabel = 'Join course', ...rest} = props\n\n return (\n <SharedServiceCard\n variant=\"course\"\n onAddToCart={onAction ? () => onAction() : undefined}\n actionLabel={actionLabel}\n {...rest}\n />\n )\n}\n","import {useEffect, useRef} from 'react'\nimport type {MouseEvent} from 'react'\nimport type {MCardTileProps} from './MCardTile.types'\nimport {cn} from '../../../utils/cn'\nimport {useInteractionEffect} from '../../../utils/useInteractionEffect'\nimport {MEllipsisVerticalIcon, MHeartFillIcon, MHeartIcon} from '../../../icons'\nimport {MButton} from '../../controls'\nimport {MDropdownItem, MDropdownMenu} from '../../overlays'\nimport {resolveMCardAction} from '../shared'\nimport './MCardTile.css'\n\n// Tile card: whole surface acts as a link/button, media can fill the card with text overlay.\n// Media can be an image URL, a video URL, an MIllustration element, or a live camera stream.\nexport function MCardTile({\n component,\n title,\n description,\n icon,\n color = 'primary',\n to,\n href,\n target,\n rel,\n onClick,\n interactive = false,\n clickEffect,\n rippleColor,\n image,\n video,\n illustration,\n camera,\n mediaFill = false,\n overlayPosition = 'bottom',\n favorite,\n onFavorite,\n menuItems,\n className,\n ...rest\n}: MCardTileProps) {\n const videoRef = useRef<HTMLVideoElement>(null)\n\n useEffect(() => {\n if (!camera) {\n return\n }\n\n const node = videoRef.current\n if (!node || typeof navigator === 'undefined' || !navigator.mediaDevices?.getUserMedia) {\n return\n }\n\n let activeStream: MediaStream | null = null\n let cancelled = false\n const constraints: MediaStreamConstraints = camera === true ? {video: true} : camera\n\n navigator.mediaDevices\n .getUserMedia(constraints)\n .then((stream) => {\n if (cancelled) {\n stream.getTracks().forEach((track) => track.stop())\n return\n }\n activeStream = stream\n node.srcObject = stream\n void node.play().catch(() => undefined)\n })\n .catch(() => undefined)\n\n return () => {\n cancelled = true\n if (activeStream) {\n activeStream.getTracks().forEach((track) => track.stop())\n }\n node.srcObject = null\n }\n }, [camera])\n\n const hasMedia = Boolean(image || video || illustration || camera)\n const {\n component: OverlayComponent,\n href: resolvedHref,\n to: resolvedTo,\n isInteractive,\n isLink,\n } = resolveMCardAction({\n component,\n href,\n to,\n interactive,\n hasClickHandler: Boolean(onClick),\n fallbackComponent: 'button',\n })\n const fillMedia = mediaFill && hasMedia\n const {effectClassName, effectLayer, handlePointerDown} = useInteractionEffect<HTMLDivElement>({\n effect: clickEffect ?? (isInteractive ? 'ripple' : 'none'),\n disabled: !isInteractive,\n color: rippleColor,\n })\n\n function stopBubble(event: MouseEvent) {\n event.stopPropagation()\n }\n\n function handleOverlayClick(event: MouseEvent<HTMLElement>) {\n if (onClick) {\n event.preventDefault()\n onClick()\n }\n }\n\n function renderMedia() {\n if (!hasMedia) {\n return null\n }\n\n return (\n <div className={cn('tile-media', fillMedia && 'fill')}>\n {image && <img src={image} alt={title} className=\"tile-image\" />}\n {video && (\n <video src={video} className=\"tile-video\" autoPlay muted loop playsInline aria-label={title} />\n )}\n {camera && (\n <video ref={videoRef} className=\"tile-video\" autoPlay muted playsInline aria-label={title} />\n )}\n {illustration && <div className=\"tile-illustration\">{illustration}</div>}\n {fillMedia && <div className={cn('tile-scrim', `scrim-${overlayPosition}`)} />}\n </div>\n )\n }\n\n function renderBody() {\n return (\n <div className={cn('tile-body', fillMedia && 'overlay', fillMedia && `pos-${overlayPosition}`)}>\n <div className=\"tile-top\">\n {icon && <span className=\"tile-icon\">{icon}</span>}\n <h3 className=\"tile-title\">{title}</h3>\n </div>\n {description && <p className=\"tile-desc\">{description}</p>}\n </div>\n )\n }\n\n const hasActions = onFavorite || (menuItems && menuItems.length > 0)\n\n return (\n <div\n className={cn(\n 'card-tile',\n `color-${color}`,\n fillMedia && 'media-fill',\n isInteractive && 'interactive',\n effectClassName,\n className\n )}\n onPointerDown={handlePointerDown}\n {...rest}\n >\n {effectLayer}\n {isLink && (\n <OverlayComponent\n href={OverlayComponent === 'a' || component ? resolvedHref : undefined}\n to={resolvedTo}\n target={target}\n rel={rel}\n className=\"tile-link\"\n aria-label={title}\n onClick={onClick ? handleOverlayClick : undefined}\n />\n )}\n {!isLink && onClick && (\n <OverlayComponent type=\"button\" className=\"tile-link\" aria-label={title} onClick={onClick} />\n )}\n\n {renderMedia()}\n {renderBody()}\n\n {hasActions && (\n <div className=\"tile-actions\" onClick={stopBubble} onPointerDown={stopBubble}>\n {menuItems && menuItems.length > 0 && (\n <MDropdownMenu\n className=\"tile-menu-wrap\"\n trigger={\n <MButton\n variant=\"ghost\"\n iconOnly\n shape=\"circle\"\n aria-label=\"More options\"\n className=\"tile-overlay-btn\"\n >\n <MEllipsisVerticalIcon />\n </MButton>\n }\n placement=\"bottom-end\"\n >\n {menuItems.map((item, i) => (\n <MDropdownItem\n key={i}\n icon={item.icon}\n color={item.danger ? 'error' : undefined}\n label={item.label}\n onClick={item.onClick}\n />\n ))}\n </MDropdownMenu>\n )}\n {onFavorite && (\n <MButton\n variant=\"ghost\"\n iconOnly\n shape=\"circle\"\n onClick={onFavorite}\n aria-label={favorite ? 'Remove from favorites' : 'Add to favorites'}\n className={cn('tile-overlay-btn', favorite && 'tile-fav-active')}\n >\n {favorite ? <MHeartFillIcon /> : <MHeartIcon />}\n </MButton>\n )}\n </div>\n )}\n </div>\n )\n}\n","import type {MCardProductProps} from './MCardProduct.types'\nimport {SharedServiceCard} from '../ServiceCardsShared/ServiceCardsShared'\n\nexport function MCardProduct(props: MCardProductProps) {\n const {addToCartLabel = 'Add to cart', ...rest} = props\n\n return <SharedServiceCard variant=\"product\" actionLabel={addToCartLabel} {...rest} />\n}\n","import type {MCardEventProps} from './MCardEvent.types'\nimport {SharedServiceCard} from '../ServiceCardsShared/ServiceCardsShared'\n\nexport function MCardEvent(props: MCardEventProps) {\n const {onRegister, registerLabel = 'Register', ...rest} = props\n\n return (\n <SharedServiceCard\n variant=\"event\"\n onAddToCart={onRegister ? () => onRegister() : undefined}\n actionLabel={registerLabel}\n {...rest}\n />\n )\n}\n","import type {PointerEvent} from 'react'\nimport type {MCardWidgetProps} from './MCardWidget.types'\nimport {cn} from '../../../utils/cn'\nimport {MArrowDownIcon, MArrowUpIcon} from '../../../icons'\nimport {useInteractionEffect} from '../../../utils/useInteractionEffect'\nimport {resolveMCardAction} from '../shared'\nimport './MCardWidget.css'\n\nfunction resolveTrendType(trend: MCardWidgetProps['trend'], explicit?: MCardWidgetProps['trendType']) {\n if (explicit) return explicit\n if (typeof trend !== 'number' || trend === 0) return 'neutral'\n return trend > 0 ? 'up' : 'down'\n}\n\nfunction formatTrend(trend: MCardWidgetProps['trend']) {\n if (typeof trend === 'number' && trend > 0) {\n return `+${trend}`\n }\n\n return trend\n}\n\nexport function MCardWidget({\n component,\n to,\n href,\n target,\n rel,\n title,\n value,\n trend,\n trendType,\n icon,\n color = 'primary',\n helperText,\n interactive = false,\n clickEffect,\n rippleColor,\n className,\n onPointerDown,\n ...rest\n}: MCardWidgetProps) {\n const hasTrend = trend !== undefined && trend !== null\n const resolvedTrendType = resolveTrendType(trend, trendType)\n const formattedTrend = formatTrend(trend)\n const {\n component: Component,\n href: resolvedHref,\n to: resolvedTo,\n isInteractive,\n } = resolveMCardAction({\n component,\n href,\n to,\n interactive,\n hasClickHandler: Boolean(rest.onClick),\n hasPointerHandler: Boolean(onPointerDown),\n })\n const {effectClassName, effectLayer, handlePointerDown} = useInteractionEffect<HTMLDivElement>({\n effect: clickEffect ?? (isInteractive ? 'ripple' : 'none'),\n disabled: !isInteractive,\n color: rippleColor,\n })\n\n return (\n <Component\n href={Component === 'a' || component ? resolvedHref : undefined}\n to={resolvedTo}\n target={target}\n rel={rel}\n className={cn('card-widget', `color-${color}`, isInteractive && 'interactive', effectClassName, className)}\n onPointerDown={(event: PointerEvent<HTMLDivElement>) => {\n handlePointerDown(event)\n onPointerDown?.(event)\n }}\n {...rest}\n >\n {effectLayer}\n <div className=\"cw-top\">\n <div className=\"cw-meta\">\n <span className=\"cw-title\">{title}</span>\n <span className=\"cw-value\">{value}</span>\n </div>\n {icon && <span className=\"cw-icon\">{icon}</span>}\n </div>\n\n {hasTrend && (\n <div className=\"cw-bottom\">\n <span className={cn('cw-trend', resolvedTrendType)}>\n {resolvedTrendType === 'up' && <MArrowUpIcon size={14} />}\n {resolvedTrendType === 'down' && <MArrowDownIcon size={14} />}\n <span>{formattedTrend}</span>\n </span>\n </div>\n )}\n\n {helperText && <div className=\"cw-helper\">{helperText}</div>}\n </Component>\n )\n}\n","import type {MCardStatProps} from './MStatCard.types'\nimport {MCard} from '../MCard'\nimport {MText} from '../../typography'\nimport {MInline, MStack} from '../../layout'\nimport {MArrowDownIcon, MArrowUpIcon} from '../../../icons'\nimport {cn} from '../../../utils/cn'\nimport './MStatCard.css'\n\nfunction resolveTrendType(trend: MCardStatProps['trend'], explicit?: MCardStatProps['trendType']) {\n if (explicit) {\n return explicit\n }\n\n if (typeof trend !== 'number' || trend === 0) {\n return 'neutral'\n }\n\n return trend > 0 ? 'up' : 'down'\n}\n\nfunction formatTrend(trend: MCardStatProps['trend']) {\n if (typeof trend === 'number' && trend > 0) {\n return `+${trend}`\n }\n\n return trend\n}\n\nexport function MCardStat({\n label,\n value,\n icon,\n badge,\n helperText,\n trend,\n trendType,\n color = 'primary',\n className,\n ...rest\n}: MCardStatProps) {\n const hasTrend = trend !== undefined && trend !== null\n const resolvedTrendType = resolveTrendType(trend, trendType)\n\n return (\n <MCard className={cn('stat-card', `color-${color}`, className)} {...rest}>\n <MStack padding={'sm'}>\n <MInline justify={'between'} align={'start'}>\n <MStack>\n <MText size={'sm'} tone={'muted'}>\n {label}\n </MText>\n <span className=\"stat-card-value\">{value}</span>\n </MStack>\n <MInline align={'center'} padding={'xs'}>\n {badge}\n {icon && <span className=\"stat-card-icon\">{icon}</span>}\n </MInline>\n </MInline>\n\n {(hasTrend || helperText) && (\n <MInline justify={'between'} align={'center'}>\n {hasTrend ? (\n <span className={cn('stat-card-trend', resolvedTrendType)}>\n {resolvedTrendType === 'up' && <MArrowUpIcon size={14} />}\n {resolvedTrendType === 'down' && <MArrowDownIcon size={14} />}\n <span>{formatTrend(trend)}</span>\n </span>\n ) : (\n <span />\n )}\n {helperText && (\n <MText size={'sm'} tone={'muted'}>\n {helperText}\n </MText>\n )}\n </MInline>\n )}\n </MStack>\n </MCard>\n )\n}\n","import {Fragment, useState, useMemo, useRef, useCallback, type CSSProperties} from 'react'\nimport type {MCardGridProps, MCardGridResponsiveColumns, MCardGridSort} from './MCardGrid.types'\nimport {cn} from '../../../utils/cn'\nimport {MButton, MCheckbox} from '../../controls'\nimport {MInputSearch} from '../../inputs'\nimport {MPagination} from '../../layout'\nimport {MPopover} from '../../primitives'\nimport {MArrowDownIcon, MArrowUpIcon, MFilterIcon, MSortIcon} from '../../../icons'\nimport './MCardGrid.css'\n\n/**\n * Builds inline style for `.card-grid-items`:\n * - `number` → hard `grid-template-columns: repeat(N, 1fr)` (overrides every breakpoint).\n * - responsive object → CSS custom properties (`--cols-base`, `--cols-sm`, ...) consumed\n * by `min-width` media queries in `MCardGrid.css`. Missing breakpoints cascade through\n * the `var()` fallback chain (xxl → xl → lg → md → sm → base → 1).\n */\nfunction buildColumnsStyle(columns: number | MCardGridResponsiveColumns): CSSProperties {\n if (typeof columns === 'number') return {gridTemplateColumns: `repeat(${columns}, 1fr)`}\n\n const style: Record<string, string | number> = {}\n if (columns.base !== undefined) style['--cols-base'] = columns.base\n if (columns.sm !== undefined) style['--cols-sm'] = columns.sm\n if (columns.md !== undefined) style['--cols-md'] = columns.md\n if (columns.lg !== undefined) style['--cols-lg'] = columns.lg\n if (columns.xl !== undefined) style['--cols-xl'] = columns.xl\n if (columns.xxl !== undefined) style['--cols-xxl'] = columns.xxl\n return style as CSSProperties\n}\n\nfunction getNestedValue(obj: unknown, key: string): unknown {\n const parts = key.split('.')\n let val: unknown = obj\n\n for (const p of parts) {\n if (val == null || typeof val !== 'object') return undefined\n val = (val as Record<string, unknown>)[p]\n }\n\n return val\n}\n\nexport function MCardGrid<T extends Record<string, unknown>>({\n items,\n renderCard,\n color = 'primary',\n searchable = false,\n searchKeys,\n searchPlaceholder = 'Search...',\n search: controlledSearch,\n onSearchChange,\n filterable = false,\n filterKeys = [],\n filters: controlledFilters,\n onFiltersChange,\n sortable = false,\n sortKeys = [],\n defaultSort,\n sort: controlledSort,\n onSortChange,\n pagination = false,\n pageSize = 12,\n page: controlledPage,\n onPageChange,\n total,\n manualSearch = false,\n manualFilters = false,\n manualSort = false,\n manualPagination = false,\n columns = 3,\n emptyMessage = 'No results found.',\n className,\n style,\n ...rest\n}: MCardGridProps<T>) {\n const [internalSearch, setInternalSearch] = useState('')\n const [internalFilters, setInternalFilters] = useState<Record<string, string[]>>({})\n const [internalSort, setInternalSort] = useState<MCardGridSort<T> | null>(defaultSort ?? null)\n const [internalPage, setInternalPage] = useState(1)\n const [filterOpen, setFilterOpen] = useState(false)\n const [sortOpen, setSortOpen] = useState(false)\n const filterBtnRef = useRef<HTMLElement>(null)\n const sortBtnRef = useRef<HTMLElement>(null)\n\n const search = controlledSearch !== undefined ? controlledSearch : internalSearch\n const filters = controlledFilters !== undefined ? controlledFilters : internalFilters\n const sort = controlledSort !== undefined ? controlledSort : internalSort\n const page = controlledPage !== undefined ? controlledPage : internalPage\n\n const setSearch = useCallback(\n (next: string) => {\n if (controlledSearch === undefined) setInternalSearch(next)\n if (!manualPagination && controlledPage === undefined) setInternalPage(1)\n onSearchChange?.(next)\n },\n [controlledSearch, controlledPage, manualPagination, onSearchChange]\n )\n\n const setFilters = useCallback(\n (next: Record<string, string[]>) => {\n if (controlledFilters === undefined) setInternalFilters(next)\n if (!manualPagination && controlledPage === undefined) setInternalPage(1)\n onFiltersChange?.(next)\n },\n [controlledFilters, controlledPage, manualPagination, onFiltersChange]\n )\n\n const setSort = useCallback(\n (next: MCardGridSort<T> | null) => {\n if (controlledSort === undefined) setInternalSort(next)\n if (!manualPagination && controlledPage === undefined) setInternalPage(1)\n onSortChange?.(next)\n },\n [controlledSort, controlledPage, manualPagination, onSortChange]\n )\n\n const setPage = useCallback(\n (next: number) => {\n if (controlledPage === undefined) setInternalPage(next)\n onPageChange?.(next)\n },\n [controlledPage, onPageChange]\n )\n\n const openFilter = useCallback(() => {\n setFilterOpen((v) => !v)\n setSortOpen(false)\n }, [])\n\n const openSort = useCallback(() => {\n setSortOpen((v) => !v)\n setFilterOpen(false)\n }, [])\n\n const processed = useMemo(() => {\n let result = items\n\n if (!manualSearch && search && searchKeys && searchKeys.length > 0) {\n const query = search.toLowerCase()\n result = result.filter((item) =>\n searchKeys.some((key) => {\n const value = getNestedValue(item, key)\n return value != null && String(value).toLowerCase().includes(query)\n })\n )\n }\n\n if (!manualFilters) {\n for (const [key, selected] of Object.entries(filters)) {\n if (!selected || selected.length === 0) continue\n\n result = result.filter((item) => {\n const value = getNestedValue(item, key)\n return value != null && selected.includes(String(value))\n })\n }\n }\n\n if (!manualSort && sort) {\n result = [...result].sort((a, b) => {\n const av = getNestedValue(a, sort.key)\n const bv = getNestedValue(b, sort.key)\n\n if (av == null && bv == null) return 0\n if (av == null) return 1\n if (bv == null) return -1\n\n const compare = String(av).localeCompare(String(bv), undefined, {numeric: true})\n return sort.direction === 'asc' ? compare : -compare\n })\n }\n\n return result === items ? [...result] : result\n }, [items, search, searchKeys, filters, sort, manualSearch, manualFilters, manualSort])\n\n const totalItems = manualPagination ? (total ?? processed.length) : processed.length\n const paginatedItems = useMemo(() => {\n if (!pagination || manualPagination) return processed\n const start = (page - 1) * pageSize\n return processed.slice(start, start + pageSize)\n }, [processed, pagination, manualPagination, page, pageSize])\n\n function toggleFilter(key: string, value: string) {\n const current = filters[key] ?? []\n const next = current.includes(value) ? current.filter((item) => item !== value) : [...current, value]\n setFilters({...filters, [key]: next})\n }\n\n const filterOptions = useMemo(() => {\n const map: Record<string, string[]> = {}\n\n for (const filterKey of filterKeys) {\n if (filterKey.options) {\n map[filterKey.key] = filterKey.options\n continue\n }\n\n const values = new Set<string>()\n\n for (const item of items) {\n const value = getNestedValue(item, filterKey.key)\n if (value != null) values.add(String(value))\n }\n\n map[filterKey.key] = Array.from(values).sort()\n }\n\n return map\n }, [items, filterKeys])\n\n const activeSort = sortKeys.find((item) => item.key === sort?.key)\n\n return (\n <div className={cn('card-grid', `color-${color}`, className)} style={style} {...rest}>\n {(searchable || filterable || sortable) && (\n <div className=\"card-grid-toolbar\">\n {searchable && (\n <MInputSearch\n className=\"card-grid-search\"\n size=\"sm\"\n fullWidth\n placeholder={searchPlaceholder}\n value={search}\n onChange={(event) => setSearch(event.target.value)}\n onClear={() => setSearch('')}\n />\n )}\n\n <div className=\"card-grid-actions\">\n {filterable && filterKeys.length > 0 && (\n <>\n <MButton\n ref={filterBtnRef}\n variant=\"outlined\"\n color={color}\n size=\"sm\"\n startIcon={<MFilterIcon />}\n aria-expanded={filterOpen}\n onClick={openFilter}\n >\n Filter\n </MButton>\n <MPopover\n open={filterOpen}\n anchorRef={filterBtnRef}\n onClose={() => setFilterOpen(false)}\n placement=\"bottom-end\"\n className=\"card-grid-dropdown\"\n >\n {filterKeys.map((filterKey) => (\n <div key={filterKey.key} className=\"card-grid-filter-group\">\n <span className=\"card-grid-filter-label\">{filterKey.label}</span>\n {(filterOptions[filterKey.key] ?? []).map((option) => (\n <div key={option} className=\"card-grid-filter-option\">\n <MCheckbox\n size=\"sm\"\n clickEffect=\"none\"\n checked={filters[filterKey.key]?.includes(option) ?? false}\n onChange={() => toggleFilter(filterKey.key, option)}\n label={option}\n />\n </div>\n ))}\n </div>\n ))}\n </MPopover>\n </>\n )}\n\n {sortable && sortKeys.length > 0 && (\n <>\n <MButton\n ref={sortBtnRef}\n variant=\"outlined\"\n color={color}\n size=\"sm\"\n startIcon={\n sort ? (\n sort.direction === 'asc' ? (\n <MArrowUpIcon />\n ) : (\n <MArrowDownIcon />\n )\n ) : (\n <MSortIcon />\n )\n }\n aria-expanded={sortOpen}\n onClick={openSort}\n >\n {activeSort ? `Sort: ${activeSort.label}` : 'Sort'}\n </MButton>\n <MPopover\n open={sortOpen}\n anchorRef={sortBtnRef}\n onClose={() => setSortOpen(false)}\n placement=\"bottom-end\"\n className=\"card-grid-dropdown\"\n >\n {sortKeys.map((sortItem) => (\n <button\n key={sortItem.key}\n type=\"button\"\n className={cn(\n 'card-grid-sort-item',\n sort?.key === sortItem.key && 'active'\n )}\n onClick={() => {\n if (sort?.key === sortItem.key) {\n setSort({\n key: sortItem.key,\n direction: sort.direction === 'asc' ? 'desc' : 'asc',\n })\n } else {\n setSort({key: sortItem.key, direction: 'asc'})\n }\n }}\n >\n {sortItem.label}\n {sort?.key === sortItem.key && (\n <span className=\"card-grid-sort-dir\">\n {sort.direction === 'asc' ? (\n <MArrowUpIcon className=\"card-grid-sort-icon\" />\n ) : (\n <MArrowDownIcon className=\"card-grid-sort-icon\" />\n )}\n </span>\n )}\n </button>\n ))}\n </MPopover>\n </>\n )}\n </div>\n </div>\n )}\n\n {paginatedItems.length > 0 ? (\n <div className=\"card-grid-items\" style={buildColumnsStyle(columns)}>\n {paginatedItems.map((item, index) => {\n // Wrap each card so consumers don't have to remember `key={item.id}` in renderCard.\n // Prefer the item's id when present (stable across reorders), fall back to index.\n const id = (item as {id?: string | number} | null | undefined)?.id\n return <Fragment key={id ?? index}>{renderCard(item, index)}</Fragment>\n })}\n </div>\n ) : (\n <div className=\"card-grid-empty\">{emptyMessage}</div>\n )}\n\n {pagination && totalItems > pageSize && (\n <div className=\"card-grid-pagination\">\n <MPagination total={totalItems} page={page} pageSize={pageSize} onChange={setPage} />\n </div>\n )}\n </div>\n )\n}\n","import type {PointerEvent} from 'react'\nimport type {MCardFinanceProps} from './MCardFinance.types'\nimport {cn} from '../../../utils/cn'\nimport {useInteractionEffect} from '../../../utils/useInteractionEffect'\nimport {MSparkline} from '../../data/MSparkline/MSparkline'\nimport {MArrowUpIcon, MArrowDownIcon} from '../../../icons'\nimport {resolveMCardAction} from '../shared'\nimport './MCardFinance.css'\n\nfunction resolveChangeType(change: number | undefined, explicit?: MCardFinanceProps['changeType']) {\n if (explicit) return explicit\n if (change === undefined || change === 0) return 'neutral'\n return change > 0 ? 'up' : 'down'\n}\n\nexport function MCardFinance({\n component,\n to,\n href,\n target,\n rel,\n label,\n value,\n change,\n changeType: changeTypeProp,\n changeLabel,\n icon,\n sparkline,\n sparklineType = 'area',\n color = 'primary',\n currency,\n interactive = false,\n clickEffect,\n rippleColor,\n className,\n onPointerDown,\n ...rest\n}: MCardFinanceProps) {\n const changeType = resolveChangeType(change, changeTypeProp)\n\n const changeColor = changeType === 'up' ? 'success' : changeType === 'down' ? 'error' : 'neutral'\n const {\n component: Component,\n href: resolvedHref,\n to: resolvedTo,\n isInteractive,\n } = resolveMCardAction({\n component,\n href,\n to,\n interactive,\n hasClickHandler: Boolean(rest.onClick),\n hasPointerHandler: Boolean(onPointerDown),\n })\n const {effectClassName, effectLayer, handlePointerDown} = useInteractionEffect<HTMLDivElement>({\n effect: clickEffect ?? (isInteractive ? 'ripple' : 'none'),\n disabled: !isInteractive,\n color: rippleColor,\n })\n\n return (\n <Component\n href={Component === 'a' || component ? resolvedHref : undefined}\n to={resolvedTo}\n target={target}\n rel={rel}\n className={cn('card-finance', `color-${color}`, isInteractive && 'interactive', effectClassName, className)}\n onPointerDown={(event: PointerEvent<HTMLDivElement>) => {\n handlePointerDown(event)\n onPointerDown?.(event)\n }}\n {...rest}\n >\n {effectLayer}\n <div className=\"cf-top\">\n <div className=\"cf-meta\">\n <span className=\"cf-label\">{label}</span>\n {currency && <span className=\"cf-currency\">{currency}</span>}\n </div>\n {icon && <span className=\"cf-icon\">{icon}</span>}\n </div>\n\n <div className=\"cf-value\">{value}</div>\n\n <div className=\"cf-bottom\">\n {change !== undefined && (\n <span className={cn('cf-change', changeColor)}>\n {changeType === 'up' && <MArrowUpIcon size={14} />}\n {changeType === 'down' && <MArrowDownIcon size={14} />}\n <span className=\"cf-change-value\">\n {change > 0 ? '+' : ''}\n {change}%\n </span>\n {changeLabel && <span className=\"cf-change-label\">{changeLabel}</span>}\n </span>\n )}\n </div>\n\n <div className=\"cf-sparkline\">\n <MSparkline\n data={sparkline}\n type={sparklineType}\n color={changeColor === 'neutral' ? color : changeColor}\n height={46}\n padding={0}\n curved\n animated\n fillOpacity={0.18}\n />\n </div>\n </Component>\n )\n}\n","import type {MCardDayScheduleProps} from './MCardDaySchedule.types'\nimport {MCard, MCardBody, MCardFooter, MCardHeader} from '../MCard'\nimport {MDetailList} from '../../display'\nimport {MGrid, MInline, MStack, MTabs} from '../../layout'\nimport {MHeading, MText} from '../../typography'\nimport {tintCardChildren} from '../shared'\nimport './MCardDaySchedule.css'\n\nexport function MCardDaySchedule({\n title = 'Today',\n description,\n color = 'primary',\n workdayStart,\n workdayEnd,\n timeline,\n summary,\n tabs = [],\n footer,\n emptyTimeline = <MText tone={'muted'}>No events scheduled for this day.</MText>,\n ...rest\n}: MCardDayScheduleProps) {\n const workdayLabel =\n workdayStart && workdayEnd ? `${workdayStart}-${workdayEnd}` : (workdayStart ?? workdayEnd ?? undefined)\n\n const populatedTabs = tabs.filter((tab) => tab.items.length > 0)\n\n return (\n <MCard color={color} {...rest}>\n <MCardHeader>\n <MStack>\n <MHeading level={4}>{title}</MHeading>\n {(description || workdayLabel) && (\n <MText size={'sm'} tone={'muted'}>\n {description}\n {description && workdayLabel ? ' ' : null}\n {workdayLabel}\n </MText>\n )}\n </MStack>\n </MCardHeader>\n <MCardBody>\n <MGrid type={'row'} align={'start'}>\n <MGrid type={'col'} xl={7} sm={12}>\n {timeline.length ? (\n <MStack className=\"day-schedule-card-timeline\">\n {timeline.map((item) => (\n <MInline key={item.id} align={'start'} className=\"day-schedule-card-entry\">\n <span className=\"day-schedule-card-time\">{item.time}</span>\n <div className=\"day-schedule-card-dot\" data-color={item.color ?? color}>\n {tintCardChildren(item.icon, item.color ?? color)}\n </div>\n <div className=\"day-schedule-card-copy\">\n <MText as={'strong'}>{item.title}</MText>\n {item.description && (\n <MText size={'sm'} tone={'muted'}>\n {item.description}\n </MText>\n )}\n </div>\n </MInline>\n ))}\n </MStack>\n ) : (\n emptyTimeline\n )}\n </MGrid>\n\n <MGrid type={'col'} xl={5} sm={12}>\n <MStack className=\"day-schedule-card-side\">\n {summary}\n\n {populatedTabs.length > 0 && (\n <MTabs\n variant={'underline'}\n size={'sm'}\n fullWidth\n defaultValue={populatedTabs[0].type}\n items={populatedTabs.map((tab) => ({\n value: tab.type,\n label: (\n <span className=\"day-schedule-card-tab-label\">\n <span>{tab.title}</span>\n <span className=\"day-schedule-card-tab-count\">{tab.items.length}</span>\n </span>\n ),\n content: <MDetailList items={tab.items} />,\n }))}\n />\n )}\n </MStack>\n </MGrid>\n </MGrid>\n </MCardBody>\n {footer && <MCardFooter>{tintCardChildren(footer, color)}</MCardFooter>}\n </MCard>\n )\n}\n","import type {MCardDocumentTreeProps} from './MCardDocumentTree.types'\nimport {MCard, MCardBody, MCardHeader} from '../MCard'\nimport {MButton} from '../../controls'\nimport {MTreeView} from '../../data'\nimport {MDetailList} from '../../display'\nimport {MGrid, MInline, MStack} from '../../layout'\nimport {MDropdownItem, MDropdownMenu} from '../../overlays'\nimport {MHeading, MText} from '../../typography'\nimport {MEllipsisVerticalIcon} from '../../../icons'\nimport {tintCardChildren} from '../shared'\nimport type {MTreeNode} from '../../data/MTreeView'\n\nexport function MCardDocumentTree({\n title = 'Documents',\n description,\n color = 'primary',\n items,\n selected,\n onSelect,\n defaultExpanded,\n expanded,\n onExpandChange,\n detailsTitle,\n detailsMeta,\n detailsItems = [],\n detailsActions = [],\n renderDetails,\n emptyDetails = <MText tone={'muted'}>Select a document to inspect its details.</MText>,\n primaryAction,\n ...rest\n}: MCardDocumentTreeProps) {\n const mapNode = (node: MTreeNode): MTreeNode => {\n return {\n ...node,\n icon: tintCardChildren(node.icon, color),\n children: node.children?.map(mapNode),\n }\n }\n const itemsWithTint = items.map(mapNode)\n\n return (\n <MCard stretch={false} color={color} {...rest}>\n <MCardHeader>\n <MInline justify={'between'} align={'center'}>\n <MStack>\n <MHeading level={4}>{title}</MHeading>\n {description && (\n <MText size={'sm'} tone={'muted'}>\n {description}\n </MText>\n )}\n </MStack>\n {tintCardChildren(primaryAction, color)}\n </MInline>\n </MCardHeader>\n <MCardBody>\n <MGrid type={'row'} align={'start'}>\n <MGrid type={'col'} xl={7} sm={12}>\n <MTreeView\n items={itemsWithTint}\n color={color}\n defaultExpanded={defaultExpanded}\n expanded={expanded}\n onExpandChange={onExpandChange}\n selected={selected}\n onSelect={onSelect}\n expandable\n selectable\n showLines\n fileIcons\n />\n </MGrid>\n <MGrid type={'col'} xl={5} sm={12}>\n <MStack padding={'sm'}>\n {(detailsTitle || detailsMeta || detailsActions.length > 0) && (\n <MInline justify={'between'} align={'start'}>\n <MStack>\n {detailsTitle && <MHeading level={5}>{detailsTitle}</MHeading>}\n {detailsMeta && (\n <MText size={'sm'} tone={'muted'}>\n {detailsMeta}\n </MText>\n )}\n </MStack>\n\n {detailsActions.length > 0 && (\n <MDropdownMenu\n placement={'bottom-end'}\n trigger={\n <MButton\n variant={'ghost'}\n color={color}\n iconOnly\n shape={'circle'}\n aria-label={'Open document actions'}\n >\n <MEllipsisVerticalIcon />\n </MButton>\n }\n >\n {detailsActions.map((action) => (\n <MDropdownItem\n key={action.id}\n icon={tintCardChildren(action.icon, action.color ?? color)}\n label={action.label}\n color={action.color ?? color}\n disabled={action.disabled}\n component={action.component}\n href={action.href}\n to={action.to}\n onClick={action.onClick}\n />\n ))}\n </MDropdownMenu>\n )}\n </MInline>\n )}\n\n {renderDetails ? (\n renderDetails\n ) : detailsItems.length ? (\n <MDetailList items={detailsItems} />\n ) : (\n emptyDetails\n )}\n </MStack>\n </MGrid>\n </MGrid>\n </MCardBody>\n </MCard>\n )\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ const e=require(`./icons-qCoE70hn.cjs`),t=require(`./cn-CU5TNITO.cjs`),n=require(`./creditCards-D_HwRUBz.cjs`),r=require(`./useInteractionEffect-Bo8285cg.cjs`),i=require(`./MPopover-CxxaY9kr.cjs`),a=require(`./MStack-w8XcuIJK.cjs`),o=require(`./MText-BHbI7KJO.cjs`),s=require(`./MHeading-f3hwkW3r.cjs`),c=require(`./MLink-CRK8YvR4.cjs`),l=require(`./MButton-DFRHWHzh.cjs`),u=require(`./MCheckbox-Dn3p_9-1.cjs`),d=require(`./MSkeleton-CuYA8eN3.cjs`),f=require(`./MInputSearch-_7jfFGr1.cjs`),p=require(`./MInputExpDate-DZ8JtSjs.cjs`),m=require(`./MDropdownMenu-c9U3sEcl.cjs`),h=require(`./MQrCode-HO2YIC7e.cjs`),g=require(`./MAvatar-DzZPRbot.cjs`),_=require(`./MTreeView-Dp9qbqQh.cjs`),v=require(`./MTabs-DeUn6bIp.cjs`),y=require(`./MGrid-B-fP4GME.cjs`),b=require(`./MPagination-D1hYqLDb.cjs`);require(`./core-DAox0BHy.cjs`);let x=require(`react`),S=require(`react/jsx-runtime`);function C(e){if(typeof e==`string`)return e;if(typeof e==`function`){let t=e;return t.displayName??t.name??``}if(typeof e==`object`&&e){let t=e;return t.displayName??t.render?.displayName??t.render?.name??``}return``}function w(e){if(e.props.color!==void 0)return!1;if(e.type===l.t)return!0;let t=C(e.type);return t.startsWith(`M`)&&t.endsWith(`Icon`)}function T(e,t){return t?x.Children.map(e,e=>{if(!(0,x.isValidElement)(e))return e;let n=e,r=n.props,i=r.children?T(r.children,t):r.children,a={};return i!==r.children&&(a.children=i),w(n)&&(a.color=t),Object.keys(a).length?(0,x.cloneElement)(n,a):n}):e}function E({component:e,to:n,href:i,target:a,rel:o,color:s,interactive:c=!0,clickEffect:l,rippleColor:u,className:f,children:p,onPointerDown:m,type:h,...g}){let{component:_,href:v,to:y,isInteractive:b}=d.o({component:e,href:i,to:n,interactive:c,hasClickHandler:!!g.onClick,hasPointerHandler:!!m,fallbackComponent:`button`}),{effectClassName:x,effectLayer:C,handlePointerDown:w}=r.t({effect:l??(b?`ripple`:`none`),disabled:!b,color:u});return(0,S.jsxs)(_,{href:_===`a`||e?v:void 0,to:y,target:a,rel:o,type:_===`button`?h??`button`:void 0,className:t.t(`card-action-area`,s&&`color-${s}`,b&&`interactive`,x,f),onPointerDown:e=>{w(e),m?.(e)},...g,children:[C,(0,S.jsx)(`span`,{className:`card-action-area-content`,children:T(p,s)})]})}function D(e){let t=e.replace(/\D/g,``);return t.length<=4?t:`\u2022\u2022\u2022\u2022 \u2022\u2022\u2022\u2022 \u2022\u2022\u2022\u2022 ${t.slice(-4)}`}function O({component:e,to:i,href:a,target:o,rel:s,holder:c,number:l,expiry:u,brand:f,brandIcon:p,balance:m,balanceLabel:h=`Current balance`,color:g,interactive:_=!1,clickEffect:v,rippleColor:y,className:b,onPointerDown:x,...C}){let w=n.n(l),T=f??w.brand,E=n.t.find(e=>e.brand===T)??w,O=D(l),k=E.iconLabel,{component:A,href:j,to:M,isInteractive:N}=d.o({component:e,href:a,to:i,interactive:_,hasClickHandler:!!C.onClick,hasPointerHandler:!!x}),{effectClassName:P,effectLayer:F,handlePointerDown:I}=r.t({effect:v??(N?`ripple`:`none`),disabled:!N,color:y});return(0,S.jsxs)(A,{href:A===`a`||e?j:void 0,to:M,target:o,rel:s,className:t.t(`card-payment`,g||`primary`,N&&`interactive`,P,b),onPointerDown:e=>{I(e),x?.(e)},...C,children:[F,m!==void 0&&(0,S.jsxs)(`div`,{children:[(0,S.jsx)(`p`,{className:`cp-balance-label`,children:h}),(0,S.jsx)(`p`,{className:`cp-balance`,children:m})]}),(0,S.jsxs)(`div`,{className:`cp-row`,children:[(0,S.jsx)(`span`,{className:t.t(`cp-brand`,!p&&T),children:p??k}),(0,S.jsx)(`span`,{className:`cp-number`,children:O})]}),(0,S.jsxs)(`div`,{className:`cp-details`,children:[(0,S.jsxs)(`div`,{children:[(0,S.jsx)(`p`,{className:`cp-field-label`,children:`MCard holder`}),(0,S.jsx)(`p`,{className:`cp-field-value`,children:c})]}),(0,S.jsxs)(`div`,{children:[(0,S.jsx)(`p`,{className:`cp-field-label`,children:`Expiration date`}),(0,S.jsx)(`p`,{className:`cp-field-value`,children:u})]})]})]})}function k(e){return n.t.find(t=>t.brand===e)?.iconLabel??`CARD`}function A({title:n=`Your payment methods`,actionLabel:r=`Change`,actionHref:i=`#`,onAction:s,brand:l=`visa`,brandIcon:u,last4:f,badgeLabel:m,summary:h,helperText:g=`All fields are required, unless stated otherwise.`,expiryLabel:_=`Expiration date`,cvcLabel:v=`Security code`,expiryProps:y,cvcProps:b,color:x,className:C,...w}){let T=y?.value??y?.defaultValue,E=m===void 0?`Default`:m,D=T?`Credit card - Expiration date ${String(T).replace(`/`,`.`)}`:`Credit card`,O=h===void 0?D:h,A=k(l),j={clearable:!0,...y};return(0,S.jsxs)(`div`,{className:t.t(`card-payment-method`,x||`primary`,C),...w,children:[(0,S.jsxs)(`div`,{className:`cpm-header`,children:[(0,S.jsx)(`h3`,{className:`cpm-title`,children:n}),(0,S.jsxs)(c.t,{href:i,tone:`accent`,underline:`none`,className:`cpm-action`,onClick:e=>{s&&(e.preventDefault(),s())},children:[r,(0,S.jsx)(e.Ai,{})]})]}),(0,S.jsxs)(`div`,{className:`cpm-surface`,children:[(0,S.jsxs)(`div`,{className:`cpm-method`,children:[(0,S.jsxs)(a.n,{align:`center`,className:`cpm-method-row`,children:[(0,S.jsx)(`span`,{className:t.t(`cpm-brand`,!u&&l),children:u??A}),(0,S.jsx)(`span`,{className:`cpm-last4`,children:`\u2022\u2022\u2022\u2022 ${f}`}),E&&(0,S.jsx)(d.s,{color:`info`,children:E})]}),O&&(0,S.jsx)(o.t,{tone:`muted`,className:`cpm-summary`,children:O})]}),g&&(0,S.jsx)(o.t,{tone:`muted`,size:`sm`,className:`cpm-helper`,children:g}),(0,S.jsxs)(`div`,{className:`cpm-fields`,children:[(0,S.jsx)(p.t,{label:_,placeholder:`MM/YYYY`,fullWidth:!0,...j}),(0,S.jsx)(p.n,{label:v,placeholder:`123`,fullWidth:!0,...b})]})]})]})}var j={apple:{label:`Apple`,icon:e.i,colorIcon:e.r,rgb:`24, 24, 27`},discord:{label:`Discord`,icon:e.M,colorIcon:e.j,rgb:`88, 101, 242`},facebook:{label:`Facebook`,icon:e.P,colorIcon:e.N,rgb:`24, 119, 242`},figma:{label:`Figma`,icon:e.I,colorIcon:e.F,rgb:`162, 89, 255`},github:{label:`GitHub`,icon:e.R,colorIcon:e.L,rgb:`24, 23, 23`},google:{label:`Google`,icon:e.B,colorIcon:e.z,rgb:`66, 133, 244`},instagram:{label:`Instagram`,icon:e.H,colorIcon:e.V,rgb:`225, 48, 108`},linkedin:{label:`LinkedIn`,icon:e.W,colorIcon:e.U,rgb:`10, 102, 194`},pinterest:{label:`Pinterest`,icon:e.v,colorIcon:e._,rgb:`230, 0, 35`},slack:{label:`Slack`,icon:e.K,colorIcon:e.G,rgb:`74, 21, 75`},spotify:{label:`Spotify`,icon:e.b,colorIcon:e.y,rgb:`30, 215, 96`},tumblr:{label:`Tumblr`,icon:e.S,colorIcon:e.x,rgb:`0, 25, 53`},vimeo:{label:`Vimeo`,icon:e.E,colorIcon:e.T,rgb:`26, 183, 234`},vk:{label:`VK`,icon:e.A,colorIcon:e.k,rgb:`0, 119, 255`},x:{label:`X`,icon:e.J,colorIcon:e.q,rgb:`17, 17, 17`},youtube:{label:`YouTube`,icon:e.X,colorIcon:e.Y,rgb:`255, 0, 0`}};function M(e){let t=e.trim().toLowerCase().replace(/[\s._-]+/g,``);return t===`twitter`?`x`:t===`vkontakte`?`vk`:t}function N(e){return j[M(e)]?.label??e}function P(e,t=!1){let n=j[M(e)];return n?t?n.colorIcon:n.icon:null}function F(e){return e?[e.street,[e.zip,e.city].filter(Boolean).join(` `),e.country].filter(Boolean).join(`, `):null}function I({variant:n=`user`,name:r,title:i,avatar:a,address:o,contact:s,socials:c,online:l,lastActive:u,qrCode:d,qrValue:f,qrStatus:p,qrStatusLabel:m,color:_=`primary`,className:v,...y}){let b=F(o);return(0,S.jsxs)(`div`,{className:t.t(`card-business`,n,`color-${_}`,v),...y,children:[(0,S.jsxs)(`div`,{className:`cb-header`,children:[(0,S.jsx)(`div`,{className:`cb-avatar-wrap`,children:(0,S.jsx)(g.t,{src:a,alt:r,name:r,size:56,shape:n===`company`?`rounded`:`circle`,color:_,badge:l===void 0?void 0:!0,badgeColor:l===void 0?void 0:l?`success`:`error`,badgePulsing:!!l,className:t.t(`cb-avatar`,n)})}),(0,S.jsxs)(`div`,{className:`cb-info`,children:[(0,S.jsx)(`h3`,{className:`cb-name`,children:r}),i&&(0,S.jsx)(`p`,{className:`cb-title`,children:i}),u&&(0,S.jsx)(`p`,{className:`cb-last-active`,children:u})]}),(f||d)&&(0,S.jsx)(`div`,{className:`cb-qr`,children:f?(0,S.jsx)(h.t,{value:f,size:56,padding:3,status:p,statusLabel:m,className:`cb-qr-code`}):(0,S.jsx)(`img`,{src:d,alt:`QR`,className:`cb-qr-img`})})]}),(s||b)&&(0,S.jsxs)(`div`,{className:`cb-details`,children:[s?.email&&(0,S.jsxs)(`div`,{className:`cb-detail`,children:[(0,S.jsx)(`span`,{className:`cb-detail-icon`,children:(0,S.jsx)(e.Si,{})}),(0,S.jsx)(`a`,{href:`mailto:${s.email}`,className:`cb-detail-value`,children:s.email})]}),s?.phone&&(0,S.jsxs)(`div`,{className:`cb-detail`,children:[(0,S.jsx)(`span`,{className:`cb-detail-icon`,children:(0,S.jsx)(e.bi,{})}),(0,S.jsx)(`a`,{href:`tel:${s.phone}`,className:`cb-detail-value`,children:s.phone})]}),s?.website&&(0,S.jsxs)(`div`,{className:`cb-detail`,children:[(0,S.jsx)(`span`,{className:`cb-detail-icon`,children:(0,S.jsx)(e.gi,{})}),(0,S.jsx)(`a`,{href:s.website,target:`_blank`,rel:`noopener noreferrer`,className:`cb-detail-value`,children:s.website.replace(/^https?:\/\//,``)})]}),b&&(0,S.jsxs)(`div`,{className:`cb-detail`,children:[(0,S.jsx)(`span`,{className:`cb-detail-icon`,children:(0,S.jsx)(e.hi,{})}),(0,S.jsx)(`span`,{className:`cb-detail-value`,children:b})]})]}),c&&c.length>0&&(0,S.jsx)(`div`,{className:`cb-socials`,children:c.map(e=>(()=>{let t=P(e.platform,!0);return(0,S.jsx)(`a`,{href:e.url,target:`_blank`,rel:`noopener noreferrer`,className:`cb-social`,title:N(e.platform),"aria-label":N(e.platform),children:e.icon??(t?(0,S.jsx)(t,{}):(0,S.jsx)(`span`,{className:`cb-social-text`,children:e.platform}))},e.platform)})())})]})}function L({variant:n,title:r,description:i,price:a,currency:o=`PLN`,duration:s,available:c,image:u,gallery:f,galleryAutoPlay:p=!1,rating:_,reviewCount:v,favorite:y,onFavorite:b,menuItems:C,onAddToCart:w,actionLabel:T,icon:E,color:D=`primary`,leader:O,participants:k,maxParticipants:A,quantity:j,onQuantityChange:M,date:N,location:P,status:F,className:I,...L}){let[R,z]=(0,x.useState)(0),[B,V]=(0,x.useState)(!1),[ee,H]=(0,x.useState)(1),U=j??ee,W=f&&f.length>0?f:u?[u]:[];(0,x.useEffect)(()=>{R>=W.length&&z(0)},[R,W.length]),(0,x.useEffect)(()=>{if(!B)return;let e=window.setTimeout(()=>{V(!1)},220);return()=>window.clearTimeout(e)},[R,B]);function G(e){e===R||e<0||e>=W.length||(W.length>1&&V(!0),z(e))}(0,x.useEffect)(()=>{if(!p||W.length<=1)return;let e=window.setInterval(()=>{V(!0),z(e=>(e+1)%W.length)},3500);return()=>window.clearInterval(e)},[p,W.length]);function K(e){let t=Math.max(1,e);M?M(t):H(t)}let q=c===!0?`Available`:c===!1?`Unavailable`:typeof c==`number`?`${c} spots`:null,J=N?N instanceof Date?N:new Date(N):null,Y=J?J.getDate():null,X=J?J.toLocaleString(`en`,{month:`short`}).toUpperCase():null;return(0,S.jsxs)(`div`,{className:t.t(`card-service`,n,`color-${D}`,I),...L,children:[W.length>0&&(0,S.jsxs)(`div`,{className:`cs-gallery`,children:[(0,S.jsx)(`img`,{src:W[R],alt:r,className:t.t(`cs-image`,B&&`is-transitioning`)}),W.length>1&&(0,S.jsx)(`div`,{className:`cs-gallery-dots`,children:W.map((e,n)=>(0,S.jsx)(`button`,{type:`button`,className:t.t(`cs-dot`,n===R&&`active`),onClick:()=>G(n),"aria-label":`Image ${n+1}`},n))}),(b||C&&C.length>0)&&(0,S.jsxs)(`div`,{className:`cs-gallery-actions`,children:[C&&C.length>0&&(0,S.jsx)(m.i,{className:`cs-menu-wrap`,trigger:(0,S.jsx)(l.t,{variant:`ghost`,iconOnly:!0,shape:`circle`,"aria-label":`More options`,className:`cs-overlay-btn`,children:(0,S.jsx)(e.sn,{})}),placement:`bottom-end`,children:C.map((e,t)=>(0,S.jsx)(m.r,{icon:e.icon,color:e.danger?`error`:void 0,label:e.label,onClick:e.onClick},t))}),b&&(0,S.jsx)(l.t,{variant:`ghost`,iconOnly:!0,shape:`circle`,onClick:b,"aria-label":y?`Remove from favorites`:`Add to favorites`,className:t.t(`cs-overlay-btn`,y&&`cs-fav-active`),children:y?(0,S.jsx)(e.pn,{}):(0,S.jsx)(e.mn,{})})]})]}),(0,S.jsxs)(`div`,{className:`cs-body`,children:[n===`event`&&J&&(0,S.jsxs)(`div`,{className:`cs-event-header`,children:[(0,S.jsxs)(`div`,{className:`cs-date-block`,children:[(0,S.jsx)(`span`,{className:`cs-date-day`,children:Y}),(0,S.jsx)(`span`,{className:`cs-date-month`,children:X})]}),(0,S.jsxs)(`div`,{className:`cs-event-info`,children:[(0,S.jsx)(`h3`,{className:`cs-title`,children:r}),i&&(0,S.jsx)(`p`,{className:`cs-desc`,children:i})]})]}),n!==`event`&&(0,S.jsxs)(S.Fragment,{children:[(0,S.jsxs)(`div`,{className:`cs-top`,children:[E&&(0,S.jsx)(`span`,{className:`cs-icon`,children:E}),(0,S.jsx)(`h3`,{className:`cs-title`,children:r})]}),i&&(0,S.jsx)(`p`,{className:`cs-desc`,children:i})]}),n===`event`&&!J&&(0,S.jsxs)(S.Fragment,{children:[(0,S.jsxs)(`div`,{className:`cs-top`,children:[E&&(0,S.jsx)(`span`,{className:`cs-icon`,children:E}),(0,S.jsx)(`h3`,{className:`cs-title`,children:r})]}),i&&(0,S.jsx)(`p`,{className:`cs-desc`,children:i})]}),_!==void 0&&(0,S.jsxs)(`div`,{className:`cs-rating`,children:[(0,S.jsx)(h.r,{value:Math.round(_),size:`sm`,color:`warning`,readOnly:!0,className:`cs-stars`}),(0,S.jsx)(`span`,{className:`cs-rating-value`,children:_.toFixed(1)}),v!==void 0&&(0,S.jsxs)(`span`,{className:`cs-review-count`,children:[`(`,v,`)`]})]}),O&&(0,S.jsxs)(`div`,{className:`cs-leader`,children:[(0,S.jsx)(g.t,{src:O.avatar,name:O.name,size:28,color:D}),(0,S.jsx)(`span`,{className:`cs-leader-name`,children:O.name})]}),n===`course`&&k&&(0,S.jsxs)(`div`,{className:`cs-participants`,children:[(0,S.jsx)(`div`,{className:`cs-participants-avatars`,children:k.slice(0,4).map((e,t)=>(0,S.jsx)(g.t,{src:e.avatar,name:e.name,size:28,color:D,className:`cs-participant-avatar`},`${e.name}-${t}`))}),A&&(0,S.jsxs)(`span`,{className:`cs-spots`,children:[k.length,`/`,A]})]}),(0,S.jsxs)(`div`,{className:`cs-meta`,children:[n===`event`&&P&&(0,S.jsx)(d.s,{size:`xs`,color:D,children:P}),s&&(0,S.jsx)(d.s,{size:`xs`,color:D,icon:(0,S.jsx)(e.wi,{}),children:s}),n===`event`&&F&&(0,S.jsx)(d.s,{size:`xs`,color:F.toLowerCase()===`sold out`?`error`:D,children:F}),q&&n!==`event`&&(0,S.jsx)(d.s,{size:`xs`,color:c===!1?`error`:D,children:q})]})]}),(0,S.jsxs)(`div`,{className:`cs-footer`,children:[a!==void 0&&(0,S.jsxs)(`span`,{className:`cs-price`,children:[typeof a==`number`?a.toFixed(2):a,` `,(0,S.jsx)(`span`,{className:`cs-currency`,children:o})]}),(0,S.jsxs)(`div`,{className:`cs-actions`,children:[n===`product`&&w&&(0,S.jsxs)(`div`,{className:`cs-qty`,children:[(0,S.jsx)(l.t,{variant:`ghost`,iconOnly:!0,size:`sm`,onClick:()=>K(U-1),"aria-label":`Decrease`,className:`cs-qty-btn`,children:(0,S.jsx)(e.yr,{})}),(0,S.jsx)(`span`,{className:`cs-qty-value`,children:U}),(0,S.jsx)(l.t,{variant:`ghost`,iconOnly:!0,size:`sm`,onClick:()=>K(U+1),"aria-label":`Increase`,className:`cs-qty-btn`,children:(0,S.jsx)(e.br,{})})]}),w&&(0,S.jsx)(l.t,{variant:`filled`,size:`sm`,color:D,onClick:()=>w(U),disabled:c===!1,className:`cs-cart-btn`,children:T??(n===`event`?`Register`:`Add to cart`)})]})]})]})}function R(e){let{onAction:t,actionLabel:n=`Book now`,...r}=e;return(0,S.jsx)(L,{variant:`service`,onAddToCart:t?()=>t():void 0,actionLabel:n,...r})}function z(e){let{onAction:t,actionLabel:n=`Join course`,...r}=e;return(0,S.jsx)(L,{variant:`course`,onAddToCart:t?()=>t():void 0,actionLabel:n,...r})}function B({component:n,title:i,description:a,icon:o,color:s=`primary`,to:c,href:u,target:f,rel:p,onClick:h,interactive:g=!1,clickEffect:_,rippleColor:v,image:y,video:b,illustration:C,camera:w,mediaFill:T=!1,overlayPosition:E=`bottom`,favorite:D,onFavorite:O,menuItems:k,className:A,...j}){let M=(0,x.useRef)(null);(0,x.useEffect)(()=>{if(!w)return;let e=M.current;if(!e||typeof navigator>`u`||!navigator.mediaDevices?.getUserMedia)return;let t=null,n=!1,r=w===!0?{video:!0}:w;return navigator.mediaDevices.getUserMedia(r).then(r=>{if(n){r.getTracks().forEach(e=>e.stop());return}t=r,e.srcObject=r,e.play().catch(()=>void 0)}).catch(()=>void 0),()=>{n=!0,t&&t.getTracks().forEach(e=>e.stop()),e.srcObject=null}},[w]);let N=!!(y||b||C||w),{component:P,href:F,to:I,isInteractive:L,isLink:R}=d.o({component:n,href:u,to:c,interactive:g,hasClickHandler:!!h,fallbackComponent:`button`}),z=T&&N,{effectClassName:B,effectLayer:V,handlePointerDown:ee}=r.t({effect:_??(L?`ripple`:`none`),disabled:!L,color:v});function H(e){e.stopPropagation()}function U(e){h&&(e.preventDefault(),h())}function W(){return N?(0,S.jsxs)(`div`,{className:t.t(`tile-media`,z&&`fill`),children:[y&&(0,S.jsx)(`img`,{src:y,alt:i,className:`tile-image`}),b&&(0,S.jsx)(`video`,{src:b,className:`tile-video`,autoPlay:!0,muted:!0,loop:!0,playsInline:!0,"aria-label":i}),w&&(0,S.jsx)(`video`,{ref:M,className:`tile-video`,autoPlay:!0,muted:!0,playsInline:!0,"aria-label":i}),C&&(0,S.jsx)(`div`,{className:`tile-illustration`,children:C}),z&&(0,S.jsx)(`div`,{className:t.t(`tile-scrim`,`scrim-${E}`)})]}):null}function G(){return(0,S.jsxs)(`div`,{className:t.t(`tile-body`,z&&`overlay`,z&&`pos-${E}`),children:[(0,S.jsxs)(`div`,{className:`tile-top`,children:[o&&(0,S.jsx)(`span`,{className:`tile-icon`,children:o}),(0,S.jsx)(`h3`,{className:`tile-title`,children:i})]}),a&&(0,S.jsx)(`p`,{className:`tile-desc`,children:a})]})}let K=O||k&&k.length>0;return(0,S.jsxs)(`div`,{className:t.t(`card-tile`,`color-${s}`,z&&`media-fill`,L&&`interactive`,B,A),onPointerDown:ee,...j,children:[V,R&&(0,S.jsx)(P,{href:P===`a`||n?F:void 0,to:I,target:f,rel:p,className:`tile-link`,"aria-label":i,onClick:h?U:void 0}),!R&&h&&(0,S.jsx)(P,{type:`button`,className:`tile-link`,"aria-label":i,onClick:h}),W(),G(),K&&(0,S.jsxs)(`div`,{className:`tile-actions`,onClick:H,onPointerDown:H,children:[k&&k.length>0&&(0,S.jsx)(m.i,{className:`tile-menu-wrap`,trigger:(0,S.jsx)(l.t,{variant:`ghost`,iconOnly:!0,shape:`circle`,"aria-label":`More options`,className:`tile-overlay-btn`,children:(0,S.jsx)(e.sn,{})}),placement:`bottom-end`,children:k.map((e,t)=>(0,S.jsx)(m.r,{icon:e.icon,color:e.danger?`error`:void 0,label:e.label,onClick:e.onClick},t))}),O&&(0,S.jsx)(l.t,{variant:`ghost`,iconOnly:!0,shape:`circle`,onClick:O,"aria-label":D?`Remove from favorites`:`Add to favorites`,className:t.t(`tile-overlay-btn`,D&&`tile-fav-active`),children:D?(0,S.jsx)(e.pn,{}):(0,S.jsx)(e.mn,{})})]})]})}function V(e){let{addToCartLabel:t=`Add to cart`,...n}=e;return(0,S.jsx)(L,{variant:`product`,actionLabel:t,...n})}function ee(e){let{onRegister:t,registerLabel:n=`Register`,...r}=e;return(0,S.jsx)(L,{variant:`event`,onAddToCart:t?()=>t():void 0,actionLabel:n,...r})}function H(e,t){return t||(typeof e!=`number`||e===0?`neutral`:e>0?`up`:`down`)}function U(e){return typeof e==`number`&&e>0?`+${e}`:e}function W({component:n,to:i,href:a,target:o,rel:s,title:c,value:l,trend:u,trendType:f,icon:p,color:m=`primary`,helperText:h,interactive:g=!1,clickEffect:_,rippleColor:v,className:y,onPointerDown:b,...x}){let C=u!=null,w=H(u,f),T=U(u),{component:E,href:D,to:O,isInteractive:k}=d.o({component:n,href:a,to:i,interactive:g,hasClickHandler:!!x.onClick,hasPointerHandler:!!b}),{effectClassName:A,effectLayer:j,handlePointerDown:M}=r.t({effect:_??(k?`ripple`:`none`),disabled:!k,color:v});return(0,S.jsxs)(E,{href:E===`a`||n?D:void 0,to:O,target:o,rel:s,className:t.t(`card-widget`,`color-${m}`,k&&`interactive`,A,y),onPointerDown:e=>{M(e),b?.(e)},...x,children:[j,(0,S.jsxs)(`div`,{className:`cw-top`,children:[(0,S.jsxs)(`div`,{className:`cw-meta`,children:[(0,S.jsx)(`span`,{className:`cw-title`,children:c}),(0,S.jsx)(`span`,{className:`cw-value`,children:l})]}),p&&(0,S.jsx)(`span`,{className:`cw-icon`,children:p})]}),C&&(0,S.jsx)(`div`,{className:`cw-bottom`,children:(0,S.jsxs)(`span`,{className:t.t(`cw-trend`,w),children:[w===`up`&&(0,S.jsx)(e.ki,{size:14}),w===`down`&&(0,S.jsx)(e.Oi,{size:14}),(0,S.jsx)(`span`,{children:T})]})}),h&&(0,S.jsx)(`div`,{className:`cw-helper`,children:h})]})}function G(e,t){return t||(typeof e!=`number`||e===0?`neutral`:e>0?`up`:`down`)}function K(e){return typeof e==`number`&&e>0?`+${e}`:e}function q({label:n,value:r,icon:i,badge:s,helperText:c,trend:l,trendType:u,color:f=`primary`,className:p,...m}){let h=l!=null,g=G(l,u);return(0,S.jsx)(d.n,{className:t.t(`stat-card`,`color-${f}`,p),...m,children:(0,S.jsxs)(a.t,{padding:`sm`,children:[(0,S.jsxs)(a.n,{justify:`between`,align:`start`,children:[(0,S.jsxs)(a.t,{children:[(0,S.jsx)(o.t,{size:`sm`,tone:`muted`,children:n}),(0,S.jsx)(`span`,{className:`stat-card-value`,children:r})]}),(0,S.jsxs)(a.n,{align:`center`,padding:`xs`,children:[s,i&&(0,S.jsx)(`span`,{className:`stat-card-icon`,children:i})]})]}),(h||c)&&(0,S.jsxs)(a.n,{justify:`between`,align:`center`,children:[h?(0,S.jsxs)(`span`,{className:t.t(`stat-card-trend`,g),children:[g===`up`&&(0,S.jsx)(e.ki,{size:14}),g===`down`&&(0,S.jsx)(e.Oi,{size:14}),(0,S.jsx)(`span`,{children:K(l)})]}):(0,S.jsx)(`span`,{}),c&&(0,S.jsx)(o.t,{size:`sm`,tone:`muted`,children:c})]})]})})}function J(e){if(typeof e==`number`)return{gridTemplateColumns:`repeat(${e}, 1fr)`};let t={};return e.base!==void 0&&(t[`--cols-base`]=e.base),e.sm!==void 0&&(t[`--cols-sm`]=e.sm),e.md!==void 0&&(t[`--cols-md`]=e.md),e.lg!==void 0&&(t[`--cols-lg`]=e.lg),e.xl!==void 0&&(t[`--cols-xl`]=e.xl),e.xxl!==void 0&&(t[`--cols-xxl`]=e.xxl),t}function Y(e,t){let n=t.split(`.`),r=e;for(let e of n){if(typeof r!=`object`||!r)return;r=r[e]}return r}function X({items:n,renderCard:r,color:a=`primary`,searchable:o=!1,searchKeys:s,searchPlaceholder:c=`Search...`,search:d,onSearchChange:p,filterable:m=!1,filterKeys:h=[],filters:g,onFiltersChange:_,sortable:v=!1,sortKeys:y=[],defaultSort:C,sort:w,onSortChange:T,pagination:E=!1,pageSize:D=12,page:O,onPageChange:k,total:A,manualSearch:j=!1,manualFilters:M=!1,manualSort:N=!1,manualPagination:P=!1,columns:F=3,emptyMessage:I=`No results found.`,className:L,style:R,...z}){let[B,V]=(0,x.useState)(``),[ee,H]=(0,x.useState)({}),[U,W]=(0,x.useState)(C??null),[G,K]=(0,x.useState)(1),[q,X]=(0,x.useState)(!1),[te,ne]=(0,x.useState)(!1),re=(0,x.useRef)(null),ie=(0,x.useRef)(null),ae=d===void 0?B:d,Z=g===void 0?ee:g,Q=w===void 0?U:w,oe=O===void 0?G:O,se=(0,x.useCallback)(e=>{d===void 0&&V(e),!P&&O===void 0&&K(1),p?.(e)},[d,O,P,p]),ce=(0,x.useCallback)(e=>{g===void 0&&H(e),!P&&O===void 0&&K(1),_?.(e)},[g,O,P,_]),le=(0,x.useCallback)(e=>{w===void 0&&W(e),!P&&O===void 0&&K(1),T?.(e)},[w,O,P,T]),ue=(0,x.useCallback)(e=>{O===void 0&&K(e),k?.(e)},[O,k]),de=(0,x.useCallback)(()=>{X(e=>!e),ne(!1)},[]),fe=(0,x.useCallback)(()=>{ne(e=>!e),X(!1)},[]),$=(0,x.useMemo)(()=>{let e=n;if(!j&&ae&&s&&s.length>0){let t=ae.toLowerCase();e=e.filter(e=>s.some(n=>{let r=Y(e,n);return r!=null&&String(r).toLowerCase().includes(t)}))}if(!M)for(let[t,n]of Object.entries(Z))!n||n.length===0||(e=e.filter(e=>{let r=Y(e,t);return r!=null&&n.includes(String(r))}));return!N&&Q&&(e=[...e].sort((e,t)=>{let n=Y(e,Q.key),r=Y(t,Q.key);if(n==null&&r==null)return 0;if(n==null)return 1;if(r==null)return-1;let i=String(n).localeCompare(String(r),void 0,{numeric:!0});return Q.direction===`asc`?i:-i})),e===n?[...e]:e},[n,ae,s,Z,Q,j,M,N]),pe=P?A??$.length:$.length,me=(0,x.useMemo)(()=>{if(!E||P)return $;let e=(oe-1)*D;return $.slice(e,e+D)},[$,E,P,oe,D]);function he(e,t){let n=Z[e]??[],r=n.includes(t)?n.filter(e=>e!==t):[...n,t];ce({...Z,[e]:r})}let ge=(0,x.useMemo)(()=>{let e={};for(let t of h){if(t.options){e[t.key]=t.options;continue}let r=new Set;for(let e of n){let n=Y(e,t.key);n!=null&&r.add(String(n))}e[t.key]=Array.from(r).sort()}return e},[n,h]),_e=y.find(e=>e.key===Q?.key);return(0,S.jsxs)(`div`,{className:t.t(`card-grid`,`color-${a}`,L),style:R,...z,children:[(o||m||v)&&(0,S.jsxs)(`div`,{className:`card-grid-toolbar`,children:[o&&(0,S.jsx)(f.t,{className:`card-grid-search`,size:`sm`,fullWidth:!0,placeholder:c,value:ae,onChange:e=>se(e.target.value),onClear:()=>se(``)}),(0,S.jsxs)(`div`,{className:`card-grid-actions`,children:[m&&h.length>0&&(0,S.jsxs)(S.Fragment,{children:[(0,S.jsx)(l.t,{ref:re,variant:`outlined`,color:a,size:`sm`,startIcon:(0,S.jsx)(e.an,{}),"aria-expanded":q,onClick:de,children:`Filter`}),(0,S.jsx)(i.t,{open:q,anchorRef:re,onClose:()=>X(!1),placement:`bottom-end`,className:`card-grid-dropdown`,children:h.map(e=>(0,S.jsxs)(`div`,{className:`card-grid-filter-group`,children:[(0,S.jsx)(`span`,{className:`card-grid-filter-label`,children:e.label}),(ge[e.key]??[]).map(t=>(0,S.jsx)(`div`,{className:`card-grid-filter-option`,children:(0,S.jsx)(u.t,{size:`sm`,clickEffect:`none`,checked:Z[e.key]?.includes(t)??!1,onChange:()=>he(e.key,t),label:t})},t))]},e.key))})]}),v&&y.length>0&&(0,S.jsxs)(S.Fragment,{children:[(0,S.jsx)(l.t,{ref:ie,variant:`outlined`,color:a,size:`sm`,startIcon:Q?Q.direction===`asc`?(0,S.jsx)(e.ki,{}):(0,S.jsx)(e.Oi,{}):(0,S.jsx)(e.in,{}),"aria-expanded":te,onClick:fe,children:_e?`Sort: ${_e.label}`:`Sort`}),(0,S.jsx)(i.t,{open:te,anchorRef:ie,onClose:()=>ne(!1),placement:`bottom-end`,className:`card-grid-dropdown`,children:y.map(n=>(0,S.jsxs)(`button`,{type:`button`,className:t.t(`card-grid-sort-item`,Q?.key===n.key&&`active`),onClick:()=>{Q?.key===n.key?le({key:n.key,direction:Q.direction===`asc`?`desc`:`asc`}):le({key:n.key,direction:`asc`})},children:[n.label,Q?.key===n.key&&(0,S.jsx)(`span`,{className:`card-grid-sort-dir`,children:Q.direction===`asc`?(0,S.jsx)(e.ki,{className:`card-grid-sort-icon`}):(0,S.jsx)(e.Oi,{className:`card-grid-sort-icon`})})]},n.key))})]})]})]}),me.length>0?(0,S.jsx)(`div`,{className:`card-grid-items`,style:J(F),children:me.map((e,t)=>{let n=e?.id;return(0,S.jsx)(x.Fragment,{children:r(e,t)},n??t)})}):(0,S.jsx)(`div`,{className:`card-grid-empty`,children:I}),E&&pe>D&&(0,S.jsx)(`div`,{className:`card-grid-pagination`,children:(0,S.jsx)(b.t,{total:pe,page:oe,pageSize:D,onChange:ue})})]})}function te(e,t){return t||(e===void 0||e===0?`neutral`:e>0?`up`:`down`)}function ne({component:n,to:i,href:a,target:o,rel:s,label:c,value:l,change:u,changeType:f,changeLabel:p,icon:m,sparkline:h,sparklineType:g=`area`,color:v=`primary`,currency:y,interactive:b=!1,clickEffect:x,rippleColor:C,className:w,onPointerDown:T,...E}){let D=te(u,f),O=D===`up`?`success`:D===`down`?`error`:`neutral`,{component:k,href:A,to:j,isInteractive:M}=d.o({component:n,href:a,to:i,interactive:b,hasClickHandler:!!E.onClick,hasPointerHandler:!!T}),{effectClassName:N,effectLayer:P,handlePointerDown:F}=r.t({effect:x??(M?`ripple`:`none`),disabled:!M,color:C});return(0,S.jsxs)(k,{href:k===`a`||n?A:void 0,to:j,target:o,rel:s,className:t.t(`card-finance`,`color-${v}`,M&&`interactive`,N,w),onPointerDown:e=>{F(e),T?.(e)},...E,children:[P,(0,S.jsxs)(`div`,{className:`cf-top`,children:[(0,S.jsxs)(`div`,{className:`cf-meta`,children:[(0,S.jsx)(`span`,{className:`cf-label`,children:c}),y&&(0,S.jsx)(`span`,{className:`cf-currency`,children:y})]}),m&&(0,S.jsx)(`span`,{className:`cf-icon`,children:m})]}),(0,S.jsx)(`div`,{className:`cf-value`,children:l}),(0,S.jsx)(`div`,{className:`cf-bottom`,children:u!==void 0&&(0,S.jsxs)(`span`,{className:t.t(`cf-change`,O),children:[D===`up`&&(0,S.jsx)(e.ki,{size:14}),D===`down`&&(0,S.jsx)(e.Oi,{size:14}),(0,S.jsxs)(`span`,{className:`cf-change-value`,children:[u>0?`+`:``,u,`%`]}),p&&(0,S.jsx)(`span`,{className:`cf-change-label`,children:p})]})}),(0,S.jsx)(`div`,{className:`cf-sparkline`,children:(0,S.jsx)(_.n,{data:h,type:g,color:O===`neutral`?v:O,height:46,padding:0,curved:!0,animated:!0,fillOpacity:.18})})]})}function re({title:e=`Today`,description:t,color:n=`primary`,workdayStart:r,workdayEnd:i,timeline:c,summary:l,tabs:u=[],footer:f,emptyTimeline:p=(0,S.jsx)(o.t,{tone:`muted`,children:`No events scheduled for this day.`}),...m}){let g=r&&i?`${r}-${i}`:r??i??void 0,_=u.filter(e=>e.items.length>0);return(0,S.jsxs)(d.n,{color:n,...m,children:[(0,S.jsx)(d.a,{children:(0,S.jsxs)(a.t,{children:[(0,S.jsx)(s.t,{level:4,children:e}),(t||g)&&(0,S.jsxs)(o.t,{size:`sm`,tone:`muted`,children:[t,t&&g?` `:null,g]})]})}),(0,S.jsx)(d.r,{children:(0,S.jsxs)(y.t,{type:`row`,align:`start`,children:[(0,S.jsx)(y.t,{type:`col`,xl:7,sm:12,children:c.length?(0,S.jsx)(a.t,{className:`day-schedule-card-timeline`,children:c.map(e=>(0,S.jsxs)(a.n,{align:`start`,className:`day-schedule-card-entry`,children:[(0,S.jsx)(`span`,{className:`day-schedule-card-time`,children:e.time}),(0,S.jsx)(`div`,{className:`day-schedule-card-dot`,"data-color":e.color??n,children:T(e.icon,e.color??n)}),(0,S.jsxs)(`div`,{className:`day-schedule-card-copy`,children:[(0,S.jsx)(o.t,{as:`strong`,children:e.title}),e.description&&(0,S.jsx)(o.t,{size:`sm`,tone:`muted`,children:e.description})]})]},e.id))}):p}),(0,S.jsx)(y.t,{type:`col`,xl:5,sm:12,children:(0,S.jsxs)(a.t,{className:`day-schedule-card-side`,children:[l,_.length>0&&(0,S.jsx)(v.t,{variant:`underline`,size:`sm`,fullWidth:!0,defaultValue:_[0].type,items:_.map(e=>({value:e.type,label:(0,S.jsxs)(`span`,{className:`day-schedule-card-tab-label`,children:[(0,S.jsx)(`span`,{children:e.title}),(0,S.jsx)(`span`,{className:`day-schedule-card-tab-count`,children:e.items.length})]}),content:(0,S.jsx)(h.n,{items:e.items})}))})]})})]})}),f&&(0,S.jsx)(d.i,{children:T(f,n)})]})}function ie({title:t=`Documents`,description:n,color:r=`primary`,items:i,selected:c,onSelect:u,defaultExpanded:f,expanded:p,onExpandChange:g,detailsTitle:v,detailsMeta:b,detailsItems:x=[],detailsActions:C=[],renderDetails:w,emptyDetails:E=(0,S.jsx)(o.t,{tone:`muted`,children:`Select a document to inspect its details.`}),primaryAction:D,...O}){let k=e=>({...e,icon:T(e.icon,r),children:e.children?.map(k)}),A=i.map(k);return(0,S.jsxs)(d.n,{stretch:!1,color:r,...O,children:[(0,S.jsx)(d.a,{children:(0,S.jsxs)(a.n,{justify:`between`,align:`center`,children:[(0,S.jsxs)(a.t,{children:[(0,S.jsx)(s.t,{level:4,children:t}),n&&(0,S.jsx)(o.t,{size:`sm`,tone:`muted`,children:n})]}),T(D,r)]})}),(0,S.jsx)(d.r,{children:(0,S.jsxs)(y.t,{type:`row`,align:`start`,children:[(0,S.jsx)(y.t,{type:`col`,xl:7,sm:12,children:(0,S.jsx)(_.t,{items:A,color:r,defaultExpanded:f,expanded:p,onExpandChange:g,selected:c,onSelect:u,expandable:!0,selectable:!0,showLines:!0,fileIcons:!0})}),(0,S.jsx)(y.t,{type:`col`,xl:5,sm:12,children:(0,S.jsxs)(a.t,{padding:`sm`,children:[(v||b||C.length>0)&&(0,S.jsxs)(a.n,{justify:`between`,align:`start`,children:[(0,S.jsxs)(a.t,{children:[v&&(0,S.jsx)(s.t,{level:5,children:v}),b&&(0,S.jsx)(o.t,{size:`sm`,tone:`muted`,children:b})]}),C.length>0&&(0,S.jsx)(m.i,{placement:`bottom-end`,trigger:(0,S.jsx)(l.t,{variant:`ghost`,color:r,iconOnly:!0,shape:`circle`,"aria-label":`Open document actions`,children:(0,S.jsx)(e.sn,{})}),children:C.map(e=>(0,S.jsx)(m.r,{icon:T(e.icon,e.color??r),label:e.label,color:e.color??r,disabled:e.disabled,component:e.component,href:e.href,to:e.to,onClick:e.onClick},e.id))})]}),w||(x.length?(0,S.jsx)(h.n,{items:x}):E)]})})]})})]})}Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return q}}),Object.defineProperty(exports,`c`,{enumerable:!0,get:function(){return V}}),Object.defineProperty(exports,`d`,{enumerable:!0,get:function(){return R}}),Object.defineProperty(exports,`f`,{enumerable:!0,get:function(){return I}}),Object.defineProperty(exports,`h`,{enumerable:!0,get:function(){return E}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return X}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return B}}),Object.defineProperty(exports,`m`,{enumerable:!0,get:function(){return O}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return re}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return W}}),Object.defineProperty(exports,`p`,{enumerable:!0,get:function(){return A}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return ne}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return ee}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return ie}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return z}});
2
+ //# sourceMappingURL=cards-Ci1FoV9C.cjs.map