@banzamel/mineralui 1.6.4 → 1.8.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.
- package/README.md +1 -1
- package/dist/{MAvatar-BHASnoyu.js → MAvatar-BcayQCnp.js} +2 -2
- package/dist/{MAvatar-BHASnoyu.js.map → MAvatar-BcayQCnp.js.map} +1 -1
- package/dist/{MAvatar-BVJh6kgW.cjs → MAvatar-BgevCYi3.cjs} +2 -2
- package/dist/{MAvatar-BVJh6kgW.cjs.map → MAvatar-BgevCYi3.cjs.map} +1 -1
- package/dist/MButton-8UCydOik.cjs +2 -0
- package/dist/MButton-8UCydOik.cjs.map +1 -0
- package/dist/{MButton-y9qXhhGt.js → MButton-DZLLrtQb.js} +38 -36
- package/dist/MButton-DZLLrtQb.js.map +1 -0
- package/dist/{MCheckbox-B-nT2OBE.js → MCheckbox-B7SpcD4H.js} +1 -1
- package/dist/{MCheckbox-B-nT2OBE.js.map → MCheckbox-B7SpcD4H.js.map} +1 -1
- package/dist/{MCheckbox-C40ESQRe.cjs → MCheckbox-Dn3p_9-1.cjs} +2 -2
- package/dist/{MCheckbox-C40ESQRe.cjs.map → MCheckbox-Dn3p_9-1.cjs.map} +1 -1
- package/dist/{MCookieBootstrap-3-wyz3Dk.cjs → MCookieBootstrap-BUqtJO3m.cjs} +1 -1
- package/dist/{MCookieBootstrap-3-wyz3Dk.cjs.map → MCookieBootstrap-BUqtJO3m.cjs.map} +1 -1
- package/dist/{MCookieBootstrap-CGvYxIK8.js → MCookieBootstrap-Btt49Iuq.js} +1 -1
- package/dist/{MCookieBootstrap-CGvYxIK8.js.map → MCookieBootstrap-Btt49Iuq.js.map} +1 -1
- package/dist/MDataTable-95_Mb6jE.cjs +2 -0
- package/dist/MDataTable-95_Mb6jE.cjs.map +1 -0
- package/dist/MDataTable-DxDS5auV.js +297 -0
- package/dist/MDataTable-DxDS5auV.js.map +1 -0
- package/dist/{MDrawer-W2WQs1sM.js → MDrawer-CXNHYwPO.js} +2 -2
- package/dist/{MDrawer-W2WQs1sM.js.map → MDrawer-CXNHYwPO.js.map} +1 -1
- package/dist/{MDrawer-DFkrFrnD.cjs → MDrawer-DzqtHVeA.cjs} +2 -2
- package/dist/{MDrawer-DFkrFrnD.cjs.map → MDrawer-DzqtHVeA.cjs.map} +1 -1
- package/dist/{MDropdownMenu-D79Cm5aS.js → MDropdownMenu-CeiC1tz3.js} +5 -5
- package/dist/MDropdownMenu-CeiC1tz3.js.map +1 -0
- package/dist/MDropdownMenu-c9U3sEcl.cjs +2 -0
- package/dist/MDropdownMenu-c9U3sEcl.cjs.map +1 -0
- package/dist/{MGalleryIllustration-BB3DoCl_.cjs → MGalleryIllustration-Dglx_Ckc.cjs} +2 -2
- package/dist/{MGalleryIllustration-BB3DoCl_.cjs.map → MGalleryIllustration-Dglx_Ckc.cjs.map} +1 -1
- package/dist/MGrid-C4kPZDSa.cjs +2 -0
- package/dist/MGrid-C4kPZDSa.cjs.map +1 -0
- package/dist/MGrid-DR0fHItF.js +182 -0
- package/dist/MGrid-DR0fHItF.js.map +1 -0
- package/dist/{MHeading-BhCNoJeW.cjs → MHeading-CKe5lcM_.cjs} +2 -2
- package/dist/{MHeading-BhCNoJeW.cjs.map → MHeading-CKe5lcM_.cjs.map} +1 -1
- package/dist/{MI18nProvider-B2sE0x5D.cjs → MI18nProvider-DOh5xexz.cjs} +2 -2
- package/dist/{MI18nProvider-B2sE0x5D.cjs.map → MI18nProvider-DOh5xexz.cjs.map} +1 -1
- package/dist/MImage-BZ6SrSao.cjs +2 -0
- package/dist/MImage-BZ6SrSao.cjs.map +1 -0
- package/dist/{MImage-BKX-xBm3.js → MImage-Btx_7g2Z.js} +5 -6
- package/dist/MImage-Btx_7g2Z.js.map +1 -0
- package/dist/{MInput-bzSwK880.js → MInput-7i0Dy1t4.js} +3 -2
- package/dist/{MInput-bzSwK880.js.map → MInput-7i0Dy1t4.js.map} +1 -1
- package/dist/{MInput-DYqV3-rQ.cjs → MInput-D_zaoWwX.cjs} +2 -2
- package/dist/{MInput-DYqV3-rQ.cjs.map → MInput-D_zaoWwX.cjs.map} +1 -1
- package/dist/MInputExpDate-DWWwjMYK.cjs +2 -0
- package/dist/MInputExpDate-DWWwjMYK.cjs.map +1 -0
- package/dist/{MInputCVC-BHpMHTO5.js → MInputExpDate-DhO5zN7L.js} +97 -97
- package/dist/MInputExpDate-DhO5zN7L.js.map +1 -0
- package/dist/{MInputSearch-Dh4C3Tz5.js → MInputSearch-CmzHPnmC.js} +2 -2
- package/dist/{MInputSearch-Dh4C3Tz5.js.map → MInputSearch-CmzHPnmC.js.map} +1 -1
- package/dist/{MInputSearch-DfoenJIm.cjs → MInputSearch-DpHSVpmL.cjs} +2 -2
- package/dist/{MInputSearch-DfoenJIm.cjs.map → MInputSearch-DpHSVpmL.cjs.map} +1 -1
- package/dist/MKbd-DWTS3iS5.cjs +2 -0
- package/dist/MKbd-DWTS3iS5.cjs.map +1 -0
- package/dist/MKbd-v6-tJ9sP.js +14 -0
- package/dist/MKbd-v6-tJ9sP.js.map +1 -0
- package/dist/{MLink-CY45UR_j.cjs → MLink-B3ImjkJV.cjs} +2 -2
- package/dist/{MLink-CY45UR_j.cjs.map → MLink-B3ImjkJV.cjs.map} +1 -1
- package/dist/{MModal-DT5BBgNZ.cjs → MModal-CP0e31pv.cjs} +2 -2
- package/dist/{MModal-DT5BBgNZ.cjs.map → MModal-CP0e31pv.cjs.map} +1 -1
- package/dist/{MModal-BDTAgnrm.js → MModal-DGmeQlWo.js} +2 -2
- package/dist/{MModal-BDTAgnrm.js.map → MModal-DGmeQlWo.js.map} +1 -1
- package/dist/{MPagination-CZEJMJzZ.cjs → MPagination-CS62B9kZ.cjs} +2 -2
- package/dist/{MPagination-CZEJMJzZ.cjs.map → MPagination-CS62B9kZ.cjs.map} +1 -1
- package/dist/{MPagination-CTnaW5AW.js → MPagination-Dr110are.js} +2 -2
- package/dist/{MPagination-CTnaW5AW.js.map → MPagination-Dr110are.js.map} +1 -1
- package/dist/{MPopover-B4IUb9f0.cjs → MPopover-CxxaY9kr.cjs} +2 -2
- package/dist/{MPopover-B4IUb9f0.cjs.map → MPopover-CxxaY9kr.cjs.map} +1 -1
- package/dist/{MPortal-Bi24xTGW.cjs → MPortal-BIxPtFYd.cjs} +2 -2
- package/dist/{MPortal-Bi24xTGW.cjs.map → MPortal-BIxPtFYd.cjs.map} +1 -1
- package/dist/{MQrCode-CCtTkkv9.js → MQrCode-6ANDcExA.js} +150 -100
- package/dist/MQrCode-6ANDcExA.js.map +1 -0
- package/dist/MQrCode-B0-Np-N3.cjs +2 -0
- package/dist/MQrCode-B0-Np-N3.cjs.map +1 -0
- package/dist/MSimpleGrid-Bojj4xKH.js +18 -0
- package/dist/MSimpleGrid-Bojj4xKH.js.map +1 -0
- package/dist/MSimpleGrid-CyLf-9R2.cjs +2 -0
- package/dist/MSimpleGrid-CyLf-9R2.cjs.map +1 -0
- package/dist/MSkeleton-BdwhPx-k.cjs +2 -0
- package/dist/MSkeleton-BdwhPx-k.cjs.map +1 -0
- package/dist/MSkeleton-BvXgnYs_.js +136 -0
- package/dist/MSkeleton-BvXgnYs_.js.map +1 -0
- package/dist/{MSlider-5141rKeH.js → MSlider-CqrusKJQ.js} +1 -1
- package/dist/{MSlider-5141rKeH.js.map → MSlider-CqrusKJQ.js.map} +1 -1
- package/dist/{MSlider-Ch3VjAJC.cjs → MSlider-qCGmD4UA.cjs} +2 -2
- package/dist/{MSlider-Ch3VjAJC.cjs.map → MSlider-qCGmD4UA.cjs.map} +1 -1
- package/dist/MStack-ByFYGSsy.cjs +2 -0
- package/dist/MStack-ByFYGSsy.cjs.map +1 -0
- package/dist/MStack-DFIc3S4_.js +70 -0
- package/dist/MStack-DFIc3S4_.js.map +1 -0
- package/dist/{MSubText-C-70zn0m.cjs → MSubText-1ilKSz8e.cjs} +2 -2
- package/dist/{MSubText-C-70zn0m.cjs.map → MSubText-1ilKSz8e.cjs.map} +1 -1
- package/dist/MSurface-CmVIQC1A.js +43 -0
- package/dist/MSurface-CmVIQC1A.js.map +1 -0
- package/dist/MSurface-CpAuwpHv.cjs +2 -0
- package/dist/MSurface-CpAuwpHv.cjs.map +1 -0
- package/dist/MTabs-BQZ--mMq.js +89 -0
- package/dist/MTabs-BQZ--mMq.js.map +1 -0
- package/dist/MTabs-DeUn6bIp.cjs +2 -0
- package/dist/MTabs-DeUn6bIp.cjs.map +1 -0
- package/dist/{MTag-CH5nMbm7.js → MTag-C4SUJly2.js} +2 -2
- package/dist/{MTag-CH5nMbm7.js.map → MTag-C4SUJly2.js.map} +1 -1
- package/dist/{MTag-Y4Tswmli.cjs → MTag-DwQ-j1sV.cjs} +2 -2
- package/dist/{MTag-Y4Tswmli.cjs.map → MTag-DwQ-j1sV.cjs.map} +1 -1
- package/dist/{MText-DEJddMB5.cjs → MText-D0fI_D_Q.cjs} +2 -2
- package/dist/{MText-DEJddMB5.cjs.map → MText-D0fI_D_Q.cjs.map} +1 -1
- package/dist/{MTimeAgo-DxZGVo2Y.cjs → MTimeAgo-DI3DF7bD.cjs} +2 -2
- package/dist/{MTimeAgo-DxZGVo2Y.cjs.map → MTimeAgo-DI3DF7bD.cjs.map} +1 -1
- package/dist/{MTimeAgo-C4p80NvI.js → MTimeAgo-Db8gOade.js} +2 -2
- package/dist/{MTimeAgo-C4p80NvI.js.map → MTimeAgo-Db8gOade.js.map} +1 -1
- package/dist/{MToggle-Dt1Ctr5e.js → MToggle-B6emKoKq.js} +1 -1
- package/dist/{MToggle-Dt1Ctr5e.js.map → MToggle-B6emKoKq.js.map} +1 -1
- package/dist/{MToggle-C8vYRzpC.cjs → MToggle-BVJm5Bdk.cjs} +2 -2
- package/dist/{MToggle-C8vYRzpC.cjs.map → MToggle-BVJm5Bdk.cjs.map} +1 -1
- package/dist/{MTooltip-kSTMMpvu.cjs → MTooltip-Dq2vYf3G.cjs} +2 -2
- package/dist/{MTooltip-kSTMMpvu.cjs.map → MTooltip-Dq2vYf3G.cjs.map} +1 -1
- package/dist/{MTooltip-C43aUKMP.js → MTooltip-jSf4VBtB.js} +1 -1
- package/dist/{MTooltip-C43aUKMP.js.map → MTooltip-jSf4VBtB.js.map} +1 -1
- package/dist/MTreeView-AqH8XMPz.js +516 -0
- package/dist/MTreeView-AqH8XMPz.js.map +1 -0
- package/dist/MTreeView-Dp9qbqQh.cjs +2 -0
- package/dist/MTreeView-Dp9qbqQh.cjs.map +1 -0
- package/dist/{arduino-CXUo7Bjy.cjs → arduino-Bm509TuR.cjs} +1 -1
- package/dist/{arduino-CXUo7Bjy.cjs.map → arduino-Bm509TuR.cjs.map} +1 -1
- package/dist/{arduino-Eif5KI8O.js → arduino-C5s1z3P1.js} +1 -1
- package/dist/{arduino-Eif5KI8O.js.map → arduino-C5s1z3P1.js.map} +1 -1
- package/dist/{bash-W4h3o_nx.cjs → bash-CyBbinAU.cjs} +1 -1
- package/dist/{bash-W4h3o_nx.cjs.map → bash-CyBbinAU.cjs.map} +1 -1
- package/dist/{bash-CCF_TYbb.js → bash-RIFbRcCe.js} +1 -1
- package/dist/{bash-CCF_TYbb.js.map → bash-RIFbRcCe.js.map} +1 -1
- package/dist/{c-DVgkp6T3.js → c-DAywn1DE.js} +1 -1
- package/dist/{c-DVgkp6T3.js.map → c-DAywn1DE.js.map} +1 -1
- package/dist/{c-Dm60JY-W.cjs → c-DGOxo0dj.cjs} +1 -1
- package/dist/{c-Dm60JY-W.cjs.map → c-DGOxo0dj.cjs.map} +1 -1
- package/dist/cards-B9g6Lf1n.cjs +2 -0
- package/dist/cards-B9g6Lf1n.cjs.map +1 -0
- package/dist/cards-D7oHIHmU.js +1535 -0
- package/dist/cards-D7oHIHmU.js.map +1 -0
- package/dist/cards.cjs +1 -1
- package/dist/cards.js +3 -3
- package/dist/components/cards/MCard/MCard.d.ts +1 -1
- package/dist/components/cards/MCard/MCard.types.d.ts +2 -5
- package/dist/components/cards/MCardActionArea/MCardActionArea.d.ts +2 -0
- package/dist/components/cards/MCardActionArea/MCardActionArea.types.d.ts +7 -0
- package/dist/components/cards/MCardActionArea/index.d.ts +2 -0
- package/dist/components/cards/MCardDaySchedule/MCardDaySchedule.d.ts +2 -0
- package/dist/components/cards/MCardDaySchedule/MCardDaySchedule.types.d.ts +41 -0
- package/dist/components/cards/MCardDaySchedule/index.d.ts +2 -0
- package/dist/components/cards/MCardDocumentTree/MCardDocumentTree.d.ts +2 -0
- package/dist/components/cards/MCardDocumentTree/MCardDocumentTree.types.d.ts +31 -0
- package/dist/components/cards/MCardDocumentTree/index.d.ts +2 -0
- package/dist/components/cards/MCardFinance/MCardFinance.d.ts +1 -1
- package/dist/components/cards/MCardFinance/MCardFinance.types.d.ts +2 -1
- package/dist/components/cards/MCardGrid/MCardGrid.d.ts +1 -1
- package/dist/components/cards/MCardGrid/MCardGrid.types.d.ts +23 -5
- package/dist/components/cards/MCardPayment/MCardPayment.d.ts +1 -1
- package/dist/components/cards/MCardPayment/MCardPayment.types.d.ts +2 -1
- package/dist/components/cards/MCardTile/MCardTile.d.ts +2 -0
- package/dist/components/cards/MCardTile/MCardTile.types.d.ts +26 -0
- package/dist/components/cards/MCardTile/index.d.ts +2 -0
- package/dist/components/cards/MCardWidget/MCardWidget.d.ts +1 -1
- package/dist/components/cards/MCardWidget/MCardWidget.types.d.ts +2 -1
- package/dist/components/cards/MStatCard/MStatCard.d.ts +3 -0
- package/dist/components/cards/MStatCard/MStatCard.types.d.ts +16 -0
- package/dist/components/cards/MStatCard/index.d.ts +2 -0
- package/dist/components/cards/ServiceCardsShared/ServiceCardsShared.d.ts +1 -1
- package/dist/components/cards/ServiceCardsShared/ServiceCardsShared.types.d.ts +1 -3
- package/dist/components/cards/index.d.ts +12 -0
- package/dist/components/cards/shared/MCardAction.types.d.ts +12 -0
- package/dist/components/cards/shared/MCardAction.utils.d.ts +16 -0
- package/dist/components/cards/shared/MCardColor.utils.d.ts +3 -0
- package/dist/components/cards/shared/index.d.ts +3 -0
- package/dist/components/controls/MButton/MButton.types.d.ts +2 -0
- package/dist/components/controls/MQuickActions/MQuickActions.d.ts +2 -0
- package/dist/components/controls/MQuickActions/MQuickActions.types.d.ts +33 -0
- package/dist/components/controls/MQuickActions/index.d.ts +2 -0
- package/dist/components/controls/index.d.ts +2 -0
- package/dist/components/data/MCalendarBoard/MCalendarBoard.d.ts +8 -7
- package/dist/components/data/MCalendarBoard/MCalendarBoard.types.d.ts +75 -6
- package/dist/components/data/MCalendarBoard/index.d.ts +2 -2
- package/dist/components/data/MDataTable/MDataTable.d.ts +1 -1
- package/dist/components/data/MDataTable/MDataTable.types.d.ts +23 -0
- package/dist/components/data/MTreeView/MTreeView.d.ts +1 -1
- package/dist/components/data/MTreeView/MTreeView.types.d.ts +11 -1
- package/dist/components/data/index.d.ts +2 -2
- package/dist/components/display/MBlur/MBlur.d.ts +2 -0
- package/dist/components/display/MBlur/MBlur.types.d.ts +13 -0
- package/dist/components/display/MBlur/index.d.ts +2 -0
- package/dist/components/display/MDetailList/MDetailList.d.ts +2 -0
- package/dist/components/display/MDetailList/MDetailList.types.d.ts +20 -0
- package/dist/components/display/MDetailList/index.d.ts +2 -0
- package/dist/components/display/index.d.ts +4 -0
- package/dist/components/inputs/MInputIBAN/MInputIBAN.types.d.ts +3 -3
- package/dist/components/inputs/MInputPhone/MInputPhone.types.d.ts +2 -0
- package/dist/components/layout/MAppMenu/MAppMenu.d.ts +2 -0
- package/dist/components/layout/MAppMenu/MAppMenu.types.d.ts +63 -0
- package/dist/components/layout/MAppMenu/index.d.ts +2 -0
- package/dist/components/layout/MGrid/MGrid.d.ts +2 -2
- package/dist/components/layout/MGrid/MGrid.types.d.ts +2 -0
- package/dist/components/layout/MInline/MInline.d.ts +1 -1
- package/dist/components/layout/MInline/MInline.types.d.ts +1 -1
- package/dist/components/layout/MSidebar/MSidebar.d.ts +1 -1
- package/dist/components/layout/MSidebar/MSidebar.types.d.ts +7 -0
- package/dist/components/layout/MStatGrid/MStatGrid.d.ts +2 -0
- package/dist/components/layout/MStatGrid/MStatGrid.types.d.ts +9 -0
- package/dist/components/layout/MStatGrid/index.d.ts +2 -0
- package/dist/components/layout/MSurface/MSurface.d.ts +1 -1
- package/dist/components/layout/MSurface/MSurface.types.d.ts +6 -1
- package/dist/components/layout/index.d.ts +6 -0
- package/dist/components/media/MGallery/MGallery.types.d.ts +5 -0
- package/dist/components/media/MMediaLightbox/MMediaLightbox.d.ts +1 -1
- package/dist/components/overlays/MCommandPalette/MCommandPalette.d.ts +2 -0
- package/dist/components/overlays/MCommandPalette/MCommandPalette.types.d.ts +35 -0
- package/dist/components/overlays/MCommandPalette/index.d.ts +2 -0
- package/dist/components/overlays/MTooltip/MTooltip.types.d.ts +2 -2
- package/dist/components/overlays/index.d.ts +2 -0
- package/dist/components/typography/MHeading/MHeading.d.ts +3 -3
- package/dist/{controls-DCtMOoQe.js → controls-BczTk73I.js} +141 -100
- package/dist/controls-BczTk73I.js.map +1 -0
- package/dist/controls-BfV0vxeJ.cjs +2 -0
- package/dist/controls-BfV0vxeJ.cjs.map +1 -0
- package/dist/controls.cjs +1 -1
- package/dist/controls.js +6 -6
- package/dist/cookie-consent-bootstrap.cjs +1 -1
- package/dist/cookie-consent-bootstrap.js +1 -1
- package/dist/{core-CB9-PTLK.js → core-BUYr52VU.js} +1 -1
- package/dist/{core-CB9-PTLK.js.map → core-BUYr52VU.js.map} +1 -1
- package/dist/{core-AKWkE8Bx.cjs → core-DAox0BHy.cjs} +1 -1
- package/dist/{core-AKWkE8Bx.cjs.map → core-DAox0BHy.cjs.map} +1 -1
- package/dist/{cpp-DyKt1H8n.cjs → cpp-D-FtdQo9.cjs} +1 -1
- package/dist/{cpp-DyKt1H8n.cjs.map → cpp-D-FtdQo9.cjs.map} +1 -1
- package/dist/{cpp-OOenfB17.js → cpp-Y9cHXDal.js} +1 -1
- package/dist/{cpp-OOenfB17.js.map → cpp-Y9cHXDal.js.map} +1 -1
- package/dist/creditCards-D_HwRUBz.cjs +2 -0
- package/dist/creditCards-D_HwRUBz.cjs.map +1 -0
- package/dist/{creditCards-CCysEwry.js → creditCards-D_iWmtG6.js} +14 -8
- package/dist/creditCards-D_iWmtG6.js.map +1 -0
- package/dist/{css-u5LSEAra.js → css-C__ffGj6.js} +1 -1
- package/dist/{css-u5LSEAra.js.map → css-C__ffGj6.js.map} +1 -1
- package/dist/{css-DxVbPJLu.cjs → css-DCYZ-Rs6.cjs} +1 -1
- package/dist/{css-DxVbPJLu.cjs.map → css-DCYZ-Rs6.cjs.map} +1 -1
- package/dist/data-7kG1MC1Z.cjs +2 -0
- package/dist/data-7kG1MC1Z.cjs.map +1 -0
- package/dist/{data-BiwK5rfx.js → data-z3e8XTSt.js} +1039 -874
- package/dist/data-z3e8XTSt.js.map +1 -0
- package/dist/data.cjs +1 -1
- package/dist/data.js +4 -4
- package/dist/display-Cw3-bTsm.cjs +3 -0
- package/dist/display-Cw3-bTsm.cjs.map +1 -0
- package/dist/{display-Zxj9YHu_.js → display-DyC7084n.js} +68 -41
- package/dist/display-DyC7084n.js.map +1 -0
- package/dist/display.cjs +1 -1
- package/dist/display.js +4 -4
- package/dist/dropdowns-6eO0b6eI.cjs +2 -0
- package/dist/dropdowns-6eO0b6eI.cjs.map +1 -0
- package/dist/{dropdowns-Bw8obCYl.js → dropdowns-zXgrjNXZ.js} +586 -559
- package/dist/dropdowns-zXgrjNXZ.js.map +1 -0
- package/dist/dropdowns.cjs +1 -1
- package/dist/dropdowns.js +1 -1
- package/dist/feedback-BvRmoSzV.cjs +2 -0
- package/dist/{feedback-Di0SEpRe.cjs.map → feedback-BvRmoSzV.cjs.map} +1 -1
- package/dist/{feedback-8H3bmQw5.js → feedback-DfBjzJAw.js} +299 -300
- package/dist/{feedback-8H3bmQw5.js.map → feedback-DfBjzJAw.js.map} +1 -1
- package/dist/feedback.cjs +1 -1
- package/dist/feedback.js +6 -7
- package/dist/{form-JHlvtP9r.js → form-BiPQ8SRK.js} +2 -2
- package/dist/{form-JHlvtP9r.js.map → form-BiPQ8SRK.js.map} +1 -1
- package/dist/{form-BYz99Py5.cjs → form-DlXWN2ul.cjs} +2 -2
- package/dist/{form-BYz99Py5.cjs.map → form-DlXWN2ul.cjs.map} +1 -1
- package/dist/form.cjs +1 -1
- package/dist/form.js +1 -1
- package/dist/frameworkTexts-BLJcGUXz.cjs +2 -0
- package/dist/frameworkTexts-BLJcGUXz.cjs.map +1 -0
- package/dist/{frameworkTexts-CvxcWRXp.js → frameworkTexts-BTFyhWFD.js} +3 -1
- package/dist/frameworkTexts-BTFyhWFD.js.map +1 -0
- package/dist/i18n/frameworkTexts.d.ts +2 -0
- package/dist/i18n.cjs +1 -1
- package/dist/icons-CfpYxnfg.js.map +1 -1
- package/dist/{icons-DWMgDKgt.cjs → icons-qCoE70hn.cjs} +2 -2
- package/dist/{icons-DWMgDKgt.cjs.map → icons-qCoE70hn.cjs.map} +1 -1
- package/dist/icons.cjs +1 -1
- package/dist/illustrations.cjs +1 -1
- package/dist/index.cjs +2 -1
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +88 -53
- package/dist/index.js.map +1 -0
- package/dist/inputs-C1I1SLZ8.cjs +2 -0
- package/dist/inputs-C1I1SLZ8.cjs.map +1 -0
- package/dist/{inputs-Bcwd_UTr.js → inputs-Dy1WurNK.js} +556 -441
- package/dist/inputs-Dy1WurNK.js.map +1 -0
- package/dist/inputs.cjs +1 -1
- package/dist/inputs.js +5 -5
- package/dist/{javascript-CXjsxb-I.js → javascript-ClV78Svx.js} +1 -1
- package/dist/{javascript-CXjsxb-I.js.map → javascript-ClV78Svx.js.map} +1 -1
- package/dist/{javascript-CzjCTQxn.cjs → javascript-_Sr9cnsG.cjs} +1 -1
- package/dist/{javascript-CzjCTQxn.cjs.map → javascript-_Sr9cnsG.cjs.map} +1 -1
- package/dist/{json-9Qq5guN0.cjs → json-BFetU4Pi.cjs} +1 -1
- package/dist/{json-9Qq5guN0.cjs.map → json-BFetU4Pi.cjs.map} +1 -1
- package/dist/{json-CyV5VF8D.js → json-Dz6EkGZR.js} +1 -1
- package/dist/{json-CyV5VF8D.js.map → json-Dz6EkGZR.js.map} +1 -1
- package/dist/layout-D1-mF4xn.js +772 -0
- package/dist/layout-D1-mF4xn.js.map +1 -0
- package/dist/layout-Op6GWQ8w.cjs +2 -0
- package/dist/layout-Op6GWQ8w.cjs.map +1 -0
- package/dist/layout.cjs +1 -1
- package/dist/layout.js +8 -6
- package/dist/licensing-DmF0ObpG.cjs +2 -0
- package/dist/licensing-DmF0ObpG.cjs.map +1 -0
- package/dist/{licensing-CwzqhHH9.js → licensing-ZFCUU4Z8.js} +5 -1
- package/dist/licensing-ZFCUU4Z8.js.map +1 -0
- package/dist/{locale-CZyqh3ON.cjs → locale-Bz2JXxDZ.cjs} +2 -2
- package/dist/{locale-CZyqh3ON.cjs.map → locale-Bz2JXxDZ.cjs.map} +1 -1
- package/dist/{locale-JX_gX03k.js → locale-CS1-IY_I.js} +1 -1
- package/dist/{locale-JX_gX03k.js.map → locale-CS1-IY_I.js.map} +1 -1
- package/dist/media-DbToUupt.cjs +2 -0
- package/dist/media-DbToUupt.cjs.map +1 -0
- package/dist/{media-IM9mfVAn.js → media-DdChr0Cw.js} +7 -7
- package/dist/media-DdChr0Cw.js.map +1 -0
- package/dist/media.cjs +1 -1
- package/dist/media.js +3 -3
- package/dist/overlays-B0khU6Wb.js +392 -0
- package/dist/overlays-B0khU6Wb.js.map +1 -0
- package/dist/overlays-VAh5PqAe.cjs +2 -0
- package/dist/overlays-VAh5PqAe.cjs.map +1 -0
- package/dist/overlays.cjs +1 -1
- package/dist/overlays.js +6 -6
- package/dist/{php-deNqvHeU.js → php-5Erp5xxI.js} +1 -1
- package/dist/{php-deNqvHeU.js.map → php-5Erp5xxI.js.map} +1 -1
- package/dist/{php-Br75m0HU.cjs → php-jOdR0XS8.cjs} +1 -1
- package/dist/{php-Br75m0HU.cjs.map → php-jOdR0XS8.cjs.map} +1 -1
- package/dist/primitives.cjs +1 -1
- package/dist/style-runtime.cjs +1 -1
- package/dist/style-runtime.js +1 -1
- package/dist/styles.css +1 -1
- package/dist/{theme-CgS-bND3.cjs → theme-BaroO-OB.cjs} +2 -2
- package/dist/{theme-CgS-bND3.cjs.map → theme-BaroO-OB.cjs.map} +1 -1
- package/dist/theme.cjs +1 -1
- package/dist/{typescript-CRgqVaw_.cjs → typescript-C65sNL5w.cjs} +1 -1
- package/dist/{typescript-CRgqVaw_.cjs.map → typescript-C65sNL5w.cjs.map} +1 -1
- package/dist/{typescript-jNfCpQvl.js → typescript-wdQKWfxO.js} +1 -1
- package/dist/{typescript-jNfCpQvl.js.map → typescript-wdQKWfxO.js.map} +1 -1
- package/dist/{typography-BSBsn0f8.js → typography-CldwDFse.js} +2 -11
- package/dist/typography-CldwDFse.js.map +1 -0
- package/dist/typography-D7COsP1O.cjs +2 -0
- package/dist/typography-D7COsP1O.cjs.map +1 -0
- package/dist/typography.cjs +1 -1
- package/dist/typography.js +4 -3
- package/dist/{useGhostText-tv1LiSPs.cjs → useGhostText-Dg4P606B.cjs} +2 -2
- package/dist/{useGhostText-tv1LiSPs.cjs.map → useGhostText-Dg4P606B.cjs.map} +1 -1
- package/dist/{useInteractionEffect-D1ZdNbKU.cjs → useInteractionEffect-Bo8285cg.cjs} +2 -2
- package/dist/{useInteractionEffect-D1ZdNbKU.cjs.map → useInteractionEffect-Bo8285cg.cjs.map} +1 -1
- package/dist/{useKeyboardNav-CkIlAagq.cjs → useKeyboardNav-CyeQtqF8.cjs} +2 -2
- package/dist/{useKeyboardNav-CkIlAagq.cjs.map → useKeyboardNav-CyeQtqF8.cjs.map} +1 -1
- package/dist/utils/commandPaletteFromAppMenu.d.ts +42 -0
- package/dist/utils/creditCards.d.ts +1 -0
- package/dist/utils/licensing.d.ts +4 -0
- package/dist/utils/validators.d.ts +2 -0
- package/dist/utils.cjs +1 -1
- package/dist/utils.js +4 -4
- package/dist/{validators-H8tNxb8O.js → validators-D5OCyV2h.js} +23 -20
- package/dist/validators-D5OCyV2h.js.map +1 -0
- package/dist/{validators-BeNTD8mf.cjs → validators-DRhikiAi.cjs} +2 -2
- package/dist/validators-DRhikiAi.cjs.map +1 -0
- package/dist/{xml-C_ksWBRH.cjs → xml-B2okahIr.cjs} +1 -1
- package/dist/{xml-C_ksWBRH.cjs.map → xml-B2okahIr.cjs.map} +1 -1
- package/dist/{xml-0Th6YIDv.js → xml-a3b-XevT.js} +1 -1
- package/dist/{xml-0Th6YIDv.js.map → xml-a3b-XevT.js.map} +1 -1
- package/package.json +1 -1
- package/dist/MBadge-B4x-Lx7e.cjs +0 -2
- package/dist/MBadge-B4x-Lx7e.cjs.map +0 -1
- package/dist/MBadge-_BggwkrM.js +0 -19
- package/dist/MBadge-_BggwkrM.js.map +0 -1
- package/dist/MButton-DrkVdRDy.cjs +0 -2
- package/dist/MButton-DrkVdRDy.cjs.map +0 -1
- package/dist/MButton-y9qXhhGt.js.map +0 -1
- package/dist/MDataTable-Bx7W-Ari.cjs +0 -2
- package/dist/MDataTable-Bx7W-Ari.cjs.map +0 -1
- package/dist/MDataTable-ByvNQqNP.js +0 -149
- package/dist/MDataTable-ByvNQqNP.js.map +0 -1
- package/dist/MDropdownMenu-BmfXSc46.cjs +0 -2
- package/dist/MDropdownMenu-BmfXSc46.cjs.map +0 -1
- package/dist/MDropdownMenu-D79Cm5aS.js.map +0 -1
- package/dist/MImage-BKX-xBm3.js.map +0 -1
- package/dist/MImage-YbDKE-1t.cjs +0 -2
- package/dist/MImage-YbDKE-1t.cjs.map +0 -1
- package/dist/MInline-CHrh3PHH.cjs +0 -2
- package/dist/MInline-CHrh3PHH.cjs.map +0 -1
- package/dist/MInline-CoMhfX5V.js +0 -39
- package/dist/MInline-CoMhfX5V.js.map +0 -1
- package/dist/MInputCVC-5NkYSxV8.cjs +0 -2
- package/dist/MInputCVC-5NkYSxV8.cjs.map +0 -1
- package/dist/MInputCVC-BHpMHTO5.js.map +0 -1
- package/dist/MQrCode-ByfmG33y.cjs +0 -2
- package/dist/MQrCode-ByfmG33y.cjs.map +0 -1
- package/dist/MQrCode-CCtTkkv9.js.map +0 -1
- package/dist/MSkeleton-5j1h9s95.cjs +0 -2
- package/dist/MSkeleton-5j1h9s95.cjs.map +0 -1
- package/dist/MSkeleton-DGhtNmpI.js +0 -98
- package/dist/MSkeleton-DGhtNmpI.js.map +0 -1
- package/dist/MSparkline-B6qpt5WM.cjs +0 -2
- package/dist/MSparkline-B6qpt5WM.cjs.map +0 -1
- package/dist/MSparkline-voNWOLNz.js +0 -207
- package/dist/MSparkline-voNWOLNz.js.map +0 -1
- package/dist/MStack-Bh-R2opf.cjs +0 -2
- package/dist/MStack-Bh-R2opf.cjs.map +0 -1
- package/dist/MStack-CSaEbepM.js +0 -39
- package/dist/MStack-CSaEbepM.js.map +0 -1
- package/dist/MSurface-CpiV1-7f.cjs +0 -2
- package/dist/MSurface-CpiV1-7f.cjs.map +0 -1
- package/dist/MSurface-DJYSftdM.js +0 -39
- package/dist/MSurface-DJYSftdM.js.map +0 -1
- package/dist/cards-BiYdorB0.cjs +0 -2
- package/dist/cards-BiYdorB0.cjs.map +0 -1
- package/dist/cards-fn61xD_5.js +0 -1013
- package/dist/cards-fn61xD_5.js.map +0 -1
- package/dist/controls-C5PtrGZf.cjs +0 -2
- package/dist/controls-C5PtrGZf.cjs.map +0 -1
- package/dist/controls-DCtMOoQe.js.map +0 -1
- package/dist/creditCards-CCysEwry.js.map +0 -1
- package/dist/creditCards-ljs044xt.cjs +0 -2
- package/dist/creditCards-ljs044xt.cjs.map +0 -1
- package/dist/data-BiwK5rfx.js.map +0 -1
- package/dist/data-DOuPqg8d.cjs +0 -2
- package/dist/data-DOuPqg8d.cjs.map +0 -1
- package/dist/display-BafEcBK_.cjs +0 -3
- package/dist/display-BafEcBK_.cjs.map +0 -1
- package/dist/display-Zxj9YHu_.js.map +0 -1
- package/dist/dropdowns-Bw8obCYl.js.map +0 -1
- package/dist/dropdowns-DN7j1HhE.cjs +0 -2
- package/dist/dropdowns-DN7j1HhE.cjs.map +0 -1
- package/dist/feedback-Di0SEpRe.cjs +0 -2
- package/dist/frameworkTexts-CvxcWRXp.js.map +0 -1
- package/dist/frameworkTexts-abkS5XZK.cjs +0 -2
- package/dist/frameworkTexts-abkS5XZK.cjs.map +0 -1
- package/dist/inputs-Bcwd_UTr.js.map +0 -1
- package/dist/inputs-FP545Yri.cjs +0 -2
- package/dist/inputs-FP545Yri.cjs.map +0 -1
- package/dist/layout-BpEnTocp.js +0 -936
- package/dist/layout-BpEnTocp.js.map +0 -1
- package/dist/layout-rtlHrjDb.cjs +0 -2
- package/dist/layout-rtlHrjDb.cjs.map +0 -1
- package/dist/licensing-CwzqhHH9.js.map +0 -1
- package/dist/licensing-ezfo7ZTh.cjs +0 -2
- package/dist/licensing-ezfo7ZTh.cjs.map +0 -1
- package/dist/media-CiHsgOmu.cjs +0 -2
- package/dist/media-CiHsgOmu.cjs.map +0 -1
- package/dist/media-IM9mfVAn.js.map +0 -1
- package/dist/overlays-CGlqD3rl.js +0 -186
- package/dist/overlays-CGlqD3rl.js.map +0 -1
- package/dist/overlays-DrSGzbbA.cjs +0 -2
- package/dist/overlays-DrSGzbbA.cjs.map +0 -1
- package/dist/typography-BSBsn0f8.js.map +0 -1
- package/dist/typography-Zo4Usx9I.cjs +0 -2
- package/dist/typography-Zo4Usx9I.cjs.map +0 -1
- package/dist/validators-BeNTD8mf.cjs.map +0 -1
- package/dist/validators-H8tNxb8O.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cards-D7oHIHmU.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\nexport const MStatCard = MCardStat\n","import {Fragment, useState, useMemo, useRef, useCallback} from 'react'\nimport type {MCardGridProps, 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\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\n className=\"card-grid-items\"\n style={{\n gridTemplateColumns: `repeat(${columns}, 1fr)`,\n }}\n >\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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"}
|
package/dist/cards.cjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
const {ensureStyles}=require('./style-runtime.cjs')
|
|
2
2
|
ensureStyles()
|
|
3
|
-
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./MSkeleton-
|
|
3
|
+
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./MSkeleton-BdwhPx-k.cjs`),t=require(`./cards-B9g6Lf1n.cjs`);exports.MCard=e.n,exports.MCardActionArea=t.g,exports.MCardBody=e.r,exports.MCardBusiness=t.p,exports.MCardCourse=t.d,exports.MCardDaySchedule=t.n,exports.MCardDocumentTree=t.t,exports.MCardEvent=t.c,exports.MCardFinance=t.r,exports.MCardFooter=e.i,exports.MCardGrid=t.i,exports.MCardHeader=e.a,exports.MCardOffer=t.f,exports.MCardPayment=t.h,exports.MCardPaymentMethod=t.m,exports.MCardProduct=t.l,exports.MCardStat=t.a,exports.MCardTile=t.u,exports.MCardWidget=t.s,exports.MStatCard=t.o,exports.resolveMCardAction=e.o;
|
package/dist/cards.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import {ensureStyles} from './style-runtime.js'
|
|
2
2
|
ensureStyles()
|
|
3
|
-
import { a as e, i as t, n, r } from "./MSkeleton-
|
|
4
|
-
import { a as
|
|
5
|
-
export { n as MCard,
|
|
3
|
+
import { a as e, i as t, n, o as r, r as i } from "./MSkeleton-BvXgnYs_.js";
|
|
4
|
+
import { a, c as o, d as s, f as c, g as l, h as u, i as d, l as f, m as p, n as m, o as h, p as g, r as _, s as v, t as y, u as b } from "./cards-D7oHIHmU.js";
|
|
5
|
+
export { n as MCard, l as MCardActionArea, i as MCardBody, g as MCardBusiness, s as MCardCourse, m as MCardDaySchedule, y as MCardDocumentTree, o as MCardEvent, _ as MCardFinance, t as MCardFooter, d as MCardGrid, e as MCardHeader, c as MCardOffer, u as MCardPayment, p as MCardPaymentMethod, f as MCardProduct, a as MCardStat, b as MCardTile, v as MCardWidget, h as MStatCard, r as resolveMCardAction };
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { MCardProps, MCardSectionProps } from './MCard.types';
|
|
2
|
-
export declare function MCard({ interactive, stretch, tone, padded, color, clickEffect, rippleColor, skeleton, spacing, mt, mb, ml, mr, mx, my, className, children, onPointerDown, ...rest }: MCardProps): import("react/jsx-runtime").JSX.Element;
|
|
2
|
+
export declare function MCard({ component, to, href, target, rel, interactive, stretch, tone, padded, color, clickEffect, rippleColor, skeleton, spacing, mt, mb, ml, mr, mx, my, className, children, onPointerDown, ...rest }: MCardProps): import("react/jsx-runtime").JSX.Element;
|
|
3
3
|
export declare function MCardHeader({ className, children, ...rest }: MCardSectionProps): import("react/jsx-runtime").JSX.Element;
|
|
4
4
|
export declare function MCardBody({ className, children, ...rest }: MCardSectionProps): import("react/jsx-runtime").JSX.Element;
|
|
5
5
|
export declare function MCardFooter({ className, children, ...rest }: MCardSectionProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -1,13 +1,10 @@
|
|
|
1
1
|
import { HTMLAttributes, ReactNode } from 'react';
|
|
2
2
|
import { MColor } from '../../../theme';
|
|
3
3
|
import { MSurfaceProps } from '../../layout';
|
|
4
|
-
import {
|
|
5
|
-
export interface MCardProps extends Omit<MSurfaceProps, 'children'
|
|
6
|
-
interactive?: boolean;
|
|
4
|
+
import { MCardActionProps } from '../shared';
|
|
5
|
+
export interface MCardProps extends Omit<MSurfaceProps, 'children' | 'component' | 'to' | 'href' | 'target' | 'rel'>, MCardActionProps {
|
|
7
6
|
stretch?: boolean;
|
|
8
7
|
color?: MColor;
|
|
9
|
-
clickEffect?: MClickEffect;
|
|
10
|
-
rippleColor?: string;
|
|
11
8
|
/** Show skeleton placeholder instead of content */
|
|
12
9
|
skeleton?: boolean;
|
|
13
10
|
children?: ReactNode;
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { MCardActionAreaProps } from './MCardActionArea.types';
|
|
2
|
+
export declare function MCardActionArea({ component, to, href, target, rel, color, interactive, clickEffect, rippleColor, className, children, onPointerDown, type, ...rest }: MCardActionAreaProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ButtonHTMLAttributes, ReactNode } from 'react';
|
|
2
|
+
import { MColor } from '../../../theme';
|
|
3
|
+
import { MCardActionProps } from '../shared';
|
|
4
|
+
export interface MCardActionAreaProps extends Omit<ButtonHTMLAttributes<HTMLButtonElement>, 'color'>, MCardActionProps {
|
|
5
|
+
color?: MColor;
|
|
6
|
+
children?: ReactNode;
|
|
7
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { MCardDayScheduleProps } from './MCardDaySchedule.types';
|
|
2
|
+
export declare function MCardDaySchedule({ title, description, color, workdayStart, workdayEnd, timeline, summary, tabs, footer, emptyTimeline, ...rest }: MCardDayScheduleProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { MColor } from '../../../theme';
|
|
3
|
+
import { MCardProps } from '../MCard';
|
|
4
|
+
import { MDetailListItem } from '../../display/MDetailList';
|
|
5
|
+
export interface MDayScheduleEntry {
|
|
6
|
+
id: string;
|
|
7
|
+
title: ReactNode;
|
|
8
|
+
description?: ReactNode;
|
|
9
|
+
time: ReactNode;
|
|
10
|
+
icon?: ReactNode;
|
|
11
|
+
color?: MColor;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Semantic role of a side-panel tab. Drives the colored indicator next to the
|
|
15
|
+
* tab label so the user can spot "available", "needs attention" and "neutral
|
|
16
|
+
* info" buckets at a glance, and lets analytics/automation reason about the
|
|
17
|
+
* panels without inspecting their titles.
|
|
18
|
+
*/
|
|
19
|
+
export type MCardDayScheduleTabType = 'free' | 'alerts' | 'info';
|
|
20
|
+
export interface MCardDayScheduleTab {
|
|
21
|
+
type: MCardDayScheduleTabType;
|
|
22
|
+
title: ReactNode;
|
|
23
|
+
items: MDetailListItem[];
|
|
24
|
+
}
|
|
25
|
+
export interface MCardDayScheduleProps extends Omit<MCardProps, 'children' | 'title'> {
|
|
26
|
+
title?: ReactNode;
|
|
27
|
+
description?: ReactNode;
|
|
28
|
+
workdayStart?: ReactNode;
|
|
29
|
+
workdayEnd?: ReactNode;
|
|
30
|
+
timeline: MDayScheduleEntry[];
|
|
31
|
+
summary?: ReactNode;
|
|
32
|
+
/**
|
|
33
|
+
* Side-panel content — rendered as a single `MTabs` strip in the right
|
|
34
|
+
* column. Empty `items` arrays are skipped automatically; the first tab
|
|
35
|
+
* with items is selected by default. Pass an empty array (or omit the prop)
|
|
36
|
+
* to render only the timeline + summary on the side.
|
|
37
|
+
*/
|
|
38
|
+
tabs?: MCardDayScheduleTab[];
|
|
39
|
+
footer?: ReactNode;
|
|
40
|
+
emptyTimeline?: ReactNode;
|
|
41
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { MCardDocumentTreeProps } from './MCardDocumentTree.types';
|
|
2
|
+
export declare function MCardDocumentTree({ title, description, color, items, selected, onSelect, defaultExpanded, expanded, onExpandChange, detailsTitle, detailsMeta, detailsItems, detailsActions, renderDetails, emptyDetails, primaryAction, ...rest }: MCardDocumentTreeProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { MColor } from '../../../theme';
|
|
3
|
+
import { MTreeNode } from '../../data/MTreeView';
|
|
4
|
+
import { MCardProps } from '../MCard';
|
|
5
|
+
import { MDetailListItem } from '../../display/MDetailList';
|
|
6
|
+
import { MCardActionProps } from '../shared';
|
|
7
|
+
export interface MCardDocumentTreeAction extends MCardActionProps {
|
|
8
|
+
id: string;
|
|
9
|
+
label: ReactNode;
|
|
10
|
+
icon?: ReactNode;
|
|
11
|
+
color?: MColor;
|
|
12
|
+
disabled?: boolean;
|
|
13
|
+
onClick?: () => void;
|
|
14
|
+
}
|
|
15
|
+
export interface MCardDocumentTreeProps extends Omit<MCardProps, 'children' | 'title' | 'onSelect'> {
|
|
16
|
+
title?: ReactNode;
|
|
17
|
+
description?: ReactNode;
|
|
18
|
+
items: MTreeNode[];
|
|
19
|
+
selected?: string | null;
|
|
20
|
+
onSelect?: (id: string, node: MTreeNode) => void;
|
|
21
|
+
defaultExpanded?: string[];
|
|
22
|
+
expanded?: string[];
|
|
23
|
+
onExpandChange?: (ids: string[]) => void;
|
|
24
|
+
detailsTitle?: ReactNode;
|
|
25
|
+
detailsMeta?: ReactNode;
|
|
26
|
+
detailsItems?: MDetailListItem[];
|
|
27
|
+
detailsActions?: MCardDocumentTreeAction[];
|
|
28
|
+
renderDetails?: ReactNode;
|
|
29
|
+
emptyDetails?: ReactNode;
|
|
30
|
+
primaryAction?: ReactNode;
|
|
31
|
+
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { MCardFinanceProps } from './MCardFinance.types';
|
|
2
|
-
export declare function MCardFinance({ label, value, change, changeType: changeTypeProp, changeLabel, icon, sparkline, sparklineType, color, currency, className, ...rest }: MCardFinanceProps): import("react/jsx-runtime").JSX.Element;
|
|
2
|
+
export declare function MCardFinance({ component, to, href, target, rel, label, value, change, changeType: changeTypeProp, changeLabel, icon, sparkline, sparklineType, color, currency, interactive, clickEffect, rippleColor, className, onPointerDown, ...rest }: MCardFinanceProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { HTMLAttributes, ReactNode } from 'react';
|
|
2
2
|
import { MColor } from '../../../theme/MTheme.types';
|
|
3
3
|
import { MSparklineType } from '../../data/MSparkline/MSparkline.types';
|
|
4
|
+
import { MCardActionProps } from '../shared';
|
|
4
5
|
export type MCardFinanceChangeType = 'up' | 'down' | 'neutral';
|
|
5
|
-
export interface MCardFinanceProps extends Omit<HTMLAttributes<HTMLDivElement>, 'color'
|
|
6
|
+
export interface MCardFinanceProps extends Omit<HTMLAttributes<HTMLDivElement>, 'color'>, MCardActionProps {
|
|
6
7
|
label: string;
|
|
7
8
|
value: ReactNode;
|
|
8
9
|
change?: number;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { MCardGridProps } from './MCardGrid.types';
|
|
2
|
-
export declare function MCardGrid<T extends Record<string, unknown>>({ items, renderCard, searchable, searchKeys, searchPlaceholder, filterable, filterKeys, sortable, sortKeys, defaultSort, columns, emptyMessage, className, style, ...rest }: MCardGridProps<T>): import("react/jsx-runtime").JSX.Element;
|
|
2
|
+
export declare function MCardGrid<T extends Record<string, unknown>>({ items, renderCard, color, searchable, searchKeys, searchPlaceholder, search: controlledSearch, onSearchChange, filterable, filterKeys, filters: controlledFilters, onFiltersChange, sortable, sortKeys, defaultSort, sort: controlledSort, onSortChange, pagination, pageSize, page: controlledPage, onPageChange, total, manualSearch, manualFilters, manualSort, manualPagination, columns, emptyMessage, className, style, ...rest }: MCardGridProps<T>): import("react/jsx-runtime").JSX.Element;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { HTMLAttributes, ReactNode } from 'react';
|
|
2
|
+
import { MColor } from '../../../theme';
|
|
2
3
|
export interface MCardGridFilterKey<T> {
|
|
3
4
|
key: keyof T & string;
|
|
4
5
|
label: string;
|
|
@@ -8,20 +9,37 @@ export interface MCardGridSortKey<T> {
|
|
|
8
9
|
key: keyof T & string;
|
|
9
10
|
label: string;
|
|
10
11
|
}
|
|
11
|
-
export interface
|
|
12
|
+
export interface MCardGridSort<T = unknown> {
|
|
13
|
+
key: keyof T & string;
|
|
14
|
+
direction: 'asc' | 'desc';
|
|
15
|
+
}
|
|
16
|
+
export interface MCardGridProps<T> extends Omit<HTMLAttributes<HTMLDivElement>, 'children' | 'onChange'> {
|
|
12
17
|
items: T[];
|
|
13
18
|
renderCard: (item: T, index: number) => ReactNode;
|
|
19
|
+
color?: MColor;
|
|
14
20
|
searchable?: boolean;
|
|
15
21
|
searchKeys?: (keyof T & string)[];
|
|
16
22
|
searchPlaceholder?: string;
|
|
23
|
+
search?: string;
|
|
24
|
+
onSearchChange?: (search: string) => void;
|
|
17
25
|
filterable?: boolean;
|
|
18
26
|
filterKeys?: MCardGridFilterKey<T>[];
|
|
27
|
+
filters?: Record<string, string[]>;
|
|
28
|
+
onFiltersChange?: (filters: Record<string, string[]>) => void;
|
|
19
29
|
sortable?: boolean;
|
|
20
30
|
sortKeys?: MCardGridSortKey<T>[];
|
|
21
|
-
defaultSort?:
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
31
|
+
defaultSort?: MCardGridSort<T>;
|
|
32
|
+
sort?: MCardGridSort<T> | null;
|
|
33
|
+
onSortChange?: (sort: MCardGridSort<T> | null) => void;
|
|
34
|
+
pagination?: boolean;
|
|
35
|
+
pageSize?: number;
|
|
36
|
+
page?: number;
|
|
37
|
+
onPageChange?: (page: number) => void;
|
|
38
|
+
total?: number;
|
|
39
|
+
manualSearch?: boolean;
|
|
40
|
+
manualFilters?: boolean;
|
|
41
|
+
manualSort?: boolean;
|
|
42
|
+
manualPagination?: boolean;
|
|
25
43
|
columns?: number;
|
|
26
44
|
emptyMessage?: ReactNode;
|
|
27
45
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { MCardPaymentProps } from './MCardPayment.types';
|
|
2
|
-
export declare function MCardPayment({ holder, number, expiry, brand, brandIcon, balance, balanceLabel, color, className, ...rest }: MCardPaymentProps): import("react/jsx-runtime").JSX.Element;
|
|
2
|
+
export declare function MCardPayment({ component, to, href, target, rel, holder, number, expiry, brand, brandIcon, balance, balanceLabel, color, interactive, clickEffect, rippleColor, className, onPointerDown, ...rest }: MCardPaymentProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { HTMLAttributes, ReactNode } from 'react';
|
|
2
2
|
import { MColor } from '../../../theme';
|
|
3
|
+
import { MCardActionProps } from '../shared';
|
|
3
4
|
export type MCardPaymentBrand = 'visa' | 'mastercard' | 'amex' | 'discover' | 'maestro' | 'unknown';
|
|
4
|
-
export interface MCardPaymentProps extends Omit<HTMLAttributes<HTMLDivElement>, 'color'
|
|
5
|
+
export interface MCardPaymentProps extends Omit<HTMLAttributes<HTMLDivElement>, 'color'>, MCardActionProps {
|
|
5
6
|
holder: string;
|
|
6
7
|
number: string;
|
|
7
8
|
expiry: string;
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { MCardTileProps } from './MCardTile.types';
|
|
2
|
+
export declare function MCardTile({ component, title, description, icon, color, to, href, target, rel, onClick, interactive, clickEffect, rippleColor, image, video, illustration, camera, mediaFill, overlayPosition, favorite, onFavorite, menuItems, className, ...rest }: MCardTileProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { HTMLAttributes, ReactNode } from 'react';
|
|
2
|
+
import { MColor } from '../../../theme';
|
|
3
|
+
import { MCardActionProps } from '../shared';
|
|
4
|
+
export type MCardTileOverlayPosition = 'top' | 'bottom' | 'center';
|
|
5
|
+
export interface MCardTileMenuItem {
|
|
6
|
+
label: string;
|
|
7
|
+
onClick?: () => void;
|
|
8
|
+
icon?: ReactNode;
|
|
9
|
+
danger?: boolean;
|
|
10
|
+
}
|
|
11
|
+
export interface MCardTileProps extends Omit<HTMLAttributes<HTMLDivElement>, 'color' | 'onClick'>, MCardActionProps {
|
|
12
|
+
title: string;
|
|
13
|
+
description?: string;
|
|
14
|
+
icon?: ReactNode;
|
|
15
|
+
color?: MColor;
|
|
16
|
+
onClick?: () => void;
|
|
17
|
+
image?: string;
|
|
18
|
+
video?: string;
|
|
19
|
+
illustration?: ReactNode;
|
|
20
|
+
camera?: boolean | MediaStreamConstraints;
|
|
21
|
+
mediaFill?: boolean;
|
|
22
|
+
overlayPosition?: MCardTileOverlayPosition;
|
|
23
|
+
favorite?: boolean;
|
|
24
|
+
onFavorite?: () => void;
|
|
25
|
+
menuItems?: MCardTileMenuItem[];
|
|
26
|
+
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { MCardWidgetProps } from './MCardWidget.types';
|
|
2
|
-
export declare function MCardWidget({ title, value, trend, trendType, icon, color, helperText, className, ...rest }: MCardWidgetProps): import("react/jsx-runtime").JSX.Element;
|
|
2
|
+
export declare function MCardWidget({ component, to, href, target, rel, title, value, trend, trendType, icon, color, helperText, interactive, clickEffect, rippleColor, className, onPointerDown, ...rest }: MCardWidgetProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { HTMLAttributes, ReactNode } from 'react';
|
|
2
2
|
import { MColor } from '../../../theme';
|
|
3
|
+
import { MCardActionProps } from '../shared';
|
|
3
4
|
export type MCardWidgetTrendType = 'up' | 'down' | 'neutral';
|
|
4
|
-
export interface MCardWidgetProps extends Omit<HTMLAttributes<HTMLDivElement>, 'color' | 'title'
|
|
5
|
+
export interface MCardWidgetProps extends Omit<HTMLAttributes<HTMLDivElement>, 'color' | 'title'>, MCardActionProps {
|
|
5
6
|
title: ReactNode;
|
|
6
7
|
value: ReactNode;
|
|
7
8
|
trend?: ReactNode;
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { MCardStatProps } from './MStatCard.types';
|
|
2
|
+
export declare function MCardStat({ label, value, icon, badge, helperText, trend, trendType, color, className, ...rest }: MCardStatProps): import("react/jsx-runtime").JSX.Element;
|
|
3
|
+
export declare const MStatCard: typeof MCardStat;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { MColor } from '../../../theme';
|
|
3
|
+
import { MCardProps } from '../MCard';
|
|
4
|
+
export type MCardStatTrendType = 'up' | 'down' | 'neutral';
|
|
5
|
+
export interface MCardStatProps extends Omit<MCardProps, 'children' | 'color'> {
|
|
6
|
+
label: ReactNode;
|
|
7
|
+
value: ReactNode;
|
|
8
|
+
icon?: ReactNode;
|
|
9
|
+
badge?: ReactNode;
|
|
10
|
+
helperText?: ReactNode;
|
|
11
|
+
trend?: ReactNode;
|
|
12
|
+
trendType?: MCardStatTrendType;
|
|
13
|
+
color?: MColor;
|
|
14
|
+
}
|
|
15
|
+
export type MStatCardTrendType = MCardStatTrendType;
|
|
16
|
+
export type MStatCardProps = MCardStatProps;
|