@banzamel/mineralui 1.0.2 → 1.0.4
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 +55 -22
- package/dist/{MArrowDownIcon-BslRpwqk.js → MArrowDownIcon-BcKSgdTY.js} +1 -1
- package/dist/{MArrowDownIcon-BslRpwqk.js.map → MArrowDownIcon-BcKSgdTY.js.map} +1 -1
- package/dist/{MArrowDownIcon-DjLz-A0I.cjs → MArrowDownIcon-C8EAODgv.cjs} +1 -1
- package/dist/{MArrowDownIcon-DjLz-A0I.cjs.map → MArrowDownIcon-C8EAODgv.cjs.map} +1 -1
- package/dist/MArrowUpDownIcon-CW_PWr7Q.cjs +2 -0
- package/dist/MArrowUpDownIcon-CW_PWr7Q.cjs.map +1 -0
- package/dist/MArrowUpDownIcon-DukXemVA.js +19 -0
- package/dist/MArrowUpDownIcon-DukXemVA.js.map +1 -0
- package/dist/{MArrowUpIcon-CjLbBZOW.cjs → MArrowUpIcon-DWV_HYrz.cjs} +1 -1
- package/dist/{MArrowUpIcon-CjLbBZOW.cjs.map → MArrowUpIcon-DWV_HYrz.cjs.map} +1 -1
- package/dist/{MArrowUpIcon-CudFd1sD.js → MArrowUpIcon-Dan-4hs8.js} +1 -1
- package/dist/{MArrowUpIcon-CudFd1sD.js.map → MArrowUpIcon-Dan-4hs8.js.map} +1 -1
- package/dist/{MAvatar-B_YPaZt9.js → MAvatar-Blh5pfSO.js} +4 -4
- package/dist/{MAvatar-B_YPaZt9.js.map → MAvatar-Blh5pfSO.js.map} +1 -1
- package/dist/{MAvatar-lzW37S2c.cjs → MAvatar-DMM1CsdO.cjs} +2 -2
- package/dist/{MAvatar-lzW37S2c.cjs.map → MAvatar-DMM1CsdO.cjs.map} +1 -1
- package/dist/{MBadge-lezDpe-x.cjs → MBadge-Babyr1R9.cjs} +2 -2
- package/dist/{MBadge-lezDpe-x.cjs.map → MBadge-Babyr1R9.cjs.map} +1 -1
- package/dist/{MBadge-jh7HI3jR.js → MBadge-BjZX0MIC.js} +2 -2
- package/dist/{MBadge-jh7HI3jR.js.map → MBadge-BjZX0MIC.js.map} +1 -1
- package/dist/MBrandMoreIcons-ClUq3DXO.js +873 -0
- package/dist/MBrandMoreIcons-ClUq3DXO.js.map +1 -0
- package/dist/MBrandMoreIcons-Xxf9FaIx.cjs +2 -0
- package/dist/MBrandMoreIcons-Xxf9FaIx.cjs.map +1 -0
- package/dist/{MButton-BIWj6T2J.js → MButton-33EzpGvQ.js} +3 -3
- package/dist/{MButton-BIWj6T2J.js.map → MButton-33EzpGvQ.js.map} +1 -1
- package/dist/{MButton-DOtMjOTz.cjs → MButton-C_WTyNvw.cjs} +2 -2
- package/dist/{MButton-DOtMjOTz.cjs.map → MButton-C_WTyNvw.cjs.map} +1 -1
- package/dist/{MCalendarIcon-CgFKAojj.cjs → MCalendarIcon-4PilFCrR.cjs} +1 -1
- package/dist/{MCalendarIcon-CgFKAojj.cjs.map → MCalendarIcon-4PilFCrR.cjs.map} +1 -1
- package/dist/{MCalendarIcon-Csj_JV9i.js → MCalendarIcon-DXx62vjV.js} +1 -1
- package/dist/{MCalendarIcon-Csj_JV9i.js.map → MCalendarIcon-DXx62vjV.js.map} +1 -1
- package/dist/MChatIcon-CnDOfqkO.js +102 -0
- package/dist/MChatIcon-CnDOfqkO.js.map +1 -0
- package/dist/MChatIcon-DX-u8_6S.cjs +2 -0
- package/dist/MChatIcon-DX-u8_6S.cjs.map +1 -0
- package/dist/MCheckIcon-DQumT4HX.js +15 -0
- package/dist/MCheckIcon-DQumT4HX.js.map +1 -0
- package/dist/MCheckIcon-ck_21ybZ.cjs +2 -0
- package/dist/MCheckIcon-ck_21ybZ.cjs.map +1 -0
- package/dist/{MCheckbox-Vbr4IhEn.cjs → MCheckbox-BhtJDdip.cjs} +2 -2
- package/dist/{MCheckbox-Vbr4IhEn.cjs.map → MCheckbox-BhtJDdip.cjs.map} +1 -1
- package/dist/{MCheckbox-DhDggBnO.js → MCheckbox-CugP7F6H.js} +3 -3
- package/dist/{MCheckbox-DhDggBnO.js.map → MCheckbox-CugP7F6H.js.map} +1 -1
- package/dist/{MChevronDownIcon-CPXk51nE.js → MChevronDownIcon-D3yTpzni.js} +1 -1
- package/dist/{MChevronDownIcon-CPXk51nE.js.map → MChevronDownIcon-D3yTpzni.js.map} +1 -1
- package/dist/{MChevronDownIcon-CE25HFYo.cjs → MChevronDownIcon-DCMmxkRt.cjs} +1 -1
- package/dist/{MChevronDownIcon-CE25HFYo.cjs.map → MChevronDownIcon-DCMmxkRt.cjs.map} +1 -1
- package/dist/{MChevronRightIcon-QbfE-b7g.cjs → MChevronRightIcon-BC08M6g8.cjs} +1 -1
- package/dist/{MChevronRightIcon-QbfE-b7g.cjs.map → MChevronRightIcon-BC08M6g8.cjs.map} +1 -1
- package/dist/{MChevronRightIcon-BozfuNpv.js → MChevronRightIcon-CXs8IHiV.js} +1 -1
- package/dist/{MChevronRightIcon-BozfuNpv.js.map → MChevronRightIcon-CXs8IHiV.js.map} +1 -1
- package/dist/{MClockIcon-2NNldTuA.cjs → MClockIcon-C-zYY2A0.cjs} +1 -1
- package/dist/{MClockIcon-2NNldTuA.cjs.map → MClockIcon-C-zYY2A0.cjs.map} +1 -1
- package/dist/{MClockIcon-D4K6fmV9.js → MClockIcon-DefFl5ks.js} +1 -1
- package/dist/{MClockIcon-D4K6fmV9.js.map → MClockIcon-DefFl5ks.js.map} +1 -1
- package/dist/{MCloseIcon-BKH33Q51.cjs → MCloseIcon-6cfw9trj.cjs} +1 -1
- package/dist/{MCloseIcon-BKH33Q51.cjs.map → MCloseIcon-6cfw9trj.cjs.map} +1 -1
- package/dist/{MCloseIcon-BQv01JOS.js → MCloseIcon-lDH3Vc10.js} +1 -1
- package/dist/{MCloseIcon-BQv01JOS.js.map → MCloseIcon-lDH3Vc10.js.map} +1 -1
- package/dist/MCookieBootstrap-Ct5mIm5P.cjs +2 -0
- package/dist/MCookieBootstrap-Ct5mIm5P.cjs.map +1 -0
- package/dist/MCookieBootstrap-DEEHYxXi.js +437 -0
- package/dist/MCookieBootstrap-DEEHYxXi.js.map +1 -0
- package/dist/MDataTable--pUkQHAv.js +151 -0
- package/dist/MDataTable--pUkQHAv.js.map +1 -0
- package/dist/MDataTable-8ZhnWhqW.cjs +2 -0
- package/dist/MDataTable-8ZhnWhqW.cjs.map +1 -0
- package/dist/MDrawer-00BvU8Dn.js +122 -0
- package/dist/MDrawer-00BvU8Dn.js.map +1 -0
- package/dist/MDrawer-FYS50FtQ.cjs +2 -0
- package/dist/MDrawer-FYS50FtQ.cjs.map +1 -0
- package/dist/MDropdownMenu-BLBdToIz.cjs +2 -0
- package/dist/MDropdownMenu-BLBdToIz.cjs.map +1 -0
- package/dist/MDropdownMenu-BgOiM5yr.js +152 -0
- package/dist/MDropdownMenu-BgOiM5yr.js.map +1 -0
- package/dist/MEllipsisVerticalIcon-C87B9UQK.cjs +2 -0
- package/dist/MEllipsisVerticalIcon-C87B9UQK.cjs.map +1 -0
- package/dist/MEllipsisVerticalIcon-CNn1AQ8W.js +37 -0
- package/dist/MEllipsisVerticalIcon-CNn1AQ8W.js.map +1 -0
- package/dist/{MFileExtIcons-H7zvI8AL.js → MFileExtIcons-BoG3GPxg.js} +1 -1
- package/dist/{MFileExtIcons-H7zvI8AL.js.map → MFileExtIcons-BoG3GPxg.js.map} +1 -1
- package/dist/{MFileExtIcons-DzACx_eM.cjs → MFileExtIcons-DH9oZPpf.cjs} +1 -1
- package/dist/{MFileExtIcons-DzACx_eM.cjs.map → MFileExtIcons-DH9oZPpf.cjs.map} +1 -1
- package/dist/MImage-CKrjXRmf.js +49 -0
- package/dist/MImage-CKrjXRmf.js.map +1 -0
- package/dist/MImage-f854avZS.cjs +2 -0
- package/dist/MImage-f854avZS.cjs.map +1 -0
- package/dist/{MInput-DYEAqxod.js → MInput-BUCcLWSI.js} +6 -6
- package/dist/{MInput-DYEAqxod.js.map → MInput-BUCcLWSI.js.map} +1 -1
- package/dist/{MInput-CjsJRLaz.cjs → MInput-CQ3MqKsk.cjs} +2 -2
- package/dist/{MInput-CjsJRLaz.cjs.map → MInput-CQ3MqKsk.cjs.map} +1 -1
- package/dist/{MInputSearch-CrVrpYsR.js → MInputSearch-BeXUh4lz.js} +4 -4
- package/dist/{MInputSearch-CrVrpYsR.js.map → MInputSearch-BeXUh4lz.js.map} +1 -1
- package/dist/{MInputSearch-CQZ-ccri.cjs → MInputSearch-Dt79qbZg.cjs} +2 -2
- package/dist/{MInputSearch-CQZ-ccri.cjs.map → MInputSearch-Dt79qbZg.cjs.map} +1 -1
- package/dist/{MLink-CAaK6SOG.cjs → MLink-CVN-Vll4.cjs} +2 -2
- package/dist/{MLink-CAaK6SOG.cjs.map → MLink-CVN-Vll4.cjs.map} +1 -1
- package/dist/{MLink-BfRaT8NU.js → MLink-DH4vk7O5.js} +2 -2
- package/dist/{MLink-BfRaT8NU.js.map → MLink-DH4vk7O5.js.map} +1 -1
- package/dist/{MMenuIcon-TZ9iJAXz.cjs → MMenuIcon-Brpitjq1.cjs} +1 -1
- package/dist/{MMenuIcon-TZ9iJAXz.cjs.map → MMenuIcon-Brpitjq1.cjs.map} +1 -1
- package/dist/{MMenuIcon-B13EvS3i.js → MMenuIcon-idfVpVQD.js} +1 -1
- package/dist/{MMenuIcon-B13EvS3i.js.map → MMenuIcon-idfVpVQD.js.map} +1 -1
- package/dist/MModal-BQvk1KKc.cjs +2 -0
- package/dist/MModal-BQvk1KKc.cjs.map +1 -0
- package/dist/MModal-D1Knn-bg.js +69 -0
- package/dist/MModal-D1Knn-bg.js.map +1 -0
- package/dist/MPagination-Bu84ZlVh.cjs +2 -0
- package/dist/MPagination-Bu84ZlVh.cjs.map +1 -0
- package/dist/MPagination-CbkRMnL1.js +147 -0
- package/dist/MPagination-CbkRMnL1.js.map +1 -0
- package/dist/MPhoneIcon-efl6BqwU.js +38 -0
- package/dist/MPhoneIcon-efl6BqwU.js.map +1 -0
- package/dist/MPhoneIcon-lgC9DH5a.cjs +2 -0
- package/dist/MPhoneIcon-lgC9DH5a.cjs.map +1 -0
- package/dist/{MPopover-BE73Iock.cjs → MPopover-BXPkE575.cjs} +2 -2
- package/dist/{MPopover-BE73Iock.cjs.map → MPopover-BXPkE575.cjs.map} +1 -1
- package/dist/{MPopover-C7ZJz7Uj.js → MPopover-DKBdLfrw.js} +3 -3
- package/dist/{MPopover-C7ZJz7Uj.js.map → MPopover-DKBdLfrw.js.map} +1 -1
- package/dist/{MPortal-d1mwLhwx.cjs → MPortal-BysJLuEi.cjs} +1 -1
- package/dist/{MPortal-d1mwLhwx.cjs.map → MPortal-BysJLuEi.cjs.map} +1 -1
- package/dist/{MPortal-BzordRff.js → MPortal-CbpNkzfC.js} +1 -1
- package/dist/{MPortal-BzordRff.js.map → MPortal-CbpNkzfC.js.map} +1 -1
- package/dist/MProtectIcon-BPYP06QD.cjs +2 -0
- package/dist/MProtectIcon-BPYP06QD.cjs.map +1 -0
- package/dist/{MBoltIcon-B1P4i_X4.js → MProtectIcon-BTtMmrib.js} +11 -29
- package/dist/MProtectIcon-BTtMmrib.js.map +1 -0
- package/dist/MQrCode-AttGRC6v.js +416 -0
- package/dist/MQrCode-AttGRC6v.js.map +1 -0
- package/dist/MQrCode-CbUPPd4S.cjs +2 -0
- package/dist/MQrCode-CbUPPd4S.cjs.map +1 -0
- package/dist/{MSearchIcon-Bb-f5JdO.cjs → MSearchIcon-BakfEJQd.cjs} +1 -1
- package/dist/{MSearchIcon-Bb-f5JdO.cjs.map → MSearchIcon-BakfEJQd.cjs.map} +1 -1
- package/dist/{MSearchIcon-COQaC0mk.js → MSearchIcon-Dlg4Og8t.js} +1 -1
- package/dist/{MSearchIcon-COQaC0mk.js.map → MSearchIcon-Dlg4Og8t.js.map} +1 -1
- package/dist/MSkeleton-B5jZNFOG.cjs +2 -0
- package/dist/MSkeleton-B5jZNFOG.cjs.map +1 -0
- package/dist/MSkeleton-BL4C5FkH.js +98 -0
- package/dist/MSkeleton-BL4C5FkH.js.map +1 -0
- package/dist/{MSlider-KyOhqE6d.js → MSlider-D5ckYDop.js} +2 -2
- package/dist/{MSlider-KyOhqE6d.js.map → MSlider-D5ckYDop.js.map} +1 -1
- package/dist/{MSlider-VFCviEUW.cjs → MSlider-vD6Sla2p.cjs} +2 -2
- package/dist/{MSlider-VFCviEUW.cjs.map → MSlider-vD6Sla2p.cjs.map} +1 -1
- package/dist/MSparkline-DjcDtnZH.js +207 -0
- package/dist/MSparkline-DjcDtnZH.js.map +1 -0
- package/dist/MSparkline-U-XaDvpV.cjs +2 -0
- package/dist/MSparkline-U-XaDvpV.cjs.map +1 -0
- package/dist/{MStack-SPM68IMq.cjs → MStack-BvFI0AFv.cjs} +2 -2
- package/dist/{MStack-SPM68IMq.cjs.map → MStack-BvFI0AFv.cjs.map} +1 -1
- package/dist/{MStack-CQLO9e-3.js → MStack-DhdMFSUL.js} +4 -4
- package/dist/{MStack-CQLO9e-3.js.map → MStack-DhdMFSUL.js.map} +1 -1
- package/dist/{MStarFillIcon-w67ZD64c.js → MStarFillIcon-CGyQPFi8.js} +1 -1
- package/dist/{MStarFillIcon-w67ZD64c.js.map → MStarFillIcon-CGyQPFi8.js.map} +1 -1
- package/dist/{MStarFillIcon-B2H1b7mD.cjs → MStarFillIcon-DJHfl_Qy.cjs} +1 -1
- package/dist/{MStarFillIcon-B2H1b7mD.cjs.map → MStarFillIcon-DJHfl_Qy.cjs.map} +1 -1
- package/dist/MSubText-CfWNytoK.cjs +2 -0
- package/dist/MSubText-CfWNytoK.cjs.map +1 -0
- package/dist/MSubText-uvcBr9Ba.js +15 -0
- package/dist/MSubText-uvcBr9Ba.js.map +1 -0
- package/dist/MSuccessIcon-CatQ4FmG.cjs +2 -0
- package/dist/MSuccessIcon-CatQ4FmG.cjs.map +1 -0
- package/dist/MSuccessIcon-D3GrOvye.js +33 -0
- package/dist/MSuccessIcon-D3GrOvye.js.map +1 -0
- package/dist/MSurface-DlcK6Bre.js +39 -0
- package/dist/MSurface-DlcK6Bre.js.map +1 -0
- package/dist/MSurface-qcGLaTIK.cjs +2 -0
- package/dist/MSurface-qcGLaTIK.cjs.map +1 -0
- package/dist/{MTag-CXAmy8tJ.cjs → MTag-BMi1GS7v.cjs} +2 -2
- package/dist/{MTag-CXAmy8tJ.cjs.map → MTag-BMi1GS7v.cjs.map} +1 -1
- package/dist/{MTag-BbIqugpb.js → MTag-Cor8ZIW3.js} +4 -4
- package/dist/{MTag-BbIqugpb.js.map → MTag-Cor8ZIW3.js.map} +1 -1
- package/dist/MText-C0FdseW1.js +57 -0
- package/dist/MText-C0FdseW1.js.map +1 -0
- package/dist/MText-OV0ihtQ6.cjs +2 -0
- package/dist/MText-OV0ihtQ6.cjs.map +1 -0
- package/dist/MTimeAgo-BOXKcDYN.cjs +2 -0
- package/dist/MTimeAgo-BOXKcDYN.cjs.map +1 -0
- package/dist/MTimeAgo-DrDs52Y1.js +51 -0
- package/dist/MTimeAgo-DrDs52Y1.js.map +1 -0
- package/dist/MToggle-B7cKH5Tl.js +48 -0
- package/dist/MToggle-B7cKH5Tl.js.map +1 -0
- package/dist/MToggle-Hheo-jfZ.cjs +2 -0
- package/dist/MToggle-Hheo-jfZ.cjs.map +1 -0
- package/dist/{MTooltip-CKS_zgzR.js → MTooltip-D3xuZ5kG.js} +3 -3
- package/dist/{MTooltip-CKS_zgzR.js.map → MTooltip-D3xuZ5kG.js.map} +1 -1
- package/dist/{MTooltip-CXXYU-j1.cjs → MTooltip-DzwZ637q.cjs} +2 -2
- package/dist/{MTooltip-CXXYU-j1.cjs.map → MTooltip-DzwZ637q.cjs.map} +1 -1
- package/dist/{MZoomInIcon-CK2aJhDg.js → MZoomInIcon-BEdmglk6.js} +11 -46
- package/dist/MZoomInIcon-BEdmglk6.js.map +1 -0
- package/dist/MZoomInIcon-dhRm7zT6.cjs +2 -0
- package/dist/MZoomInIcon-dhRm7zT6.cjs.map +1 -0
- package/dist/cards-CKCr-GuJ.js +934 -0
- package/dist/cards-CKCr-GuJ.js.map +1 -0
- package/dist/cards-yPK4lBAA.cjs +2 -0
- package/dist/cards-yPK4lBAA.cjs.map +1 -0
- package/dist/cards.cjs +1 -1
- package/dist/cards.js +3 -3
- package/dist/{cn-B_veu23e.js → cn-DZLxql0l.js} +1 -1
- package/dist/{cn-B_veu23e.js.map → cn-DZLxql0l.js.map} +1 -1
- package/dist/{cn-CpRt8Xjj.cjs → cn-SOcVdnX6.cjs} +1 -1
- package/dist/{cn-CpRt8Xjj.cjs.map → cn-SOcVdnX6.cjs.map} +1 -1
- package/dist/components/cards/MCardBusiness/MCardBusiness.d.ts +2 -0
- package/dist/components/cards/MCardBusiness/MCardBusiness.types.d.ts +37 -0
- package/dist/components/cards/MCardBusiness/index.d.ts +4 -0
- package/dist/components/cards/MCardFinance/MCardFinance.d.ts +2 -0
- package/dist/components/cards/MCardFinance/MCardFinance.types.d.ts +16 -0
- package/dist/components/cards/MCardFinance/index.d.ts +4 -0
- package/dist/components/cards/index.d.ts +8 -0
- package/dist/components/data/MCalendarBoard/MCalendarBoard.d.ts +7 -0
- package/dist/components/data/MCalendarBoard/MCalendarBoard.types.d.ts +117 -0
- package/dist/components/data/MCalendarBoard/index.d.ts +4 -0
- package/dist/components/data/MChart/MAreaChart.d.ts +2 -0
- package/dist/components/data/MChart/MBarChart.d.ts +2 -0
- package/dist/components/data/MChart/MChart.d.ts +2 -0
- package/dist/components/data/MChart/MChart.types.d.ts +95 -0
- package/dist/components/data/MChart/MLineChart.d.ts +2 -0
- package/dist/components/data/MChart/MPieChart.d.ts +2 -0
- package/dist/components/data/MChart/charts/MAreaChart.d.ts +27 -0
- package/dist/components/data/MChart/charts/MBarChart.d.ts +26 -0
- package/dist/components/data/MChart/charts/MLineChart.d.ts +26 -0
- package/dist/components/data/MChart/charts/MPieChart.d.ts +19 -0
- package/dist/components/data/MChart/index.d.ts +5 -0
- package/dist/components/data/MChart/parts/ChartAxis.d.ts +13 -0
- package/dist/components/data/MChart/parts/ChartDefs.d.ts +1 -0
- package/dist/components/data/MChart/parts/ChartGrid.d.ts +10 -0
- package/dist/components/data/MChart/parts/ChartLegend.d.ts +9 -0
- package/dist/components/data/MChart/parts/ChartTooltip.d.ts +7 -0
- package/dist/components/data/MChart/utils/formats.d.ts +3 -0
- package/dist/components/data/MChart/utils/paths.d.ts +10 -0
- package/dist/components/data/MChart/utils/scales.d.ts +7 -0
- package/dist/components/data/MChat/MChat.d.ts +2 -0
- package/dist/components/data/MChat/MChat.types.d.ts +77 -0
- package/dist/components/data/MChat/MChatBody.d.ts +2 -0
- package/dist/components/data/MChat/MChatContext.d.ts +6 -0
- package/dist/components/data/MChat/MChatConversationItem.d.ts +2 -0
- package/dist/components/data/MChat/MChatConversationList.d.ts +2 -0
- package/dist/components/data/MChat/MChatHeader.d.ts +2 -0
- package/dist/components/data/MChat/MChatInput.d.ts +2 -0
- package/dist/components/data/MChat/MChatMessage.d.ts +2 -0
- package/dist/components/data/MChat/MChatTypingIndicator.d.ts +2 -0
- package/dist/components/data/MChat/emojis.d.ts +2 -0
- package/dist/components/data/MChat/index.d.ts +9 -0
- package/dist/components/data/MFileManager/MFileManager.d.ts +2 -0
- package/dist/components/data/MFileManager/MFileManager.types.d.ts +70 -0
- package/dist/components/data/MFileManager/index.d.ts +4 -0
- package/dist/components/data/MSparkline/MSparkline.d.ts +2 -0
- package/dist/components/data/MSparkline/MSparkline.types.d.ts +15 -0
- package/dist/components/data/MSparkline/index.d.ts +2 -0
- package/dist/components/data/index.d.ts +20 -0
- package/dist/components/display/MQrCode/MQrCode.d.ts +2 -0
- package/dist/components/display/MQrCode/MQrCode.types.d.ts +11 -0
- package/dist/components/display/MQrCode/index.d.ts +4 -0
- package/dist/components/display/MStepper/MStepper.d.ts +3 -0
- package/dist/components/display/MStepper/MStepper.types.d.ts +20 -0
- package/dist/components/display/MStepper/index.d.ts +2 -0
- package/dist/components/display/MTimeline/MTimeline.d.ts +3 -0
- package/dist/components/display/MTimeline/MTimeline.types.d.ts +16 -0
- package/dist/components/display/MTimeline/index.d.ts +2 -0
- package/dist/components/display/index.d.ts +12 -0
- package/dist/components/feedback/MCookie/MCookieBanner/MCookieBanner.d.ts +3 -0
- package/dist/components/feedback/MCookie/MCookieBanner/MCookieBanner.types.d.ts +27 -0
- package/dist/components/feedback/MCookie/MCookieBanner/index.d.ts +2 -0
- package/dist/components/feedback/MCookie/MCookieBootstrap/MCookieBootstrap.d.ts +6 -0
- package/dist/components/feedback/MCookie/MCookieBootstrap/MCookieBootstrap.types.d.ts +90 -0
- package/dist/components/feedback/MCookie/MCookieBootstrap/index.d.ts +3 -0
- package/dist/components/feedback/MCookie/MCookieConsent/MCookieConsent.d.ts +2 -0
- package/dist/components/feedback/MCookie/MCookieConsent/MCookieConsent.types.d.ts +11 -0
- package/dist/components/feedback/MCookie/MCookieConsent/index.d.ts +2 -0
- package/dist/components/feedback/MCookie/MCookieConsentProvider/MCookieConsent.defaults.d.ts +9 -0
- package/dist/components/feedback/MCookie/MCookieConsentProvider/MCookieConsent.inventory.d.ts +6 -0
- package/dist/components/feedback/MCookie/MCookieConsentProvider/MCookieConsent.storage.d.ts +11 -0
- package/dist/components/feedback/MCookie/MCookieConsentProvider/MCookieConsent.types.d.ts +95 -0
- package/dist/components/feedback/MCookie/MCookieConsentProvider/MCookieConsentContext.d.ts +4 -0
- package/dist/components/feedback/MCookie/MCookieConsentProvider/MCookieConsentProvider.d.ts +2 -0
- package/dist/components/feedback/MCookie/MCookieConsentProvider/index.d.ts +3 -0
- package/dist/components/feedback/MCookie/MCookieDeclaration/MCookieDeclaration.d.ts +2 -0
- package/dist/components/feedback/MCookie/MCookieDeclaration/MCookieDeclaration.types.d.ts +18 -0
- package/dist/components/feedback/MCookie/MCookieDeclaration/index.d.ts +2 -0
- package/dist/components/feedback/MCookie/MCookiePreferences/MCookiePreferences.d.ts +2 -0
- package/dist/components/feedback/MCookie/MCookiePreferences/MCookiePreferences.types.d.ts +25 -0
- package/dist/components/feedback/MCookie/MCookiePreferences/index.d.ts +2 -0
- package/dist/components/feedback/MCookie/MCookieTrigger/MCookieTrigger.d.ts +2 -0
- package/dist/components/feedback/MCookie/MCookieTrigger/MCookieTrigger.types.d.ts +7 -0
- package/dist/components/feedback/MCookie/MCookieTrigger/index.d.ts +2 -0
- package/dist/components/feedback/MCookie/index.d.ts +16 -0
- package/dist/components/feedback/index.d.ts +1 -0
- package/dist/components/layout/MTopbar/MTopbar.d.ts +2 -0
- package/dist/components/layout/MTopbar/MTopbar.types.d.ts +36 -0
- package/dist/components/layout/MTopbar/index.d.ts +2 -0
- package/dist/components/layout/index.d.ts +4 -0
- package/dist/components/media/MAvatarStack/MAvatarStack.d.ts +2 -0
- package/dist/components/media/MAvatarStack/MAvatarStack.types.d.ts +14 -0
- package/dist/components/media/MAvatarStack/index.d.ts +2 -0
- package/dist/components/media/MMasonry/MMasonry.d.ts +2 -0
- package/dist/components/media/MMasonry/MMasonry.types.d.ts +7 -0
- package/dist/components/media/MMasonry/index.d.ts +2 -0
- package/dist/components/media/MMasonryItem/MMasonryItem.d.ts +2 -0
- package/dist/components/media/MMasonryItem/MMasonryItem.types.d.ts +14 -0
- package/dist/components/media/MMasonryItem/index.d.ts +2 -0
- package/dist/components/media/MShowcaseCarousel/MShowcaseCarousel.d.ts +2 -0
- package/dist/components/media/MShowcaseCarousel/MShowcaseCarousel.types.d.ts +19 -0
- package/dist/components/media/MShowcaseCarousel/index.d.ts +2 -0
- package/dist/components/media/MShowcaseCarouselItem/MShowcaseCarouselItem.d.ts +2 -0
- package/dist/components/media/MShowcaseCarouselItem/MShowcaseCarouselItem.types.d.ts +18 -0
- package/dist/components/media/MShowcaseCarouselItem/index.d.ts +2 -0
- package/dist/components/media/index.d.ts +16 -0
- package/dist/controls-DEEbLT5o.cjs +2 -0
- package/dist/controls-DEEbLT5o.cjs.map +1 -0
- package/dist/{controls-1nIh1Ih1.js → controls-IsOBNxW0.js} +33 -74
- package/dist/controls-IsOBNxW0.js.map +1 -0
- package/dist/controls.cjs +1 -1
- package/dist/controls.js +6 -5
- package/dist/cookie-consent-bootstrap.cjs +2 -0
- package/dist/cookie-consent-bootstrap.cjs.map +1 -0
- package/dist/cookie-consent-bootstrap.d.ts +1 -0
- package/dist/cookie-consent-bootstrap.js +93 -0
- package/dist/cookie-consent-bootstrap.js.map +1 -0
- package/dist/{creditCards-BVKi47yn.cjs → creditCards-BjHGqAFx.cjs} +1 -1
- package/dist/{creditCards-BVKi47yn.cjs.map → creditCards-BjHGqAFx.cjs.map} +1 -1
- package/dist/{creditCards-Bk9rsMJf.js → creditCards-CoZpbB1e.js} +1 -1
- package/dist/{creditCards-Bk9rsMJf.js.map → creditCards-CoZpbB1e.js.map} +1 -1
- package/dist/data-BEH7TbuW.cjs +2 -0
- package/dist/data-BEH7TbuW.cjs.map +1 -0
- package/dist/data-Bp3Fd2Al.js +2529 -0
- package/dist/data-Bp3Fd2Al.js.map +1 -0
- package/dist/data.cjs +1 -1
- package/dist/data.js +4 -2
- package/dist/{dateUtils-BYfEWGkb.js → dateUtils-BOsYyWde.js} +1 -1
- package/dist/{dateUtils-BYfEWGkb.js.map → dateUtils-BOsYyWde.js.map} +1 -1
- package/dist/{dateUtils-5jacfR5Q.cjs → dateUtils-xSfrXjbY.cjs} +1 -1
- package/dist/{dateUtils-5jacfR5Q.cjs.map → dateUtils-xSfrXjbY.cjs.map} +1 -1
- package/dist/display-B0Db8pF3.js +468 -0
- package/dist/display-B0Db8pF3.js.map +1 -0
- package/dist/display-DmB5CZYB.cjs +2 -0
- package/dist/display-DmB5CZYB.cjs.map +1 -0
- package/dist/display.cjs +1 -1
- package/dist/display.js +4 -3
- package/dist/dropdowns-BkBtQP4v.js +1689 -0
- package/dist/dropdowns-BkBtQP4v.js.map +1 -0
- package/dist/dropdowns-CD2myl19.cjs +2 -0
- package/dist/dropdowns-CD2myl19.cjs.map +1 -0
- package/dist/dropdowns.cjs +1 -1
- package/dist/dropdowns.js +1 -1
- package/dist/feedback-CuPBnCOw.cjs +2 -0
- package/dist/feedback-CuPBnCOw.cjs.map +1 -0
- package/dist/feedback-QP7-6I7O.js +1013 -0
- package/dist/feedback-QP7-6I7O.js.map +1 -0
- package/dist/feedback.cjs +1 -1
- package/dist/feedback.js +7 -6
- package/dist/{form-DFx61JJJ.cjs → form-BQ6-ieVC.cjs} +2 -2
- package/dist/{form-DFx61JJJ.cjs.map → form-BQ6-ieVC.cjs.map} +1 -1
- package/dist/{form-C7T4heU2.js → form-JanaUHTQ.js} +2 -2
- package/dist/{form-C7T4heU2.js.map → form-JanaUHTQ.js.map} +1 -1
- package/dist/form.cjs +1 -1
- package/dist/form.js +1 -1
- package/dist/{formatters-bW67hwbX.cjs → formatters-BIijIfCB.cjs} +1 -1
- package/dist/{formatters-bW67hwbX.cjs.map → formatters-BIijIfCB.cjs.map} +1 -1
- package/dist/{formatters-qn3Mj74v.js → formatters-DMI5QqhS.js} +1 -1
- package/dist/{formatters-qn3Mj74v.js.map → formatters-DMI5QqhS.js.map} +1 -1
- package/dist/frameworkTexts-5_DBGFFg.js +115 -0
- package/dist/frameworkTexts-5_DBGFFg.js.map +1 -0
- package/dist/frameworkTexts-CwSSRPWS.cjs +2 -0
- package/dist/frameworkTexts-CwSSRPWS.cjs.map +1 -0
- package/dist/icons/MIconV2.d.ts +7 -0
- package/dist/icons/MIconV2Glyph.d.ts +11 -0
- package/dist/icons/MIconV2Scenes.d.ts +40 -0
- package/dist/icons/glyphs/MCalendarIconV2.d.ts +2 -0
- package/dist/icons/glyphs/MChartIconV2.d.ts +2 -0
- package/dist/icons/glyphs/MFlagIconsV2.d.ts +19 -0
- package/dist/icons/glyphs/MHomeIconV2.d.ts +2 -0
- package/dist/icons/glyphs/MNavigationIconsV2.d.ts +14 -0
- package/dist/icons/glyphs/MSearchIconV2.d.ts +2 -0
- package/dist/icons/glyphs/MSettingsIconV2.d.ts +2 -0
- package/dist/icons/glyphs/MUserIconV2.d.ts +2 -0
- package/dist/icons/index.d.ts +12 -0
- package/dist/icons.cjs +1 -1
- package/dist/icons.entry-LwjwnjE2.cjs +2 -0
- package/dist/icons.entry-LwjwnjE2.cjs.map +1 -0
- package/dist/{icons.entry-CbJp27gc.js → icons.entry-txsQqMvb.js} +1663 -985
- package/dist/icons.entry-txsQqMvb.js.map +1 -0
- package/dist/icons.js +22 -17
- package/dist/illustrations.cjs +1 -1
- package/dist/{illustrations.entry-CaBqXBpd.js → illustrations.entry-C0rSNpF1.js} +2 -2
- package/dist/{illustrations.entry-CaBqXBpd.js.map → illustrations.entry-C0rSNpF1.js.map} +1 -1
- package/dist/{illustrations.entry-D5StzALw.cjs → illustrations.entry-DtMxssXq.cjs} +2 -2
- package/dist/{illustrations.entry-D5StzALw.cjs.map → illustrations.entry-DtMxssXq.cjs.map} +1 -1
- package/dist/illustrations.js +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +74 -60
- package/dist/inputs-BRjbpf9P.cjs +2 -0
- package/dist/{inputs-6TRTzH12.cjs.map → inputs-BRjbpf9P.cjs.map} +1 -1
- package/dist/{inputs-Bd_5Xg49.js → inputs-DFoD2MMX.js} +193 -191
- package/dist/{inputs-Bd_5Xg49.js.map → inputs-DFoD2MMX.js.map} +1 -1
- package/dist/inputs.cjs +1 -1
- package/dist/inputs.js +3 -3
- package/dist/layout-BWhQ1VXM.cjs +2 -0
- package/dist/layout-BWhQ1VXM.cjs.map +1 -0
- package/dist/layout-yIAZ4bP6.js +819 -0
- package/dist/layout-yIAZ4bP6.js.map +1 -0
- package/dist/layout.cjs +1 -1
- package/dist/layout.js +5 -5
- package/dist/{layoutProps-CAv0VWdN.cjs → layoutProps-CZ-XhpIX.cjs} +1 -1
- package/dist/{layoutProps-CAv0VWdN.cjs.map → layoutProps-CZ-XhpIX.cjs.map} +1 -1
- package/dist/{layoutProps-D8exMwKp.js → layoutProps-DUPQsWy9.js} +1 -1
- package/dist/{layoutProps-D8exMwKp.js.map → layoutProps-DUPQsWy9.js.map} +1 -1
- package/dist/licensing-CMLexRJk.cjs +2 -0
- package/dist/licensing-CMLexRJk.cjs.map +1 -0
- package/dist/licensing-SQAMYrOI.js +105 -0
- package/dist/licensing-SQAMYrOI.js.map +1 -0
- package/dist/{locale-BJucQij_.js → locale-Crzgecoe.js} +1 -1
- package/dist/{locale-BJucQij_.js.map → locale-Crzgecoe.js.map} +1 -1
- package/dist/{locale-CjYHLr1l.cjs → locale-DpCe_7mG.cjs} +1 -1
- package/dist/{locale-CjYHLr1l.cjs.map → locale-DpCe_7mG.cjs.map} +1 -1
- package/dist/media-D0KRmTG_.cjs +2 -0
- package/dist/media-D0KRmTG_.cjs.map +1 -0
- package/dist/media-DWG2uW1h.js +406 -0
- package/dist/media-DWG2uW1h.js.map +1 -0
- package/dist/media.cjs +1 -1
- package/dist/media.js +4 -3
- package/dist/overlays-CROlfKrR.cjs +2 -0
- package/dist/overlays-CROlfKrR.cjs.map +1 -0
- package/dist/overlays-DQOnI2NS.js +186 -0
- package/dist/overlays-DQOnI2NS.js.map +1 -0
- package/dist/overlays.cjs +1 -1
- package/dist/overlays.js +6 -4
- package/dist/primitives.cjs +1 -1
- package/dist/primitives.js +2 -2
- package/dist/{relativeTime-FdokPH7W.js → relativeTime-3dGgniAK.js} +1 -1
- package/dist/{relativeTime-FdokPH7W.js.map → relativeTime-3dGgniAK.js.map} +1 -1
- package/dist/{relativeTime-oubkDkrk.cjs → relativeTime-D5qYOJVu.cjs} +1 -1
- package/dist/{relativeTime-oubkDkrk.cjs.map → relativeTime-D5qYOJVu.cjs.map} +1 -1
- package/dist/style-runtime.cjs +1 -1
- package/dist/style-runtime.js +1 -1
- package/dist/styles.css +1 -1
- package/dist/typography-CCkJaTzp.js +40 -0
- package/dist/typography-CCkJaTzp.js.map +1 -0
- package/dist/typography-CtITQOAU.cjs +2 -0
- package/dist/typography-CtITQOAU.cjs.map +1 -0
- package/dist/typography.cjs +1 -1
- package/dist/typography.js +5 -4
- package/dist/{useGhostText-BrRYBrV_.cjs → useGhostText-CL1kSB_V.cjs} +1 -1
- package/dist/{useGhostText-BrRYBrV_.cjs.map → useGhostText-CL1kSB_V.cjs.map} +1 -1
- package/dist/{useGhostText-BpSSyl8G.js → useGhostText-Zq3iktss.js} +1 -1
- package/dist/{useGhostText-BpSSyl8G.js.map → useGhostText-Zq3iktss.js.map} +1 -1
- package/dist/{useInteractionEffect-BaJeiUns.cjs → useInteractionEffect-BLehDk91.cjs} +1 -1
- package/dist/{useInteractionEffect-BaJeiUns.cjs.map → useInteractionEffect-BLehDk91.cjs.map} +1 -1
- package/dist/{useInteractionEffect-B5_UpgTt.js → useInteractionEffect-Dfqq8lGO.js} +1 -1
- package/dist/{useInteractionEffect-B5_UpgTt.js.map → useInteractionEffect-Dfqq8lGO.js.map} +1 -1
- package/dist/{useKeyboardNav-DJtFz7Fx.cjs → useKeyboardNav-DBeCcTmg.cjs} +1 -1
- package/dist/{useKeyboardNav-DJtFz7Fx.cjs.map → useKeyboardNav-DBeCcTmg.cjs.map} +1 -1
- package/dist/{useKeyboardNav-CmUKtJag.js → useKeyboardNav-DXvrPrx9.js} +1 -1
- package/dist/{useKeyboardNav-CmUKtJag.js.map → useKeyboardNav-DXvrPrx9.js.map} +1 -1
- package/dist/{useReveal-D1YuWN9z.cjs → useReveal-CdIoh0Rk.cjs} +1 -1
- package/dist/{useReveal-D1YuWN9z.cjs.map → useReveal-CdIoh0Rk.cjs.map} +1 -1
- package/dist/{useReveal-BB9OaMDU.js → useReveal-DzskFHKb.js} +1 -1
- package/dist/{useReveal-BB9OaMDU.js.map → useReveal-DzskFHKb.js.map} +1 -1
- package/dist/utils/licensing.d.ts +78 -1
- package/dist/utils.cjs +1 -1
- package/dist/utils.js +11 -11
- package/dist/{validators-CA-TznrL.cjs → validators-CyDTl6cC.cjs} +1 -1
- package/dist/{validators-CA-TznrL.cjs.map → validators-CyDTl6cC.cjs.map} +1 -1
- package/dist/{validators-CAahqOcq.js → validators-ljBWrIca.js} +1 -1
- package/dist/{validators-CAahqOcq.js.map → validators-ljBWrIca.js.map} +1 -1
- package/package.json +29 -6
- package/dist/MBoltIcon-B1P4i_X4.js.map +0 -1
- package/dist/MBoltIcon-DB6JHWMo.cjs +0 -2
- package/dist/MBoltIcon-DB6JHWMo.cjs.map +0 -1
- package/dist/MCard-BBBA2UVf.cjs +0 -2
- package/dist/MCard-BBBA2UVf.cjs.map +0 -1
- package/dist/MCard-ViJ2Lf73.js +0 -65
- package/dist/MCard-ViJ2Lf73.js.map +0 -1
- package/dist/MDropdownMenu-BcRbNfoR.js +0 -186
- package/dist/MDropdownMenu-BcRbNfoR.js.map +0 -1
- package/dist/MDropdownMenu-DOxSG00i.cjs +0 -2
- package/dist/MDropdownMenu-DOxSG00i.cjs.map +0 -1
- package/dist/MFolderOpenIcon-35Lmw91g.cjs +0 -2
- package/dist/MFolderOpenIcon-35Lmw91g.cjs.map +0 -1
- package/dist/MFolderOpenIcon-DFahkqXu.js +0 -31
- package/dist/MFolderOpenIcon-DFahkqXu.js.map +0 -1
- package/dist/MPagination-C8txsdB6.cjs +0 -2
- package/dist/MPagination-C8txsdB6.cjs.map +0 -1
- package/dist/MPagination-RupoyjxR.js +0 -113
- package/dist/MPagination-RupoyjxR.js.map +0 -1
- package/dist/MRating-0-_XBF-T.js +0 -38
- package/dist/MRating-0-_XBF-T.js.map +0 -1
- package/dist/MRating-B-fQMZ8c.cjs +0 -2
- package/dist/MRating-B-fQMZ8c.cjs.map +0 -1
- package/dist/MSkeleton-7YJwDcvl.cjs +0 -2
- package/dist/MSkeleton-7YJwDcvl.cjs.map +0 -1
- package/dist/MSkeleton-QQ57uNaL.js +0 -39
- package/dist/MSkeleton-QQ57uNaL.js.map +0 -1
- package/dist/MSortIcon-3mD9vpMX.cjs +0 -2
- package/dist/MSortIcon-3mD9vpMX.cjs.map +0 -1
- package/dist/MSortIcon-DGHyltKa.js +0 -84
- package/dist/MSortIcon-DGHyltKa.js.map +0 -1
- package/dist/MText-BxAcAs-j.cjs +0 -2
- package/dist/MText-BxAcAs-j.cjs.map +0 -1
- package/dist/MText-CzceD0k5.js +0 -43
- package/dist/MText-CzceD0k5.js.map +0 -1
- package/dist/MZoomInIcon-BcpTfzRD.cjs +0 -2
- package/dist/MZoomInIcon-BcpTfzRD.cjs.map +0 -1
- package/dist/MZoomInIcon-CK2aJhDg.js.map +0 -1
- package/dist/cards-Bw7aZCIy.cjs +0 -2
- package/dist/cards-Bw7aZCIy.cjs.map +0 -1
- package/dist/cards-CYzgOCG5.js +0 -613
- package/dist/cards-CYzgOCG5.js.map +0 -1
- package/dist/controls-1nIh1Ih1.js.map +0 -1
- package/dist/controls-2pkUWkOa.cjs +0 -2
- package/dist/controls-2pkUWkOa.cjs.map +0 -1
- package/dist/data-BGEuiFne.cjs +0 -2
- package/dist/data-BGEuiFne.cjs.map +0 -1
- package/dist/data-CYb66BuD.js +0 -423
- package/dist/data-CYb66BuD.js.map +0 -1
- package/dist/display-BEw4iW6N.js +0 -416
- package/dist/display-BEw4iW6N.js.map +0 -1
- package/dist/display-BVeaSZDJ.cjs +0 -2
- package/dist/display-BVeaSZDJ.cjs.map +0 -1
- package/dist/dropdowns-CsUSxR0u.cjs +0 -2
- package/dist/dropdowns-CsUSxR0u.cjs.map +0 -1
- package/dist/dropdowns-DiEsLPoq.js +0 -1729
- package/dist/dropdowns-DiEsLPoq.js.map +0 -1
- package/dist/feedback-BOPPNYr5.js +0 -217
- package/dist/feedback-BOPPNYr5.js.map +0 -1
- package/dist/feedback-vTRXpBZw.cjs +0 -2
- package/dist/feedback-vTRXpBZw.cjs.map +0 -1
- package/dist/icons.entry-BBIBT_e2.cjs +0 -2
- package/dist/icons.entry-BBIBT_e2.cjs.map +0 -1
- package/dist/icons.entry-CbJp27gc.js.map +0 -1
- package/dist/inputs-6TRTzH12.cjs +0 -2
- package/dist/layout-DgxSN0QV.js +0 -698
- package/dist/layout-DgxSN0QV.js.map +0 -1
- package/dist/layout-DsxgXjK_.cjs +0 -2
- package/dist/layout-DsxgXjK_.cjs.map +0 -1
- package/dist/licensing-C80xLz-j.cjs +0 -2
- package/dist/licensing-C80xLz-j.cjs.map +0 -1
- package/dist/licensing-DsWLXZiM.js +0 -28
- package/dist/licensing-DsWLXZiM.js.map +0 -1
- package/dist/media-V8oypokY.js +0 -171
- package/dist/media-V8oypokY.js.map +0 -1
- package/dist/media-uvYa5r3D.cjs +0 -2
- package/dist/media-uvYa5r3D.cjs.map +0 -1
- package/dist/overlays-BjO2sRrU.cjs +0 -2
- package/dist/overlays-BjO2sRrU.cjs.map +0 -1
- package/dist/overlays-DnMM32yB.js +0 -360
- package/dist/overlays-DnMM32yB.js.map +0 -1
- package/dist/typography-Bcn3mZPw.js +0 -63
- package/dist/typography-Bcn3mZPw.js.map +0 -1
- package/dist/typography-Cy_-zrZI.cjs +0 -2
- package/dist/typography-Cy_-zrZI.cjs.map +0 -1
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { HTMLAttributes } from 'react';
|
|
2
|
+
import { MColor } from '../../../theme';
|
|
3
|
+
import { MAvatarSize } from '../MAvatar/MAvatar.types';
|
|
4
|
+
export interface MAvatarStackItem {
|
|
5
|
+
name?: string;
|
|
6
|
+
avatar?: string;
|
|
7
|
+
}
|
|
8
|
+
export interface MAvatarStackProps extends HTMLAttributes<HTMLDivElement> {
|
|
9
|
+
items: MAvatarStackItem[];
|
|
10
|
+
max?: number;
|
|
11
|
+
size?: MAvatarSize;
|
|
12
|
+
color?: MColor;
|
|
13
|
+
overlap?: number;
|
|
14
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { ImgHTMLAttributes, ReactNode } from 'react';
|
|
2
|
+
import { MMediaInteractionEffect } from '../mediaInteraction';
|
|
3
|
+
export interface MMasonryItemProps {
|
|
4
|
+
src: string;
|
|
5
|
+
alt?: string;
|
|
6
|
+
height?: number | string;
|
|
7
|
+
overlay?: ReactNode;
|
|
8
|
+
body?: ReactNode;
|
|
9
|
+
footer?: ReactNode;
|
|
10
|
+
interactive?: boolean;
|
|
11
|
+
imageClickEffect?: MMediaInteractionEffect;
|
|
12
|
+
imgProps?: Omit<ImgHTMLAttributes<HTMLImageElement>, 'src' | 'alt' | 'height'>;
|
|
13
|
+
children?: ReactNode;
|
|
14
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { MShowcaseCarouselProps } from './MShowcaseCarousel.types';
|
|
2
|
+
export declare function MShowcaseCarousel<T = unknown>({ items, renderItem, initialIndex, showButtons, loop, draggable, wheel, itemMinWidth, itemMaxWidth, itemWidthRatio, className, children, style, ...rest }: MShowcaseCarouselProps<T>): import("react/jsx-runtime").JSX.Element | null;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { HTMLAttributes, ReactNode } from 'react';
|
|
2
|
+
export interface MShowcaseCarouselSlide {
|
|
3
|
+
src: string;
|
|
4
|
+
alt?: string;
|
|
5
|
+
overlay?: ReactNode;
|
|
6
|
+
}
|
|
7
|
+
export interface MShowcaseCarouselProps<T = unknown> extends HTMLAttributes<HTMLDivElement> {
|
|
8
|
+
items?: T[];
|
|
9
|
+
renderItem?: (item: T, index: number) => ReactNode;
|
|
10
|
+
initialIndex?: number;
|
|
11
|
+
showButtons?: boolean;
|
|
12
|
+
loop?: boolean;
|
|
13
|
+
draggable?: boolean;
|
|
14
|
+
wheel?: boolean;
|
|
15
|
+
itemMinWidth?: number;
|
|
16
|
+
itemMaxWidth?: number;
|
|
17
|
+
itemWidthRatio?: number;
|
|
18
|
+
children?: ReactNode;
|
|
19
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { MShowcaseCarouselItemProps } from './MShowcaseCarouselItem.types';
|
|
2
|
+
export declare function MShowcaseCarouselItem({ src, alt, media, mediaHeight, overlay, body, footer, interactive, imageClickEffect, ratio, fit, imgProps, children, }: MShowcaseCarouselItemProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { ImgHTMLAttributes, ReactNode } from 'react';
|
|
2
|
+
import { MImageFit, MImageRatio } from '../MImage';
|
|
3
|
+
import { MMediaInteractionEffect } from '../mediaInteraction';
|
|
4
|
+
export interface MShowcaseCarouselItemProps {
|
|
5
|
+
src?: string;
|
|
6
|
+
alt?: string;
|
|
7
|
+
media?: ReactNode;
|
|
8
|
+
mediaHeight?: number | string;
|
|
9
|
+
overlay?: ReactNode;
|
|
10
|
+
body?: ReactNode;
|
|
11
|
+
footer?: ReactNode;
|
|
12
|
+
interactive?: boolean;
|
|
13
|
+
imageClickEffect?: MMediaInteractionEffect;
|
|
14
|
+
ratio?: MImageRatio;
|
|
15
|
+
fit?: MImageFit;
|
|
16
|
+
imgProps?: Omit<ImgHTMLAttributes<HTMLImageElement>, 'src' | 'alt'>;
|
|
17
|
+
children?: ReactNode;
|
|
18
|
+
}
|
|
@@ -4,5 +4,21 @@ export { MGallery } from './MGallery';
|
|
|
4
4
|
export type { MGalleryProps, MGalleryItem, MGalleryColumns } from './MGallery';
|
|
5
5
|
export { MCarousel } from './MCarousel';
|
|
6
6
|
export type { MCarouselProps, MCarouselTransition } from './MCarousel';
|
|
7
|
+
/** Marked as a Pro component in MineralUI licensing metadata. */
|
|
8
|
+
export { MShowcaseCarousel } from './MShowcaseCarousel';
|
|
9
|
+
/** Types for a Pro component in MineralUI licensing metadata. */
|
|
10
|
+
export type { MShowcaseCarouselSlide, MShowcaseCarouselProps } from './MShowcaseCarousel';
|
|
11
|
+
export { MShowcaseCarouselItem } from './MShowcaseCarouselItem';
|
|
12
|
+
export type { MShowcaseCarouselItemProps } from './MShowcaseCarouselItem';
|
|
13
|
+
/** Marked as a Pro component in MineralUI licensing metadata. */
|
|
14
|
+
export { MMasonry } from './MMasonry';
|
|
15
|
+
/** Types for a Pro component in MineralUI licensing metadata. */
|
|
16
|
+
export type { MMasonryProps } from './MMasonry';
|
|
17
|
+
export { MMasonryItem } from './MMasonryItem';
|
|
18
|
+
export type { MMasonryItemProps } from './MMasonryItem';
|
|
7
19
|
export { MAvatar } from './MAvatar';
|
|
8
20
|
export type { MAvatarProps, MAvatarSize, MAvatarShape } from './MAvatar';
|
|
21
|
+
/** Marked as a Pro component in MineralUI licensing metadata. */
|
|
22
|
+
export { MAvatarStack } from './MAvatarStack';
|
|
23
|
+
/** Types for a Pro component in MineralUI licensing metadata. */
|
|
24
|
+
export type { MAvatarStackProps, MAvatarStackItem } from './MAvatarStack';
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
const e=require(`./MArrowUpIcon-DWV_HYrz.cjs`),t=require(`./cn-SOcVdnX6.cjs`),n=require(`./useInteractionEffect-BLehDk91.cjs`),r=require(`./MButton-C_WTyNvw.cjs`);let i=require(`react`),a=require(`react/jsx-runtime`);var o=(0,i.forwardRef)(function({orientation:e=`horizontal`,variant:n,size:o,color:s,attached:c=!0,className:l,children:u,...d},f){let p=(0,i.useMemo)(()=>({variant:n,size:o,color:s}),[n,o,s]);return(0,a.jsx)(r.i.Provider,{value:p,children:(0,a.jsx)(`div`,{ref:f,role:`group`,className:t.t(`button-group`,e,c&&`attached`,l),...d,children:u})})}),s=(0,i.createContext)(null);function c(){return(0,i.useContext)(s)}var l=(0,i.forwardRef)(function({checked:e,defaultChecked:r,name:o,id:s,value:l,disabled:u=!1,size:d=`md`,color:f=`primary`,label:p,labelPosition:m=`right`,onChange:h,clickEffect:g=`ripple`,rippleColor:_,className:v,style:y},b){let x=c(),S=x?.name??o,C=x?.disabled??u,w=x?.size??d,T=x?.color??f,E=x?x.value===l:e,{effectClassName:D,effectLayer:O,handlePointerDown:k,triggerEffect:A}=n.t({effect:g,disabled:C,centered:!0,color:_}),j=(0,i.useCallback)(e=>{h?.(e),x?.onChange&&l&&x.onChange(l)},[h,x,l]);return(0,a.jsxs)(`label`,{className:t.t(`radio`,w,m===`left`&&`label-left`,C&&`disabled`,v),style:y,children:[(0,a.jsxs)(`span`,{className:t.t(`circle`,`color-${T}`,D),onPointerDown:k,children:[O,(0,a.jsx)(`input`,{ref:b,type:`radio`,name:S,id:s,value:l,checked:E,defaultChecked:x?void 0:r,disabled:C,onChange:j,onKeyDown:e=>{(e.key===` `||e.key===`Enter`)&&A(e.currentTarget.parentElement)},className:`input`})]}),p&&(0,a.jsx)(`span`,{className:`label-text`,children:p})]})});function u({name:e,value:n,defaultValue:r,onChange:o,direction:c=`vertical`,children:l,disabled:u=!1,size:d=`md`,color:f=`primary`,error:p=!1,errorText:m,label:h,className:g,style:_}){let[v,y]=(0,i.useState)(r),b=n===void 0?v:n,x=(0,i.useCallback)(e=>{n===void 0&&y(e),o?.(e)},[o,n]),S=(0,i.useMemo)(()=>({name:e,value:b,disabled:u,size:d,color:f,onChange:x}),[e,b,u,d,f,x]);return(0,a.jsx)(s.Provider,{value:S,children:(0,a.jsxs)(`fieldset`,{className:t.t(`radio-group`,c,g),style:_,role:`radiogroup`,children:[h&&(0,a.jsx)(`legend`,{className:t.t(`label`,p&&`error`),children:h}),l,m&&(0,a.jsx)(`span`,{className:`field-error`,role:`alert`,children:m})]})})}function d({onLoadMore:e,loading:n=!1,hasMore:o=!0,loaded:s,total:c,auto:l=!1,autoThreshold:u=100,variant:d=`outlined`,color:f=`primary`,label:p=`Load more`,loadingLabel:m=`Loading...`,doneLabel:h=`All items loaded`,className:g,..._}){let v=(0,i.useRef)(null),y=(0,i.useRef)(e);y.current=e,(0,i.useEffect)(()=>{if(!l||!o||n)return;let e=v.current;if(!e)return;let t=new IntersectionObserver(e=>{e[0].isIntersecting&&y.current()},{rootMargin:`${u}px`});return t.observe(e),()=>t.disconnect()},[l,o,n,u]);let b=(0,i.useCallback)(()=>{!n&&o&&e()},[e,n,o]),x=s!==void 0&&c!==void 0;return(0,a.jsxs)(`div`,{className:t.t(`load-more`,g),..._,children:[x&&(0,a.jsxs)(`span`,{className:`load-more-count`,children:[s,` / `,c]}),o?(0,a.jsx)(r.t,{variant:d,color:f,loading:n,onClick:b,className:`load-more-btn`,children:n?m:p}):(0,a.jsx)(`span`,{className:`load-more-done`,children:h}),l&&o&&(0,a.jsx)(`div`,{ref:v,className:`load-more-sentinel`}),x&&(0,a.jsx)(`div`,{className:`load-more-bar`,children:(0,a.jsx)(`div`,{className:`load-more-bar-fill`,style:{width:`${Math.min(s/c*100,100)}%`}})})]})}function f({threshold:n=300,variant:o=`filled`,color:s=`primary`,smooth:c=!0,className:l}){let[u,d]=(0,i.useState)(!1);return(0,i.useEffect)(()=>{function e(){d(window.scrollY>n)}return e(),window.addEventListener(`scroll`,e,{passive:!0}),()=>window.removeEventListener(`scroll`,e)},[n]),(0,a.jsx)(r.t,{variant:o,color:s,shape:`circle`,size:`lg`,iconOnly:!0,onClick:(0,i.useCallback)(()=>{window.scrollTo({top:0,behavior:c?`smooth`:`instant`})},[c]),"aria-label":`Scroll to top`,className:t.t(`scroll-top`,u&&`visible`,l),children:(0,a.jsx)(e.t,{})})}function p(e,t){return(0,a.jsx)(`svg`,{viewBox:`0 0 24 24`,fill:`none`,xmlns:`http://www.w3.org/2000/svg`,"aria-hidden":`true`,...t,children:e})}function m(e){return p((0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(`circle`,{cx:`12`,cy:`12`,r:`10.2`,fill:`#fff`,stroke:`#dadce0`,strokeWidth:`1.2`}),(0,a.jsx)(`path`,{d:`M17.95 12.25c0-.48-.04-.83-.13-1.2H12v2.26h3.42c-.07.56-.48 1.4-1.4 1.97l-.01.08 2 1.52.14.02c1.28-1.15 1.8-2.84 1.8-4.65z`,fill:`#4285F4`}),(0,a.jsx)(`path`,{d:`M12 18.2c1.67 0 3.07-.54 4.1-1.48l-2.13-1.62c-.57.39-1.34.67-1.97.67-1.64 0-3.03-1.06-3.53-2.53l-.08.01-2.08 1.58-.03.08c1.02 1.97 3.09 3.29 5.72 3.29z`,fill:`#34A853`}),(0,a.jsx)(`path`,{d:`M8.47 13.24a3.72 3.72 0 0 1-.2-1.24c0-.43.08-.84.19-1.24l-.01-.08-2.1-1.6-.07.03a6.02 6.02 0 0 0 0 5.78l2.19-1.65z`,fill:`#FBBC05`}),(0,a.jsx)(`path`,{d:`M12 8.22c.8 0 1.53.27 2.1.8l1.54-1.48C14.99 6.96 13.67 6.5 12 6.5c-2.63 0-4.7 1.32-5.72 3.29l2.18 1.66c.5-1.47 1.9-2.53 3.54-2.53z`,fill:`#EA4335`})]}),e)}function h(e){return p((0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(`rect`,{x:`2.2`,y:`2.2`,width:`19.6`,height:`19.6`,rx:`6.2`,fill:`#1877F2`}),(0,a.jsx)(`path`,{d:`M13.28 20v-6.02h2.02l.31-2.43h-2.33V10c0-.78.27-1.37 1.35-1.37h1.11V6.4c-.4-.06-1.09-.11-2.03-.11-2.3 0-3.64 1.22-3.64 3.76v1.49h-1.9v2.44h1.9V20z`,fill:`#fff`})]}),e)}function g(e){return p((0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(`path`,{d:`M15.38 11.84c.02 2.33 2.04 3.1 2.07 3.12-.03.07-.33 1.09-1.06 2.16-.63.91-1.3 1.84-2.34 1.86-1.03.02-1.37-.61-2.57-.61-1.2 0-1.57.59-2.53.63-1.02.04-1.79-1.01-2.43-1.92-1.3-1.89-2.3-5.33-.97-7.64.67-1.15 1.86-1.88 3.14-1.9.98-.02 1.89.65 2.57.65.67 0 1.92-.81 3.24-.69.55.02 2.1.22 3.09 1.67-.08.05-1.84 1.07-1.81 2.67z`,fill:`currentColor`}),(0,a.jsx)(`path`,{d:`M13.59 4.67c.53-.64.9-1.52.8-2.42-.77.04-1.69.52-2.24 1.15-.5.58-.93 1.49-.82 2.35.86.07 1.72-.44 2.26-1.08z`,fill:`currentColor`})]}),e)}function _(e){return p((0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(`rect`,{x:`3.5`,y:`3.5`,width:`7.8`,height:`7.8`,rx:`1.3`,fill:`#F25022`}),(0,a.jsx)(`rect`,{x:`12.7`,y:`3.5`,width:`7.8`,height:`7.8`,rx:`1.3`,fill:`#7FBA00`}),(0,a.jsx)(`rect`,{x:`3.5`,y:`12.7`,width:`7.8`,height:`7.8`,rx:`1.3`,fill:`#00A4EF`}),(0,a.jsx)(`rect`,{x:`12.7`,y:`12.7`,width:`7.8`,height:`7.8`,rx:`1.3`,fill:`#FFB900`})]}),e)}function v(e){return p((0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(`circle`,{cx:`12`,cy:`12`,r:`10.1`,fill:`#fff`}),(0,a.jsx)(`path`,{d:`M12.87 6.76c-2.95 0-4.74 2.03-4.74 4.34 0 1.65.92 3.07 2.38 3.62.1.03.14.01.17-.06l.32-1.23c.05-.14.02-.19-.09-.33-.26-.33-.47-.96-.47-1.57 0-1.52 1.14-2.97 3.08-2.97 1.68 0 2.86 1.14 2.86 2.78 0 1.86-.93 3.13-2.14 3.13-.67 0-1.17-.56-1-1.23.18-.8.55-1.64.55-2.2 0-.51-.28-.93-.84-.93-.67 0-1.2.69-1.2 1.62 0 .59.2.99.2.99l-.78 3.28c-.14.58-.03 1.55.01 1.68.02.08.1.1.15.03.09-.11 1.07-1.49 1.24-2.18l.27-1.06c.25.48.99.89 1.77.89 2.34 0 4.04-2.15 4.04-4.79 0-2.54-2.08-4.44-4.78-4.44z`,fill:`#E60023`})]}),e)}function y(e){return p((0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(`rect`,{x:`2.4`,y:`2.4`,width:`19.2`,height:`19.2`,rx:`4.8`,fill:`#fff`}),(0,a.jsx)(`path`,{d:`M8.1 10.02h2.04v7.24H8.1zm1.03-3.22a1.17 1.17 0 1 1 0 2.35 1.17 1.17 0 0 1 0-2.35zm2.68 3.22h1.95v.99c.34-.61 1.08-1.15 2.13-1.15 2.15 0 2.82 1.42 2.82 3.78v3.62h-2.04v-3.26c0-.98-.35-1.67-1.23-1.67-.66 0-1.05.45-1.23.88-.08.16-.08.38-.08.59v3.46h-2.32z`,fill:`#0A66C2`})]}),e)}var b={google:{label:`Sign in with Google`,iconLabel:`Google`,mode:`google`,Icon:m},facebook:{label:`Sign in with Facebook`,iconLabel:`Facebook`,mode:`outline`,Icon:h},apple:{label:`Sign in with Apple`,iconLabel:`Apple`,mode:`brand`,Icon:g},microsoft:{label:`Sign in with Microsoft`,iconLabel:`Microsoft`,mode:`brand`,Icon:_},pinterest:{label:`Sign in with Pinterest`,iconLabel:`Pinterest`,mode:`brand`,Icon:v},linkedin:{label:`Sign in with LinkedIn`,iconLabel:`LinkedIn`,mode:`brand`,Icon:y}},x=(0,i.forwardRef)(function({platform:e=`google`,variant:i=`outline`,size:o=`md`,iconOnly:s=!1,iconShape:c=`circle`,fullWidth:l=!1,loading:u=!1,active:d=!1,pulsing:f=!1,clickEffect:p=`ripple`,rippleColor:m,className:h,style:g,children:_,disabled:v=!1,type:y=`button`,onPointerDown:x,onKeyDown:S,"aria-label":C,...w},T){let E=b[e],D=E.Icon,O=_??E.label,k=C??(s?E.iconLabel:void 0),A=E.mode===`google`?i:E.mode,j=v||u,{effectClassName:M,effectLayer:N,handlePointerDown:P,triggerEffect:F}=n.t({effect:p,disabled:j,centered:s,color:m});return(0,a.jsxs)(`button`,{ref:T,type:y,className:t.t(`social-button-root`,e,A,o,l&&`full-width`,s&&`icon-only`,s&&`icon-shape-${c}`,u&&`loading`,d&&`active`,f&&`pulsing`,j&&`disabled`,M,h),style:g,disabled:j,"aria-busy":u||void 0,"aria-label":k,onPointerDown:e=>{P(e),x?.(e)},onKeyDown:e=>{(e.key===` `||e.key===`Enter`)&&F(e.currentTarget),S?.(e)},...w,children:[N,u&&(0,a.jsx)(r.r,{size:`sm`,color:`inherit`,className:`social-button-spinner`,"aria-hidden":`true`}),(0,a.jsx)(`span`,{className:`social-button-brand`,"aria-hidden":`true`,children:(0,a.jsx)(D,{className:`social-button-mark`})}),!s&&(0,a.jsx)(`span`,{className:`social-button-label`,children:O})]})});Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return l}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return u}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return f}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return o}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return d}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return x}});
|
|
2
|
+
//# sourceMappingURL=controls-DEEbLT5o.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"controls-DEEbLT5o.cjs","names":[],"sources":["../src/components/controls/MButtonGroup/MButtonGroup.tsx","../src/components/controls/MRadio/RadioContext.ts","../src/components/controls/MRadio/MRadio.tsx","../src/components/controls/MRadio/MRadioGroup.tsx","../src/components/controls/MLoadMore/MLoadMore.tsx","../src/components/controls/MScrollTop/MScrollTop.tsx","../src/components/controls/MSocialButton/MSocialButton.icons.tsx","../src/components/controls/MSocialButton/MSocialButton.tsx"],"sourcesContent":["import {forwardRef, useMemo} from 'react'\nimport type {MButtonGroupProps} from './MButtonGroup.types'\nimport {ButtonGroupContext} from './MButtonGroupContext'\nimport type {MButtonGroupContextValue} from './MButtonGroupContext'\nimport {cn} from '../../../utils/cn'\nimport './MButtonGroup.css'\n\nexport const MButtonGroup = forwardRef<HTMLDivElement, MButtonGroupProps>(function MButtonGroup(\n {orientation = 'horizontal', variant, size, color, attached = true, className, children, ...rest},\n ref\n) {\n const ctx = useMemo<MButtonGroupContextValue>(() => ({variant, size, color}), [variant, size, color])\n\n return (\n <ButtonGroupContext.Provider value={ctx}>\n <div\n ref={ref}\n role=\"group\"\n className={cn('button-group', orientation, attached && 'attached', className)}\n {...rest}\n >\n {children}\n </div>\n </ButtonGroupContext.Provider>\n )\n})\n","import {createContext, useContext} from 'react'\nimport type {MRadioGroupContextValue} from './MRadio.types'\n\nexport const RadioContext = createContext<MRadioGroupContextValue | null>(null)\n\n// Read the nearest radio-group context when a radio participates in grouped state.\nexport function useRadioGroup(): MRadioGroupContextValue | null {\n return useContext(RadioContext)\n}\n","import {forwardRef, useCallback} from 'react'\nimport type * as React from 'react'\nimport type {MRadioProps} from './MRadio.types'\nimport {useRadioGroup} from './RadioContext'\nimport {cn} from '../../../utils/cn'\nimport {useInteractionEffect} from '../../../utils/useInteractionEffect'\nimport './MRadio.css'\n\n// Render a single radio that can work standalone or inside MRadioGroup.\nexport const MRadio = forwardRef<HTMLInputElement, MRadioProps>(function MRadio(\n {\n checked,\n defaultChecked,\n name,\n id,\n value,\n disabled = false,\n size = 'md',\n color = 'primary',\n label,\n labelPosition = 'right',\n onChange,\n clickEffect = 'ripple',\n rippleColor,\n className,\n style,\n },\n ref\n) {\n const group = useRadioGroup()\n\n const resolvedName = group?.name ?? name\n const resolvedDisabled = group?.disabled ?? disabled\n const resolvedSize = group?.size ?? size\n const resolvedColor = group?.color ?? color\n const resolvedChecked = group ? group.value === value : checked\n const {effectClassName, effectLayer, handlePointerDown, triggerEffect} = useInteractionEffect<HTMLSpanElement>({\n effect: clickEffect,\n disabled: resolvedDisabled,\n centered: true,\n color: rippleColor,\n })\n\n // Delegate selection back to the group when one is present.\n const handleChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n onChange?.(event)\n if (group?.onChange && value) {\n group.onChange(value)\n }\n },\n [onChange, group, value]\n )\n\n return (\n <label\n className={cn(\n 'radio',\n resolvedSize,\n labelPosition === 'left' && 'label-left',\n resolvedDisabled && 'disabled',\n className\n )}\n style={style}\n >\n <span className={cn('circle', `color-${resolvedColor}`, effectClassName)} onPointerDown={handlePointerDown}>\n {effectLayer}\n <input\n ref={ref}\n type=\"radio\"\n name={resolvedName}\n id={id}\n value={value}\n checked={resolvedChecked}\n defaultChecked={!group ? defaultChecked : undefined}\n disabled={resolvedDisabled}\n onChange={handleChange}\n onKeyDown={(event) => {\n if (event.key === ' ' || event.key === 'Enter') {\n triggerEffect(event.currentTarget.parentElement as HTMLSpanElement | null)\n }\n }}\n className=\"input\"\n />\n </span>\n {label && <span className=\"label-text\">{label}</span>}\n </label>\n )\n})\n","import {useState, useCallback, useMemo} from 'react'\nimport type {MRadioGroupProps} from './MRadio.types'\nimport {RadioContext} from './RadioContext'\nimport {cn} from '../../../utils/cn'\nimport './MRadio.css'\n\n// Coordinate multiple radio items through shared context and optional controlled state.\nexport function MRadioGroup({\n name,\n value,\n defaultValue,\n onChange,\n direction = 'vertical',\n children,\n disabled = false,\n size = 'md',\n color = 'primary',\n error = false,\n errorText,\n label,\n className,\n style,\n}: MRadioGroupProps) {\n const [internalValue, setInternalValue] = useState(defaultValue)\n const currentValue = value !== undefined ? value : internalValue\n\n // Mirror controlled and uncontrolled usage with the same group API.\n const handleChange = useCallback(\n (val: string) => {\n if (value === undefined) {\n setInternalValue(val)\n }\n onChange?.(val)\n },\n [onChange, value]\n )\n\n // Memoize context so nested radios only update when relevant inputs change.\n const ctx = useMemo(\n () => ({name, value: currentValue, disabled, size, color, onChange: handleChange}),\n [name, currentValue, disabled, size, color, handleChange]\n )\n\n return (\n <RadioContext.Provider value={ctx}>\n <fieldset className={cn('radio-group', direction, className)} style={style} role=\"radiogroup\">\n {label && <legend className={cn('label', error && 'error')}>{label}</legend>}\n {children}\n {errorText && (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n )}\n </fieldset>\n </RadioContext.Provider>\n )\n}\n","import {useEffect, useRef, useCallback} from 'react'\nimport type {MLoadMoreProps} from './MLoadMore.types'\nimport {MButton} from '../MButton'\nimport {cn} from '../../../utils/cn'\nimport './MLoadMore.css'\n\nexport function MLoadMore({\n onLoadMore,\n loading = false,\n hasMore = true,\n loaded,\n total,\n auto = false,\n autoThreshold = 100,\n variant = 'outlined',\n color = 'primary',\n label = 'Load more',\n loadingLabel = 'Loading...',\n doneLabel = 'All items loaded',\n className,\n ...rest\n}: MLoadMoreProps) {\n const sentinelRef = useRef<HTMLDivElement>(null)\n const loadMoreRef = useRef(onLoadMore)\n loadMoreRef.current = onLoadMore\n\n useEffect(() => {\n if (!auto || !hasMore || loading) return\n\n const sentinel = sentinelRef.current\n if (!sentinel) return\n\n const observer = new IntersectionObserver(\n (entries) => {\n if (entries[0].isIntersecting) {\n loadMoreRef.current()\n }\n },\n {rootMargin: `${autoThreshold}px`}\n )\n\n observer.observe(sentinel)\n return () => observer.disconnect()\n }, [auto, hasMore, loading, autoThreshold])\n\n const handleClick = useCallback(() => {\n if (!loading && hasMore) onLoadMore()\n }, [onLoadMore, loading, hasMore])\n\n const showCount = loaded !== undefined && total !== undefined\n\n return (\n <div className={cn('load-more', className)} {...rest}>\n {showCount && (\n <span className=\"load-more-count\">\n {loaded} / {total}\n </span>\n )}\n\n {hasMore ? (\n <MButton\n variant={variant}\n color={color}\n loading={loading}\n onClick={handleClick}\n className=\"load-more-btn\"\n >\n {loading ? loadingLabel : label}\n </MButton>\n ) : (\n <span className=\"load-more-done\">{doneLabel}</span>\n )}\n\n {auto && hasMore && <div ref={sentinelRef} className=\"load-more-sentinel\" />}\n\n {showCount && (\n <div className=\"load-more-bar\">\n <div\n className=\"load-more-bar-fill\"\n style={{width: `${Math.min((loaded / total) * 100, 100)}%`}}\n />\n </div>\n )}\n </div>\n )\n}\n","import {useState, useEffect, useCallback} from 'react'\nimport type {MScrollTopProps} from './MScrollTop.types'\nimport {MButton} from '../MButton'\nimport {MArrowUpIcon} from '../../../icons'\nimport {cn} from '../../../utils/cn'\nimport './MScrollTop.css'\n\nexport function MScrollTop({\n threshold = 300,\n variant = 'filled',\n color = 'primary',\n smooth = true,\n className,\n}: MScrollTopProps) {\n const [visible, setVisible] = useState(false)\n\n useEffect(() => {\n function onScroll() {\n setVisible(window.scrollY > threshold)\n }\n onScroll()\n window.addEventListener('scroll', onScroll, {passive: true})\n return () => window.removeEventListener('scroll', onScroll)\n }, [threshold])\n\n const scrollToTop = useCallback(() => {\n window.scrollTo({top: 0, behavior: smooth ? 'smooth' : 'instant'})\n }, [smooth])\n\n return (\n <MButton\n variant={variant}\n color={color}\n shape=\"circle\"\n size=\"lg\"\n iconOnly\n onClick={scrollToTop}\n aria-label=\"Scroll to top\"\n className={cn('scroll-top', visible && 'visible', className)}\n >\n <MArrowUpIcon />\n </MButton>\n )\n}\n","import type {ReactNode, SVGProps} from 'react'\n\ntype SocialMarkProps = SVGProps<SVGSVGElement>\n\nfunction createMark(children: ReactNode, props: SocialMarkProps) {\n return (\n <svg viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\" {...props}>\n {children}\n </svg>\n )\n}\n\nexport function SocialGoogleMark(props: SocialMarkProps) {\n return createMark(\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10.2\" fill=\"#fff\" stroke=\"#dadce0\" strokeWidth=\"1.2\" />\n <path\n d=\"M17.95 12.25c0-.48-.04-.83-.13-1.2H12v2.26h3.42c-.07.56-.48 1.4-1.4 1.97l-.01.08 2 1.52.14.02c1.28-1.15 1.8-2.84 1.8-4.65z\"\n fill=\"#4285F4\"\n />\n <path\n d=\"M12 18.2c1.67 0 3.07-.54 4.1-1.48l-2.13-1.62c-.57.39-1.34.67-1.97.67-1.64 0-3.03-1.06-3.53-2.53l-.08.01-2.08 1.58-.03.08c1.02 1.97 3.09 3.29 5.72 3.29z\"\n fill=\"#34A853\"\n />\n <path\n d=\"M8.47 13.24a3.72 3.72 0 0 1-.2-1.24c0-.43.08-.84.19-1.24l-.01-.08-2.1-1.6-.07.03a6.02 6.02 0 0 0 0 5.78l2.19-1.65z\"\n fill=\"#FBBC05\"\n />\n <path\n d=\"M12 8.22c.8 0 1.53.27 2.1.8l1.54-1.48C14.99 6.96 13.67 6.5 12 6.5c-2.63 0-4.7 1.32-5.72 3.29l2.18 1.66c.5-1.47 1.9-2.53 3.54-2.53z\"\n fill=\"#EA4335\"\n />\n </>,\n props\n )\n}\n\nexport function SocialFacebookMark(props: SocialMarkProps) {\n return createMark(\n <>\n <rect x=\"2.2\" y=\"2.2\" width=\"19.6\" height=\"19.6\" rx=\"6.2\" fill=\"#1877F2\" />\n <path\n d=\"M13.28 20v-6.02h2.02l.31-2.43h-2.33V10c0-.78.27-1.37 1.35-1.37h1.11V6.4c-.4-.06-1.09-.11-2.03-.11-2.3 0-3.64 1.22-3.64 3.76v1.49h-1.9v2.44h1.9V20z\"\n fill=\"#fff\"\n />\n </>,\n props\n )\n}\n\nexport function SocialAppleMark(props: SocialMarkProps) {\n return createMark(\n <>\n <path\n d=\"M15.38 11.84c.02 2.33 2.04 3.1 2.07 3.12-.03.07-.33 1.09-1.06 2.16-.63.91-1.3 1.84-2.34 1.86-1.03.02-1.37-.61-2.57-.61-1.2 0-1.57.59-2.53.63-1.02.04-1.79-1.01-2.43-1.92-1.3-1.89-2.3-5.33-.97-7.64.67-1.15 1.86-1.88 3.14-1.9.98-.02 1.89.65 2.57.65.67 0 1.92-.81 3.24-.69.55.02 2.1.22 3.09 1.67-.08.05-1.84 1.07-1.81 2.67z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M13.59 4.67c.53-.64.9-1.52.8-2.42-.77.04-1.69.52-2.24 1.15-.5.58-.93 1.49-.82 2.35.86.07 1.72-.44 2.26-1.08z\"\n fill=\"currentColor\"\n />\n </>,\n props\n )\n}\n\nexport function SocialMicrosoftMark(props: SocialMarkProps) {\n return createMark(\n <>\n <rect x=\"3.5\" y=\"3.5\" width=\"7.8\" height=\"7.8\" rx=\"1.3\" fill=\"#F25022\" />\n <rect x=\"12.7\" y=\"3.5\" width=\"7.8\" height=\"7.8\" rx=\"1.3\" fill=\"#7FBA00\" />\n <rect x=\"3.5\" y=\"12.7\" width=\"7.8\" height=\"7.8\" rx=\"1.3\" fill=\"#00A4EF\" />\n <rect x=\"12.7\" y=\"12.7\" width=\"7.8\" height=\"7.8\" rx=\"1.3\" fill=\"#FFB900\" />\n </>,\n props\n )\n}\n\nexport function SocialPinterestMark(props: SocialMarkProps) {\n return createMark(\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10.1\" fill=\"#fff\" />\n <path\n d=\"M12.87 6.76c-2.95 0-4.74 2.03-4.74 4.34 0 1.65.92 3.07 2.38 3.62.1.03.14.01.17-.06l.32-1.23c.05-.14.02-.19-.09-.33-.26-.33-.47-.96-.47-1.57 0-1.52 1.14-2.97 3.08-2.97 1.68 0 2.86 1.14 2.86 2.78 0 1.86-.93 3.13-2.14 3.13-.67 0-1.17-.56-1-1.23.18-.8.55-1.64.55-2.2 0-.51-.28-.93-.84-.93-.67 0-1.2.69-1.2 1.62 0 .59.2.99.2.99l-.78 3.28c-.14.58-.03 1.55.01 1.68.02.08.1.1.15.03.09-.11 1.07-1.49 1.24-2.18l.27-1.06c.25.48.99.89 1.77.89 2.34 0 4.04-2.15 4.04-4.79 0-2.54-2.08-4.44-4.78-4.44z\"\n fill=\"#E60023\"\n />\n </>,\n props\n )\n}\n\nexport function SocialLinkedInMark(props: SocialMarkProps) {\n return createMark(\n <>\n <rect x=\"2.4\" y=\"2.4\" width=\"19.2\" height=\"19.2\" rx=\"4.8\" fill=\"#fff\" />\n <path\n d=\"M8.1 10.02h2.04v7.24H8.1zm1.03-3.22a1.17 1.17 0 1 1 0 2.35 1.17 1.17 0 0 1 0-2.35zm2.68 3.22h1.95v.99c.34-.61 1.08-1.15 2.13-1.15 2.15 0 2.82 1.42 2.82 3.78v3.62h-2.04v-3.26c0-.98-.35-1.67-1.23-1.67-.66 0-1.05.45-1.23.88-.08.16-.08.38-.08.59v3.46h-2.32z\"\n fill=\"#0A66C2\"\n />\n </>,\n props\n )\n}\n","import {forwardRef} from 'react'\nimport type {MSocialButtonProps} from './MSocialButton.types'\nimport {\n SocialAppleMark,\n SocialFacebookMark,\n SocialGoogleMark,\n SocialLinkedInMark,\n SocialMicrosoftMark,\n SocialPinterestMark,\n} from './MSocialButton.icons'\nimport {MSpinner} from '../../feedback'\nimport {cn} from '../../../utils/cn'\nimport {useInteractionEffect} from '../../../utils/useInteractionEffect'\nimport './MSocialButton.css'\n\nconst socialButtonConfig = {\n google: {\n label: 'Sign in with Google',\n iconLabel: 'Google',\n mode: 'google',\n Icon: SocialGoogleMark,\n },\n facebook: {\n label: 'Sign in with Facebook',\n iconLabel: 'Facebook',\n mode: 'outline',\n Icon: SocialFacebookMark,\n },\n apple: {\n label: 'Sign in with Apple',\n iconLabel: 'Apple',\n mode: 'brand',\n Icon: SocialAppleMark,\n },\n microsoft: {\n label: 'Sign in with Microsoft',\n iconLabel: 'Microsoft',\n mode: 'brand',\n Icon: SocialMicrosoftMark,\n },\n pinterest: {\n label: 'Sign in with Pinterest',\n iconLabel: 'Pinterest',\n mode: 'brand',\n Icon: SocialPinterestMark,\n },\n linkedin: {\n label: 'Sign in with LinkedIn',\n iconLabel: 'LinkedIn',\n mode: 'brand',\n Icon: SocialLinkedInMark,\n },\n} as const\n\nexport const MSocialButton = forwardRef<HTMLButtonElement, MSocialButtonProps>(function MSocialButton(\n {\n platform = 'google',\n variant = 'outline',\n size = 'md',\n iconOnly = false,\n iconShape = 'circle',\n fullWidth = false,\n loading = false,\n active = false,\n pulsing = false,\n clickEffect = 'ripple',\n rippleColor,\n className,\n style,\n children,\n disabled = false,\n type = 'button',\n onPointerDown,\n onKeyDown,\n 'aria-label': ariaLabel,\n ...rest\n },\n ref\n) {\n const config = socialButtonConfig[platform]\n const Icon = config.Icon\n const label = children ?? config.label\n const resolvedAriaLabel = ariaLabel ?? (iconOnly ? config.iconLabel : undefined)\n const resolvedVariant = config.mode === 'google' ? variant : config.mode\n const isDisabled = disabled || loading\n const {effectClassName, effectLayer, handlePointerDown, triggerEffect} = useInteractionEffect<HTMLButtonElement>({\n effect: clickEffect,\n disabled: isDisabled,\n centered: iconOnly,\n color: rippleColor,\n })\n\n return (\n <button\n ref={ref}\n type={type}\n className={cn(\n 'social-button-root',\n platform,\n resolvedVariant,\n size,\n fullWidth && 'full-width',\n iconOnly && 'icon-only',\n iconOnly && `icon-shape-${iconShape}`,\n loading && 'loading',\n active && 'active',\n pulsing && 'pulsing',\n isDisabled && 'disabled',\n effectClassName,\n className\n )}\n style={style}\n disabled={isDisabled}\n aria-busy={loading || undefined}\n aria-label={resolvedAriaLabel}\n onPointerDown={(event) => {\n handlePointerDown(event)\n onPointerDown?.(event)\n }}\n onKeyDown={(event) => {\n if (event.key === ' ' || event.key === 'Enter') {\n triggerEffect(event.currentTarget)\n }\n\n onKeyDown?.(event)\n }}\n {...rest}\n >\n {effectLayer}\n {loading && <MSpinner size=\"sm\" color=\"inherit\" className=\"social-button-spinner\" aria-hidden=\"true\" />}\n <span className=\"social-button-brand\" aria-hidden=\"true\">\n <Icon className=\"social-button-mark\" />\n </span>\n {!iconOnly && <span className=\"social-button-label\">{label}</span>}\n </button>\n )\n})\n"],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { t as e } from "./MArrowUpIcon-
|
|
2
|
-
import { t } from "./cn-
|
|
3
|
-
import { t as n } from "./useInteractionEffect-
|
|
4
|
-
import { i as r, r as i, t as a } from "./MButton-
|
|
1
|
+
import { t as e } from "./MArrowUpIcon-Dan-4hs8.js";
|
|
2
|
+
import { t } from "./cn-DZLxql0l.js";
|
|
3
|
+
import { t as n } from "./useInteractionEffect-Dfqq8lGO.js";
|
|
4
|
+
import { i as r, r as i, t as a } from "./MButton-33EzpGvQ.js";
|
|
5
5
|
import { createContext as o, forwardRef as s, useCallback as c, useContext as l, useEffect as u, useMemo as d, useRef as f, useState as p } from "react";
|
|
6
6
|
import { Fragment as m, jsx as h, jsxs as g } from "react/jsx-runtime";
|
|
7
7
|
//#region src/components/controls/MButtonGroup/MButtonGroup.tsx
|
|
@@ -113,49 +113,8 @@ function x({ name: e, value: n, defaultValue: r, onChange: i, direction: a = "ve
|
|
|
113
113
|
});
|
|
114
114
|
}
|
|
115
115
|
//#endregion
|
|
116
|
-
//#region src/components/controls/MToggle/MToggle.tsx
|
|
117
|
-
var S = s(function({ checked: e, defaultChecked: r, name: i, id: a, disabled: o = !1, size: s = "md", color: c = "primary", label: l, labelPosition: u = "right", onChange: d, clickEffect: f = "ripple", rippleColor: p, className: m, style: _ }, v) {
|
|
118
|
-
let { effectClassName: y, effectLayer: b, handlePointerDown: x, triggerEffect: S } = n({
|
|
119
|
-
effect: f,
|
|
120
|
-
disabled: o,
|
|
121
|
-
centered: !0,
|
|
122
|
-
color: p
|
|
123
|
-
});
|
|
124
|
-
return /* @__PURE__ */ g("label", {
|
|
125
|
-
className: t("toggle", s, u === "left" && "label-left", o && "disabled", m),
|
|
126
|
-
style: _,
|
|
127
|
-
children: [/* @__PURE__ */ g("span", {
|
|
128
|
-
className: t("track", `color-${c}`, y),
|
|
129
|
-
onPointerDown: x,
|
|
130
|
-
children: [
|
|
131
|
-
b,
|
|
132
|
-
/* @__PURE__ */ h("input", {
|
|
133
|
-
ref: v,
|
|
134
|
-
type: "checkbox",
|
|
135
|
-
checked: e,
|
|
136
|
-
defaultChecked: r,
|
|
137
|
-
name: i,
|
|
138
|
-
id: a,
|
|
139
|
-
disabled: o,
|
|
140
|
-
onChange: d,
|
|
141
|
-
onKeyDown: (e) => {
|
|
142
|
-
(e.key === " " || e.key === "Enter") && S(e.currentTarget.parentElement);
|
|
143
|
-
},
|
|
144
|
-
className: "input",
|
|
145
|
-
role: "switch",
|
|
146
|
-
"aria-checked": e
|
|
147
|
-
}),
|
|
148
|
-
/* @__PURE__ */ h("span", { className: "knob" })
|
|
149
|
-
]
|
|
150
|
-
}), l && /* @__PURE__ */ h("span", {
|
|
151
|
-
className: "label-text",
|
|
152
|
-
children: l
|
|
153
|
-
})]
|
|
154
|
-
});
|
|
155
|
-
});
|
|
156
|
-
//#endregion
|
|
157
116
|
//#region src/components/controls/MLoadMore/MLoadMore.tsx
|
|
158
|
-
function
|
|
117
|
+
function S({ onLoadMore: e, loading: n = !1, hasMore: r = !0, loaded: i, total: o, auto: s = !1, autoThreshold: l = 100, variant: d = "outlined", color: p = "primary", label: m = "Load more", loadingLabel: _ = "Loading...", doneLabel: v = "All items loaded", className: y, ...b }) {
|
|
159
118
|
let x = f(null), S = f(e);
|
|
160
119
|
S.current = e, u(() => {
|
|
161
120
|
if (!s || !r || n) return;
|
|
@@ -217,7 +176,7 @@ function C({ onLoadMore: e, loading: n = !1, hasMore: r = !0, loaded: i, total:
|
|
|
217
176
|
}
|
|
218
177
|
//#endregion
|
|
219
178
|
//#region src/components/controls/MScrollTop/MScrollTop.tsx
|
|
220
|
-
function
|
|
179
|
+
function C({ threshold: n = 300, variant: r = "filled", color: i = "primary", smooth: o = !0, className: s }) {
|
|
221
180
|
let [l, d] = p(!1);
|
|
222
181
|
return u(() => {
|
|
223
182
|
function e() {
|
|
@@ -243,7 +202,7 @@ function w({ threshold: n = 300, variant: r = "filled", color: i = "primary", sm
|
|
|
243
202
|
}
|
|
244
203
|
//#endregion
|
|
245
204
|
//#region src/components/controls/MSocialButton/MSocialButton.icons.tsx
|
|
246
|
-
function
|
|
205
|
+
function w(e, t) {
|
|
247
206
|
return /* @__PURE__ */ h("svg", {
|
|
248
207
|
viewBox: "0 0 24 24",
|
|
249
208
|
fill: "none",
|
|
@@ -253,8 +212,8 @@ function T(e, t) {
|
|
|
253
212
|
children: e
|
|
254
213
|
});
|
|
255
214
|
}
|
|
256
|
-
function
|
|
257
|
-
return
|
|
215
|
+
function T(e) {
|
|
216
|
+
return w(/* @__PURE__ */ g(m, { children: [
|
|
258
217
|
/* @__PURE__ */ h("circle", {
|
|
259
218
|
cx: "12",
|
|
260
219
|
cy: "12",
|
|
@@ -281,8 +240,8 @@ function E(e) {
|
|
|
281
240
|
})
|
|
282
241
|
] }), e);
|
|
283
242
|
}
|
|
284
|
-
function
|
|
285
|
-
return
|
|
243
|
+
function E(e) {
|
|
244
|
+
return w(/* @__PURE__ */ g(m, { children: [/* @__PURE__ */ h("rect", {
|
|
286
245
|
x: "2.2",
|
|
287
246
|
y: "2.2",
|
|
288
247
|
width: "19.6",
|
|
@@ -294,8 +253,8 @@ function D(e) {
|
|
|
294
253
|
fill: "#fff"
|
|
295
254
|
})] }), e);
|
|
296
255
|
}
|
|
297
|
-
function
|
|
298
|
-
return
|
|
256
|
+
function D(e) {
|
|
257
|
+
return w(/* @__PURE__ */ g(m, { children: [/* @__PURE__ */ h("path", {
|
|
299
258
|
d: "M15.38 11.84c.02 2.33 2.04 3.1 2.07 3.12-.03.07-.33 1.09-1.06 2.16-.63.91-1.3 1.84-2.34 1.86-1.03.02-1.37-.61-2.57-.61-1.2 0-1.57.59-2.53.63-1.02.04-1.79-1.01-2.43-1.92-1.3-1.89-2.3-5.33-.97-7.64.67-1.15 1.86-1.88 3.14-1.9.98-.02 1.89.65 2.57.65.67 0 1.92-.81 3.24-.69.55.02 2.1.22 3.09 1.67-.08.05-1.84 1.07-1.81 2.67z",
|
|
300
259
|
fill: "currentColor"
|
|
301
260
|
}), /* @__PURE__ */ h("path", {
|
|
@@ -303,8 +262,8 @@ function O(e) {
|
|
|
303
262
|
fill: "currentColor"
|
|
304
263
|
})] }), e);
|
|
305
264
|
}
|
|
306
|
-
function
|
|
307
|
-
return
|
|
265
|
+
function O(e) {
|
|
266
|
+
return w(/* @__PURE__ */ g(m, { children: [
|
|
308
267
|
/* @__PURE__ */ h("rect", {
|
|
309
268
|
x: "3.5",
|
|
310
269
|
y: "3.5",
|
|
@@ -339,8 +298,8 @@ function k(e) {
|
|
|
339
298
|
})
|
|
340
299
|
] }), e);
|
|
341
300
|
}
|
|
342
|
-
function
|
|
343
|
-
return
|
|
301
|
+
function k(e) {
|
|
302
|
+
return w(/* @__PURE__ */ g(m, { children: [/* @__PURE__ */ h("circle", {
|
|
344
303
|
cx: "12",
|
|
345
304
|
cy: "12",
|
|
346
305
|
r: "10.1",
|
|
@@ -350,8 +309,8 @@ function A(e) {
|
|
|
350
309
|
fill: "#E60023"
|
|
351
310
|
})] }), e);
|
|
352
311
|
}
|
|
353
|
-
function
|
|
354
|
-
return
|
|
312
|
+
function A(e) {
|
|
313
|
+
return w(/* @__PURE__ */ g(m, { children: [/* @__PURE__ */ h("rect", {
|
|
355
314
|
x: "2.4",
|
|
356
315
|
y: "2.4",
|
|
357
316
|
width: "19.2",
|
|
@@ -365,56 +324,56 @@ function j(e) {
|
|
|
365
324
|
}
|
|
366
325
|
//#endregion
|
|
367
326
|
//#region src/components/controls/MSocialButton/MSocialButton.tsx
|
|
368
|
-
var
|
|
327
|
+
var j = {
|
|
369
328
|
google: {
|
|
370
329
|
label: "Sign in with Google",
|
|
371
330
|
iconLabel: "Google",
|
|
372
331
|
mode: "google",
|
|
373
|
-
Icon:
|
|
332
|
+
Icon: T
|
|
374
333
|
},
|
|
375
334
|
facebook: {
|
|
376
335
|
label: "Sign in with Facebook",
|
|
377
336
|
iconLabel: "Facebook",
|
|
378
337
|
mode: "outline",
|
|
379
|
-
Icon:
|
|
338
|
+
Icon: E
|
|
380
339
|
},
|
|
381
340
|
apple: {
|
|
382
341
|
label: "Sign in with Apple",
|
|
383
342
|
iconLabel: "Apple",
|
|
384
343
|
mode: "brand",
|
|
385
|
-
Icon:
|
|
344
|
+
Icon: D
|
|
386
345
|
},
|
|
387
346
|
microsoft: {
|
|
388
347
|
label: "Sign in with Microsoft",
|
|
389
348
|
iconLabel: "Microsoft",
|
|
390
349
|
mode: "brand",
|
|
391
|
-
Icon:
|
|
350
|
+
Icon: O
|
|
392
351
|
},
|
|
393
352
|
pinterest: {
|
|
394
353
|
label: "Sign in with Pinterest",
|
|
395
354
|
iconLabel: "Pinterest",
|
|
396
355
|
mode: "brand",
|
|
397
|
-
Icon:
|
|
356
|
+
Icon: k
|
|
398
357
|
},
|
|
399
358
|
linkedin: {
|
|
400
359
|
label: "Sign in with LinkedIn",
|
|
401
360
|
iconLabel: "LinkedIn",
|
|
402
361
|
mode: "brand",
|
|
403
|
-
Icon:
|
|
362
|
+
Icon: A
|
|
404
363
|
}
|
|
405
|
-
},
|
|
406
|
-
let E =
|
|
364
|
+
}, M = s(function({ platform: e = "google", variant: r = "outline", size: a = "md", iconOnly: o = !1, iconShape: s = "circle", fullWidth: c = !1, loading: l = !1, active: u = !1, pulsing: d = !1, clickEffect: f = "ripple", rippleColor: p, className: m, style: _, children: v, disabled: y = !1, type: b = "button", onPointerDown: x, onKeyDown: S, "aria-label": C, ...w }, T) {
|
|
365
|
+
let E = j[e], D = E.Icon, O = v ?? E.label, k = C ?? (o ? E.iconLabel : void 0), A = E.mode === "google" ? r : E.mode, M = y || l, { effectClassName: N, effectLayer: P, handlePointerDown: F, triggerEffect: I } = n({
|
|
407
366
|
effect: f,
|
|
408
|
-
disabled:
|
|
367
|
+
disabled: M,
|
|
409
368
|
centered: o,
|
|
410
369
|
color: p
|
|
411
370
|
});
|
|
412
371
|
return /* @__PURE__ */ g("button", {
|
|
413
372
|
ref: T,
|
|
414
373
|
type: b,
|
|
415
|
-
className: t("social-button-root", e, A, a, c && "full-width", o && "icon-only", o && `icon-shape-${s}`, l && "loading", u && "active", d && "pulsing",
|
|
374
|
+
className: t("social-button-root", e, A, a, c && "full-width", o && "icon-only", o && `icon-shape-${s}`, l && "loading", u && "active", d && "pulsing", M && "disabled", N, m),
|
|
416
375
|
style: _,
|
|
417
|
-
disabled:
|
|
376
|
+
disabled: M,
|
|
418
377
|
"aria-busy": l || void 0,
|
|
419
378
|
"aria-label": k,
|
|
420
379
|
onPointerDown: (e) => {
|
|
@@ -445,6 +404,6 @@ var M = {
|
|
|
445
404
|
});
|
|
446
405
|
});
|
|
447
406
|
//#endregion
|
|
448
|
-
export {
|
|
407
|
+
export { b as a, x as i, C as n, _ as o, S as r, M as t };
|
|
449
408
|
|
|
450
|
-
//# sourceMappingURL=controls-
|
|
409
|
+
//# sourceMappingURL=controls-IsOBNxW0.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"controls-IsOBNxW0.js","names":[],"sources":["../src/components/controls/MButtonGroup/MButtonGroup.tsx","../src/components/controls/MRadio/RadioContext.ts","../src/components/controls/MRadio/MRadio.tsx","../src/components/controls/MRadio/MRadioGroup.tsx","../src/components/controls/MLoadMore/MLoadMore.tsx","../src/components/controls/MScrollTop/MScrollTop.tsx","../src/components/controls/MSocialButton/MSocialButton.icons.tsx","../src/components/controls/MSocialButton/MSocialButton.tsx"],"sourcesContent":["import {forwardRef, useMemo} from 'react'\nimport type {MButtonGroupProps} from './MButtonGroup.types'\nimport {ButtonGroupContext} from './MButtonGroupContext'\nimport type {MButtonGroupContextValue} from './MButtonGroupContext'\nimport {cn} from '../../../utils/cn'\nimport './MButtonGroup.css'\n\nexport const MButtonGroup = forwardRef<HTMLDivElement, MButtonGroupProps>(function MButtonGroup(\n {orientation = 'horizontal', variant, size, color, attached = true, className, children, ...rest},\n ref\n) {\n const ctx = useMemo<MButtonGroupContextValue>(() => ({variant, size, color}), [variant, size, color])\n\n return (\n <ButtonGroupContext.Provider value={ctx}>\n <div\n ref={ref}\n role=\"group\"\n className={cn('button-group', orientation, attached && 'attached', className)}\n {...rest}\n >\n {children}\n </div>\n </ButtonGroupContext.Provider>\n )\n})\n","import {createContext, useContext} from 'react'\nimport type {MRadioGroupContextValue} from './MRadio.types'\n\nexport const RadioContext = createContext<MRadioGroupContextValue | null>(null)\n\n// Read the nearest radio-group context when a radio participates in grouped state.\nexport function useRadioGroup(): MRadioGroupContextValue | null {\n return useContext(RadioContext)\n}\n","import {forwardRef, useCallback} from 'react'\nimport type * as React from 'react'\nimport type {MRadioProps} from './MRadio.types'\nimport {useRadioGroup} from './RadioContext'\nimport {cn} from '../../../utils/cn'\nimport {useInteractionEffect} from '../../../utils/useInteractionEffect'\nimport './MRadio.css'\n\n// Render a single radio that can work standalone or inside MRadioGroup.\nexport const MRadio = forwardRef<HTMLInputElement, MRadioProps>(function MRadio(\n {\n checked,\n defaultChecked,\n name,\n id,\n value,\n disabled = false,\n size = 'md',\n color = 'primary',\n label,\n labelPosition = 'right',\n onChange,\n clickEffect = 'ripple',\n rippleColor,\n className,\n style,\n },\n ref\n) {\n const group = useRadioGroup()\n\n const resolvedName = group?.name ?? name\n const resolvedDisabled = group?.disabled ?? disabled\n const resolvedSize = group?.size ?? size\n const resolvedColor = group?.color ?? color\n const resolvedChecked = group ? group.value === value : checked\n const {effectClassName, effectLayer, handlePointerDown, triggerEffect} = useInteractionEffect<HTMLSpanElement>({\n effect: clickEffect,\n disabled: resolvedDisabled,\n centered: true,\n color: rippleColor,\n })\n\n // Delegate selection back to the group when one is present.\n const handleChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n onChange?.(event)\n if (group?.onChange && value) {\n group.onChange(value)\n }\n },\n [onChange, group, value]\n )\n\n return (\n <label\n className={cn(\n 'radio',\n resolvedSize,\n labelPosition === 'left' && 'label-left',\n resolvedDisabled && 'disabled',\n className\n )}\n style={style}\n >\n <span className={cn('circle', `color-${resolvedColor}`, effectClassName)} onPointerDown={handlePointerDown}>\n {effectLayer}\n <input\n ref={ref}\n type=\"radio\"\n name={resolvedName}\n id={id}\n value={value}\n checked={resolvedChecked}\n defaultChecked={!group ? defaultChecked : undefined}\n disabled={resolvedDisabled}\n onChange={handleChange}\n onKeyDown={(event) => {\n if (event.key === ' ' || event.key === 'Enter') {\n triggerEffect(event.currentTarget.parentElement as HTMLSpanElement | null)\n }\n }}\n className=\"input\"\n />\n </span>\n {label && <span className=\"label-text\">{label}</span>}\n </label>\n )\n})\n","import {useState, useCallback, useMemo} from 'react'\nimport type {MRadioGroupProps} from './MRadio.types'\nimport {RadioContext} from './RadioContext'\nimport {cn} from '../../../utils/cn'\nimport './MRadio.css'\n\n// Coordinate multiple radio items through shared context and optional controlled state.\nexport function MRadioGroup({\n name,\n value,\n defaultValue,\n onChange,\n direction = 'vertical',\n children,\n disabled = false,\n size = 'md',\n color = 'primary',\n error = false,\n errorText,\n label,\n className,\n style,\n}: MRadioGroupProps) {\n const [internalValue, setInternalValue] = useState(defaultValue)\n const currentValue = value !== undefined ? value : internalValue\n\n // Mirror controlled and uncontrolled usage with the same group API.\n const handleChange = useCallback(\n (val: string) => {\n if (value === undefined) {\n setInternalValue(val)\n }\n onChange?.(val)\n },\n [onChange, value]\n )\n\n // Memoize context so nested radios only update when relevant inputs change.\n const ctx = useMemo(\n () => ({name, value: currentValue, disabled, size, color, onChange: handleChange}),\n [name, currentValue, disabled, size, color, handleChange]\n )\n\n return (\n <RadioContext.Provider value={ctx}>\n <fieldset className={cn('radio-group', direction, className)} style={style} role=\"radiogroup\">\n {label && <legend className={cn('label', error && 'error')}>{label}</legend>}\n {children}\n {errorText && (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n )}\n </fieldset>\n </RadioContext.Provider>\n )\n}\n","import {useEffect, useRef, useCallback} from 'react'\nimport type {MLoadMoreProps} from './MLoadMore.types'\nimport {MButton} from '../MButton'\nimport {cn} from '../../../utils/cn'\nimport './MLoadMore.css'\n\nexport function MLoadMore({\n onLoadMore,\n loading = false,\n hasMore = true,\n loaded,\n total,\n auto = false,\n autoThreshold = 100,\n variant = 'outlined',\n color = 'primary',\n label = 'Load more',\n loadingLabel = 'Loading...',\n doneLabel = 'All items loaded',\n className,\n ...rest\n}: MLoadMoreProps) {\n const sentinelRef = useRef<HTMLDivElement>(null)\n const loadMoreRef = useRef(onLoadMore)\n loadMoreRef.current = onLoadMore\n\n useEffect(() => {\n if (!auto || !hasMore || loading) return\n\n const sentinel = sentinelRef.current\n if (!sentinel) return\n\n const observer = new IntersectionObserver(\n (entries) => {\n if (entries[0].isIntersecting) {\n loadMoreRef.current()\n }\n },\n {rootMargin: `${autoThreshold}px`}\n )\n\n observer.observe(sentinel)\n return () => observer.disconnect()\n }, [auto, hasMore, loading, autoThreshold])\n\n const handleClick = useCallback(() => {\n if (!loading && hasMore) onLoadMore()\n }, [onLoadMore, loading, hasMore])\n\n const showCount = loaded !== undefined && total !== undefined\n\n return (\n <div className={cn('load-more', className)} {...rest}>\n {showCount && (\n <span className=\"load-more-count\">\n {loaded} / {total}\n </span>\n )}\n\n {hasMore ? (\n <MButton\n variant={variant}\n color={color}\n loading={loading}\n onClick={handleClick}\n className=\"load-more-btn\"\n >\n {loading ? loadingLabel : label}\n </MButton>\n ) : (\n <span className=\"load-more-done\">{doneLabel}</span>\n )}\n\n {auto && hasMore && <div ref={sentinelRef} className=\"load-more-sentinel\" />}\n\n {showCount && (\n <div className=\"load-more-bar\">\n <div\n className=\"load-more-bar-fill\"\n style={{width: `${Math.min((loaded / total) * 100, 100)}%`}}\n />\n </div>\n )}\n </div>\n )\n}\n","import {useState, useEffect, useCallback} from 'react'\nimport type {MScrollTopProps} from './MScrollTop.types'\nimport {MButton} from '../MButton'\nimport {MArrowUpIcon} from '../../../icons'\nimport {cn} from '../../../utils/cn'\nimport './MScrollTop.css'\n\nexport function MScrollTop({\n threshold = 300,\n variant = 'filled',\n color = 'primary',\n smooth = true,\n className,\n}: MScrollTopProps) {\n const [visible, setVisible] = useState(false)\n\n useEffect(() => {\n function onScroll() {\n setVisible(window.scrollY > threshold)\n }\n onScroll()\n window.addEventListener('scroll', onScroll, {passive: true})\n return () => window.removeEventListener('scroll', onScroll)\n }, [threshold])\n\n const scrollToTop = useCallback(() => {\n window.scrollTo({top: 0, behavior: smooth ? 'smooth' : 'instant'})\n }, [smooth])\n\n return (\n <MButton\n variant={variant}\n color={color}\n shape=\"circle\"\n size=\"lg\"\n iconOnly\n onClick={scrollToTop}\n aria-label=\"Scroll to top\"\n className={cn('scroll-top', visible && 'visible', className)}\n >\n <MArrowUpIcon />\n </MButton>\n )\n}\n","import type {ReactNode, SVGProps} from 'react'\n\ntype SocialMarkProps = SVGProps<SVGSVGElement>\n\nfunction createMark(children: ReactNode, props: SocialMarkProps) {\n return (\n <svg viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\" {...props}>\n {children}\n </svg>\n )\n}\n\nexport function SocialGoogleMark(props: SocialMarkProps) {\n return createMark(\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10.2\" fill=\"#fff\" stroke=\"#dadce0\" strokeWidth=\"1.2\" />\n <path\n d=\"M17.95 12.25c0-.48-.04-.83-.13-1.2H12v2.26h3.42c-.07.56-.48 1.4-1.4 1.97l-.01.08 2 1.52.14.02c1.28-1.15 1.8-2.84 1.8-4.65z\"\n fill=\"#4285F4\"\n />\n <path\n d=\"M12 18.2c1.67 0 3.07-.54 4.1-1.48l-2.13-1.62c-.57.39-1.34.67-1.97.67-1.64 0-3.03-1.06-3.53-2.53l-.08.01-2.08 1.58-.03.08c1.02 1.97 3.09 3.29 5.72 3.29z\"\n fill=\"#34A853\"\n />\n <path\n d=\"M8.47 13.24a3.72 3.72 0 0 1-.2-1.24c0-.43.08-.84.19-1.24l-.01-.08-2.1-1.6-.07.03a6.02 6.02 0 0 0 0 5.78l2.19-1.65z\"\n fill=\"#FBBC05\"\n />\n <path\n d=\"M12 8.22c.8 0 1.53.27 2.1.8l1.54-1.48C14.99 6.96 13.67 6.5 12 6.5c-2.63 0-4.7 1.32-5.72 3.29l2.18 1.66c.5-1.47 1.9-2.53 3.54-2.53z\"\n fill=\"#EA4335\"\n />\n </>,\n props\n )\n}\n\nexport function SocialFacebookMark(props: SocialMarkProps) {\n return createMark(\n <>\n <rect x=\"2.2\" y=\"2.2\" width=\"19.6\" height=\"19.6\" rx=\"6.2\" fill=\"#1877F2\" />\n <path\n d=\"M13.28 20v-6.02h2.02l.31-2.43h-2.33V10c0-.78.27-1.37 1.35-1.37h1.11V6.4c-.4-.06-1.09-.11-2.03-.11-2.3 0-3.64 1.22-3.64 3.76v1.49h-1.9v2.44h1.9V20z\"\n fill=\"#fff\"\n />\n </>,\n props\n )\n}\n\nexport function SocialAppleMark(props: SocialMarkProps) {\n return createMark(\n <>\n <path\n d=\"M15.38 11.84c.02 2.33 2.04 3.1 2.07 3.12-.03.07-.33 1.09-1.06 2.16-.63.91-1.3 1.84-2.34 1.86-1.03.02-1.37-.61-2.57-.61-1.2 0-1.57.59-2.53.63-1.02.04-1.79-1.01-2.43-1.92-1.3-1.89-2.3-5.33-.97-7.64.67-1.15 1.86-1.88 3.14-1.9.98-.02 1.89.65 2.57.65.67 0 1.92-.81 3.24-.69.55.02 2.1.22 3.09 1.67-.08.05-1.84 1.07-1.81 2.67z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M13.59 4.67c.53-.64.9-1.52.8-2.42-.77.04-1.69.52-2.24 1.15-.5.58-.93 1.49-.82 2.35.86.07 1.72-.44 2.26-1.08z\"\n fill=\"currentColor\"\n />\n </>,\n props\n )\n}\n\nexport function SocialMicrosoftMark(props: SocialMarkProps) {\n return createMark(\n <>\n <rect x=\"3.5\" y=\"3.5\" width=\"7.8\" height=\"7.8\" rx=\"1.3\" fill=\"#F25022\" />\n <rect x=\"12.7\" y=\"3.5\" width=\"7.8\" height=\"7.8\" rx=\"1.3\" fill=\"#7FBA00\" />\n <rect x=\"3.5\" y=\"12.7\" width=\"7.8\" height=\"7.8\" rx=\"1.3\" fill=\"#00A4EF\" />\n <rect x=\"12.7\" y=\"12.7\" width=\"7.8\" height=\"7.8\" rx=\"1.3\" fill=\"#FFB900\" />\n </>,\n props\n )\n}\n\nexport function SocialPinterestMark(props: SocialMarkProps) {\n return createMark(\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10.1\" fill=\"#fff\" />\n <path\n d=\"M12.87 6.76c-2.95 0-4.74 2.03-4.74 4.34 0 1.65.92 3.07 2.38 3.62.1.03.14.01.17-.06l.32-1.23c.05-.14.02-.19-.09-.33-.26-.33-.47-.96-.47-1.57 0-1.52 1.14-2.97 3.08-2.97 1.68 0 2.86 1.14 2.86 2.78 0 1.86-.93 3.13-2.14 3.13-.67 0-1.17-.56-1-1.23.18-.8.55-1.64.55-2.2 0-.51-.28-.93-.84-.93-.67 0-1.2.69-1.2 1.62 0 .59.2.99.2.99l-.78 3.28c-.14.58-.03 1.55.01 1.68.02.08.1.1.15.03.09-.11 1.07-1.49 1.24-2.18l.27-1.06c.25.48.99.89 1.77.89 2.34 0 4.04-2.15 4.04-4.79 0-2.54-2.08-4.44-4.78-4.44z\"\n fill=\"#E60023\"\n />\n </>,\n props\n )\n}\n\nexport function SocialLinkedInMark(props: SocialMarkProps) {\n return createMark(\n <>\n <rect x=\"2.4\" y=\"2.4\" width=\"19.2\" height=\"19.2\" rx=\"4.8\" fill=\"#fff\" />\n <path\n d=\"M8.1 10.02h2.04v7.24H8.1zm1.03-3.22a1.17 1.17 0 1 1 0 2.35 1.17 1.17 0 0 1 0-2.35zm2.68 3.22h1.95v.99c.34-.61 1.08-1.15 2.13-1.15 2.15 0 2.82 1.42 2.82 3.78v3.62h-2.04v-3.26c0-.98-.35-1.67-1.23-1.67-.66 0-1.05.45-1.23.88-.08.16-.08.38-.08.59v3.46h-2.32z\"\n fill=\"#0A66C2\"\n />\n </>,\n props\n )\n}\n","import {forwardRef} from 'react'\nimport type {MSocialButtonProps} from './MSocialButton.types'\nimport {\n SocialAppleMark,\n SocialFacebookMark,\n SocialGoogleMark,\n SocialLinkedInMark,\n SocialMicrosoftMark,\n SocialPinterestMark,\n} from './MSocialButton.icons'\nimport {MSpinner} from '../../feedback'\nimport {cn} from '../../../utils/cn'\nimport {useInteractionEffect} from '../../../utils/useInteractionEffect'\nimport './MSocialButton.css'\n\nconst socialButtonConfig = {\n google: {\n label: 'Sign in with Google',\n iconLabel: 'Google',\n mode: 'google',\n Icon: SocialGoogleMark,\n },\n facebook: {\n label: 'Sign in with Facebook',\n iconLabel: 'Facebook',\n mode: 'outline',\n Icon: SocialFacebookMark,\n },\n apple: {\n label: 'Sign in with Apple',\n iconLabel: 'Apple',\n mode: 'brand',\n Icon: SocialAppleMark,\n },\n microsoft: {\n label: 'Sign in with Microsoft',\n iconLabel: 'Microsoft',\n mode: 'brand',\n Icon: SocialMicrosoftMark,\n },\n pinterest: {\n label: 'Sign in with Pinterest',\n iconLabel: 'Pinterest',\n mode: 'brand',\n Icon: SocialPinterestMark,\n },\n linkedin: {\n label: 'Sign in with LinkedIn',\n iconLabel: 'LinkedIn',\n mode: 'brand',\n Icon: SocialLinkedInMark,\n },\n} as const\n\nexport const MSocialButton = forwardRef<HTMLButtonElement, MSocialButtonProps>(function MSocialButton(\n {\n platform = 'google',\n variant = 'outline',\n size = 'md',\n iconOnly = false,\n iconShape = 'circle',\n fullWidth = false,\n loading = false,\n active = false,\n pulsing = false,\n clickEffect = 'ripple',\n rippleColor,\n className,\n style,\n children,\n disabled = false,\n type = 'button',\n onPointerDown,\n onKeyDown,\n 'aria-label': ariaLabel,\n ...rest\n },\n ref\n) {\n const config = socialButtonConfig[platform]\n const Icon = config.Icon\n const label = children ?? config.label\n const resolvedAriaLabel = ariaLabel ?? (iconOnly ? config.iconLabel : undefined)\n const resolvedVariant = config.mode === 'google' ? variant : config.mode\n const isDisabled = disabled || loading\n const {effectClassName, effectLayer, handlePointerDown, triggerEffect} = useInteractionEffect<HTMLButtonElement>({\n effect: clickEffect,\n disabled: isDisabled,\n centered: iconOnly,\n color: rippleColor,\n })\n\n return (\n <button\n ref={ref}\n type={type}\n className={cn(\n 'social-button-root',\n platform,\n resolvedVariant,\n size,\n fullWidth && 'full-width',\n iconOnly && 'icon-only',\n iconOnly && `icon-shape-${iconShape}`,\n loading && 'loading',\n active && 'active',\n pulsing && 'pulsing',\n isDisabled && 'disabled',\n effectClassName,\n className\n )}\n style={style}\n disabled={isDisabled}\n aria-busy={loading || undefined}\n aria-label={resolvedAriaLabel}\n onPointerDown={(event) => {\n handlePointerDown(event)\n onPointerDown?.(event)\n }}\n onKeyDown={(event) => {\n if (event.key === ' ' || event.key === 'Enter') {\n triggerEffect(event.currentTarget)\n }\n\n onKeyDown?.(event)\n }}\n {...rest}\n >\n {effectLayer}\n {loading && <MSpinner size=\"sm\" color=\"inherit\" className=\"social-button-spinner\" aria-hidden=\"true\" />}\n <span className=\"social-button-brand\" aria-hidden=\"true\">\n <Icon className=\"social-button-mark\" />\n </span>\n {!iconOnly && <span className=\"social-button-label\">{label}</span>}\n </button>\n )\n})\n"],"mappings":";;;;;;;AAOA,IAAa,IAAe,EAA8C,SACtE,EAAC,iBAAc,cAAc,YAAS,SAAM,UAAO,cAAW,IAAM,cAAW,aAAU,GAAG,KAC5F,GACF;CACE,IAAM,IAAM,SAAyC;EAAC;EAAS;EAAM;EAAM,GAAG;EAAC;EAAS;EAAM;EAAM,CAAC;AAErG,QACI,kBAAC,EAAmB,UAApB;EAA6B,OAAO;YAChC,kBAAC,OAAD;GACS;GACL,MAAK;GACL,WAAW,EAAG,gBAAgB,GAAa,KAAY,YAAY,EAAU;GAC7E,GAAI;GAEH;GACC,CAAA;EACoB,CAAA;EAEpC,ECtBW,IAAe,EAA8C,KAAK;AAG/E,SAAgB,IAAgD;AAC5D,QAAO,EAAW,EAAa;;;;ACEnC,IAAa,IAAS,EAA0C,SAC5D,EACI,YACA,mBACA,SACA,OACA,UACA,cAAW,IACX,UAAO,MACP,WAAQ,WACR,UACA,mBAAgB,SAChB,aACA,iBAAc,UACd,gBACA,cACA,YAEJ,GACF;CACE,IAAM,IAAQ,GAAe,EAEvB,IAAe,GAAO,QAAQ,GAC9B,IAAmB,GAAO,YAAY,GACtC,IAAe,GAAO,QAAQ,GAC9B,IAAgB,GAAO,SAAS,GAChC,IAAkB,IAAQ,EAAM,UAAU,IAAQ,GAClD,EAAC,oBAAiB,gBAAa,sBAAmB,qBAAiB,EAAsC;EAC3G,QAAQ;EACR,UAAU;EACV,UAAU;EACV,OAAO;EACV,CAAC,EAGI,IAAe,GAChB,MAA+C;AAE5C,EADA,IAAW,EAAM,EACb,GAAO,YAAY,KACnB,EAAM,SAAS,EAAM;IAG7B;EAAC;EAAU;EAAO;EAAM,CAC3B;AAED,QACI,kBAAC,SAAD;EACI,WAAW,EACP,SACA,GACA,MAAkB,UAAU,cAC5B,KAAoB,YACpB,EACH;EACM;YARX,CAUI,kBAAC,QAAD;GAAM,WAAW,EAAG,UAAU,SAAS,KAAiB,EAAgB;GAAE,eAAe;aAAzF,CACK,GACD,kBAAC,SAAD;IACS;IACL,MAAK;IACL,MAAM;IACF;IACG;IACP,SAAS;IACT,gBAAiB,IAAyB,KAAA,IAAjB;IACzB,UAAU;IACV,UAAU;IACV,YAAY,MAAU;AAClB,MAAI,EAAM,QAAQ,OAAO,EAAM,QAAQ,YACnC,EAAc,EAAM,cAAc,cAAwC;;IAGlF,WAAU;IACZ,CAAA,CACC;MACN,KAAS,kBAAC,QAAD;GAAM,WAAU;aAAc;GAAa,CAAA,CACjD;;EAEd;;;ACjFF,SAAgB,EAAY,EACxB,SACA,UACA,iBACA,aACA,eAAY,YACZ,aACA,cAAW,IACX,UAAO,MACP,WAAQ,WACR,WAAQ,IACR,cACA,UACA,cACA,YACiB;CACjB,IAAM,CAAC,GAAe,KAAoB,EAAS,EAAa,EAC1D,IAAe,MAAU,KAAA,IAAoB,IAAR,GAGrC,IAAe,GAChB,MAAgB;AAIb,EAHI,MAAU,KAAA,KACV,EAAiB,EAAI,EAEzB,IAAW,EAAI;IAEnB,CAAC,GAAU,EAAM,CACpB,EAGK,IAAM,SACD;EAAC;EAAM,OAAO;EAAc;EAAU;EAAM;EAAO,UAAU;EAAa,GACjF;EAAC;EAAM;EAAc;EAAU;EAAM;EAAO;EAAa,CAC5D;AAED,QACI,kBAAC,EAAa,UAAd;EAAuB,OAAO;YAC1B,kBAAC,YAAD;GAAU,WAAW,EAAG,eAAe,GAAW,EAAU;GAAS;GAAO,MAAK;aAAjF;IACK,KAAS,kBAAC,UAAD;KAAQ,WAAW,EAAG,SAAS,KAAS,QAAQ;eAAG;KAAe,CAAA;IAC3E;IACA,KACG,kBAAC,QAAD;KAAM,WAAU;KAAc,MAAK;eAC9B;KACE,CAAA;IAEJ;;EACS,CAAA;;;;AChDhC,SAAgB,EAAU,EACtB,eACA,aAAU,IACV,aAAU,IACV,WACA,UACA,UAAO,IACP,mBAAgB,KAChB,aAAU,YACV,WAAQ,WACR,WAAQ,aACR,kBAAe,cACf,eAAY,oBACZ,cACA,GAAG,KACY;CACf,IAAM,IAAc,EAAuB,KAAK,EAC1C,IAAc,EAAO,EAAW;AAGtC,CAFA,EAAY,UAAU,GAEtB,QAAgB;AACZ,MAAI,CAAC,KAAQ,CAAC,KAAW,EAAS;EAElC,IAAM,IAAW,EAAY;AAC7B,MAAI,CAAC,EAAU;EAEf,IAAM,IAAW,IAAI,sBAChB,MAAY;AACT,GAAI,EAAQ,GAAG,kBACX,EAAY,SAAS;KAG7B,EAAC,YAAY,GAAG,EAAc,KAAI,CACrC;AAGD,SADA,EAAS,QAAQ,EAAS,QACb,EAAS,YAAY;IACnC;EAAC;EAAM;EAAS;EAAS;EAAc,CAAC;CAE3C,IAAM,IAAc,QAAkB;AAClC,EAAI,CAAC,KAAW,KAAS,GAAY;IACtC;EAAC;EAAY;EAAS;EAAQ,CAAC,EAE5B,IAAY,MAAW,KAAA,KAAa,MAAU,KAAA;AAEpD,QACI,kBAAC,OAAD;EAAK,WAAW,EAAG,aAAa,EAAU;EAAE,GAAI;YAAhD;GACK,KACG,kBAAC,QAAD;IAAM,WAAU;cAAhB;KACK;KAAO;KAAI;KACT;;GAGV,IACG,kBAAC,GAAD;IACa;IACF;IACE;IACT,SAAS;IACT,WAAU;cAET,IAAU,IAAe;IACpB,CAAA,GAEV,kBAAC,QAAD;IAAM,WAAU;cAAkB;IAAiB,CAAA;GAGtD,KAAQ,KAAW,kBAAC,OAAD;IAAK,KAAK;IAAa,WAAU;IAAuB,CAAA;GAE3E,KACG,kBAAC,OAAD;IAAK,WAAU;cACX,kBAAC,OAAD;KACI,WAAU;KACV,OAAO,EAAC,OAAO,GAAG,KAAK,IAAK,IAAS,IAAS,KAAK,IAAI,CAAC,IAAG;KAC7D,CAAA;IACA,CAAA;GAER;;;;;AC5Ed,SAAgB,EAAW,EACvB,eAAY,KACZ,aAAU,UACV,WAAQ,WACR,YAAS,IACT,gBACgB;CAChB,IAAM,CAAC,GAAS,KAAc,EAAS,GAAM;AAe7C,QAbA,QAAgB;EACZ,SAAS,IAAW;AAChB,KAAW,OAAO,UAAU,EAAU;;AAI1C,SAFA,GAAU,EACV,OAAO,iBAAiB,UAAU,GAAU,EAAC,SAAS,IAAK,CAAC,QAC/C,OAAO,oBAAoB,UAAU,EAAS;IAC5D,CAAC,EAAU,CAAC,EAOX,kBAAC,GAAD;EACa;EACF;EACP,OAAM;EACN,MAAK;EACL,UAAA;EACA,SAXY,QAAkB;AAClC,UAAO,SAAS;IAAC,KAAK;IAAG,UAAU,IAAS,WAAW;IAAU,CAAC;KACnE,CAAC,EAAO,CAAC;EAUJ,cAAW;EACX,WAAW,EAAG,cAAc,KAAW,WAAW,EAAU;YAE5D,kBAAC,GAAD,EAAgB,CAAA;EACV,CAAA;;;;ACrClB,SAAS,EAAW,GAAqB,GAAwB;AAC7D,QACI,kBAAC,OAAD;EAAK,SAAQ;EAAY,MAAK;EAAO,OAAM;EAA6B,eAAY;EAAO,GAAI;EAC1F;EACC,CAAA;;AAId,SAAgB,EAAiB,GAAwB;AACrD,QAAO,EACH,kBAAA,GAAA,EAAA,UAAA;EACI,kBAAC,UAAD;GAAQ,IAAG;GAAK,IAAG;GAAK,GAAE;GAAO,MAAK;GAAO,QAAO;GAAU,aAAY;GAAQ,CAAA;EAClF,kBAAC,QAAD;GACI,GAAE;GACF,MAAK;GACP,CAAA;EACF,kBAAC,QAAD;GACI,GAAE;GACF,MAAK;GACP,CAAA;EACF,kBAAC,QAAD;GACI,GAAE;GACF,MAAK;GACP,CAAA;EACF,kBAAC,QAAD;GACI,GAAE;GACF,MAAK;GACP,CAAA;EACH,EAAA,CAAA,EACH,EACH;;AAGL,SAAgB,EAAmB,GAAwB;AACvD,QAAO,EACH,kBAAA,GAAA,EAAA,UAAA,CACI,kBAAC,QAAD;EAAM,GAAE;EAAM,GAAE;EAAM,OAAM;EAAO,QAAO;EAAO,IAAG;EAAM,MAAK;EAAY,CAAA,EAC3E,kBAAC,QAAD;EACI,GAAE;EACF,MAAK;EACP,CAAA,CACH,EAAA,CAAA,EACH,EACH;;AAGL,SAAgB,EAAgB,GAAwB;AACpD,QAAO,EACH,kBAAA,GAAA,EAAA,UAAA,CACI,kBAAC,QAAD;EACI,GAAE;EACF,MAAK;EACP,CAAA,EACF,kBAAC,QAAD;EACI,GAAE;EACF,MAAK;EACP,CAAA,CACH,EAAA,CAAA,EACH,EACH;;AAGL,SAAgB,EAAoB,GAAwB;AACxD,QAAO,EACH,kBAAA,GAAA,EAAA,UAAA;EACI,kBAAC,QAAD;GAAM,GAAE;GAAM,GAAE;GAAM,OAAM;GAAM,QAAO;GAAM,IAAG;GAAM,MAAK;GAAY,CAAA;EACzE,kBAAC,QAAD;GAAM,GAAE;GAAO,GAAE;GAAM,OAAM;GAAM,QAAO;GAAM,IAAG;GAAM,MAAK;GAAY,CAAA;EAC1E,kBAAC,QAAD;GAAM,GAAE;GAAM,GAAE;GAAO,OAAM;GAAM,QAAO;GAAM,IAAG;GAAM,MAAK;GAAY,CAAA;EAC1E,kBAAC,QAAD;GAAM,GAAE;GAAO,GAAE;GAAO,OAAM;GAAM,QAAO;GAAM,IAAG;GAAM,MAAK;GAAY,CAAA;EAC5E,EAAA,CAAA,EACH,EACH;;AAGL,SAAgB,EAAoB,GAAwB;AACxD,QAAO,EACH,kBAAA,GAAA,EAAA,UAAA,CACI,kBAAC,UAAD;EAAQ,IAAG;EAAK,IAAG;EAAK,GAAE;EAAO,MAAK;EAAS,CAAA,EAC/C,kBAAC,QAAD;EACI,GAAE;EACF,MAAK;EACP,CAAA,CACH,EAAA,CAAA,EACH,EACH;;AAGL,SAAgB,EAAmB,GAAwB;AACvD,QAAO,EACH,kBAAA,GAAA,EAAA,UAAA,CACI,kBAAC,QAAD;EAAM,GAAE;EAAM,GAAE;EAAM,OAAM;EAAO,QAAO;EAAO,IAAG;EAAM,MAAK;EAAS,CAAA,EACxE,kBAAC,QAAD;EACI,GAAE;EACF,MAAK;EACP,CAAA,CACH,EAAA,CAAA,EACH,EACH;;;;ACtFL,IAAM,IAAqB;CACvB,QAAQ;EACJ,OAAO;EACP,WAAW;EACX,MAAM;EACN,MAAM;EACT;CACD,UAAU;EACN,OAAO;EACP,WAAW;EACX,MAAM;EACN,MAAM;EACT;CACD,OAAO;EACH,OAAO;EACP,WAAW;EACX,MAAM;EACN,MAAM;EACT;CACD,WAAW;EACP,OAAO;EACP,WAAW;EACX,MAAM;EACN,MAAM;EACT;CACD,WAAW;EACP,OAAO;EACP,WAAW;EACX,MAAM;EACN,MAAM;EACT;CACD,UAAU;EACN,OAAO;EACP,WAAW;EACX,MAAM;EACN,MAAM;EACT;CACJ,EAEY,IAAgB,EAAkD,SAC3E,EACI,cAAW,UACX,aAAU,WACV,UAAO,MACP,cAAW,IACX,eAAY,UACZ,eAAY,IACZ,aAAU,IACV,YAAS,IACT,aAAU,IACV,iBAAc,UACd,gBACA,cACA,UACA,aACA,cAAW,IACX,UAAO,UACP,kBACA,cACA,cAAc,GACd,GAAG,KAEP,GACF;CACE,IAAM,IAAS,EAAmB,IAC5B,IAAO,EAAO,MACd,IAAQ,KAAY,EAAO,OAC3B,IAAoB,MAAc,IAAW,EAAO,YAAY,KAAA,IAChE,IAAkB,EAAO,SAAS,WAAW,IAAU,EAAO,MAC9D,IAAa,KAAY,GACzB,EAAC,oBAAiB,gBAAa,sBAAmB,qBAAiB,EAAwC;EAC7G,QAAQ;EACR,UAAU;EACV,UAAU;EACV,OAAO;EACV,CAAC;AAEF,QACI,kBAAC,UAAD;EACS;EACC;EACN,WAAW,EACP,sBACA,GACA,GACA,GACA,KAAa,cACb,KAAY,aACZ,KAAY,cAAc,KAC1B,KAAW,WACX,KAAU,UACV,KAAW,WACX,KAAc,YACd,GACA,EACH;EACM;EACP,UAAU;EACV,aAAW,KAAW,KAAA;EACtB,cAAY;EACZ,gBAAgB,MAAU;AAEtB,GADA,EAAkB,EAAM,EACxB,IAAgB,EAAM;;EAE1B,YAAY,MAAU;AAKlB,IAJI,EAAM,QAAQ,OAAO,EAAM,QAAQ,YACnC,EAAc,EAAM,cAAc,EAGtC,IAAY,EAAM;;EAEtB,GAAI;YAjCR;GAmCK;GACA,KAAW,kBAAC,GAAD;IAAU,MAAK;IAAK,OAAM;IAAU,WAAU;IAAwB,eAAY;IAAS,CAAA;GACvG,kBAAC,QAAD;IAAM,WAAU;IAAsB,eAAY;cAC9C,kBAAC,GAAD,EAAM,WAAU,sBAAuB,CAAA;IACpC,CAAA;GACN,CAAC,KAAY,kBAAC,QAAD;IAAM,WAAU;cAAuB;IAAa,CAAA;GAC7D;;EAEf"}
|
package/dist/controls.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(`./MButton-
|
|
3
|
+
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./MButton-C_WTyNvw.cjs`),t=require(`./MToggle-Hheo-jfZ.cjs`),n=require(`./controls-DEEbLT5o.cjs`),r=require(`./MCheckbox-BhtJDdip.cjs`),i=require(`./MSlider-vD6Sla2p.cjs`);exports.MButton=e.t,exports.MButtonGroup=n.o,exports.MCheckbox=r.t,exports.MLoadMore=n.r,exports.MRadio=n.a,exports.MRadioGroup=n.i,exports.MScrollTop=n.n,exports.MSlider=i.t,exports.MSocialButton=n.t,exports.MToggle=t.t;
|
package/dist/controls.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import {ensureStyles} from './style-runtime.js'
|
|
2
2
|
ensureStyles()
|
|
3
|
-
import { t as e } from "./MButton-
|
|
4
|
-
import {
|
|
5
|
-
import { t as
|
|
6
|
-
import { t as
|
|
7
|
-
|
|
3
|
+
import { t as e } from "./MButton-33EzpGvQ.js";
|
|
4
|
+
import { t } from "./MToggle-B7cKH5Tl.js";
|
|
5
|
+
import { a as n, i as r, n as i, o as a, r as o, t as s } from "./controls-IsOBNxW0.js";
|
|
6
|
+
import { t as c } from "./MCheckbox-CugP7F6H.js";
|
|
7
|
+
import { t as l } from "./MSlider-D5ckYDop.js";
|
|
8
|
+
export { e as MButton, a as MButtonGroup, c as MCheckbox, o as MLoadMore, n as MRadio, r as MRadioGroup, i as MScrollTop, l as MSlider, s as MSocialButton, t as MToggle };
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./MCookieBootstrap-Ct5mIm5P.cjs`);function t(e){return`${e.storageKey??`mineralui-cookie-consent`}-key`}function n(e){if(typeof window>`u`)return null;try{return window.localStorage.getItem(e)}catch{return null}}function r(e,t){if(!(typeof window>`u`||!t))try{window.localStorage.setItem(e,t)}catch{}}function i(t){typeof window>`u`||(window[e.o]=t.config,window[e.c]=t,window.dispatchEvent(new CustomEvent(e.l)))}function a(e){if(typeof document>`u`)return null;for(let t of Array.from(document.querySelectorAll(`script[src]`)))try{let n=new URL(t.src,window.location.href);if(n.href===e.href||n.origin===e.origin&&n.pathname===e.pathname)return t}catch{}return null}function o(e,i,a){let o=`${i.origin}/cookie/sites/${encodeURIComponent(a)}`,s=t(e);return{config:e,getDeclaration:async()=>{let e=await fetch(`${o}/declaration`);return e.ok?(await e.json()).items??[]:[]},getConsent:async()=>{let e=n(s);if(!e)return null;let t=await fetch(`${o}/consent?consentKey=${encodeURIComponent(e)}`);return t.ok?(await t.json()).state??null:null},saveConsent:async t=>{let i=n(s),a=await fetch(`${o}/consent`,{method:`POST`,headers:{"content-type":`application/json`},body:JSON.stringify({...i?{consentKey:i}:{},version:t.version,decidedAt:t.decidedAt,source:t.source,categories:t.categories,domain:typeof window<`u`?window.location.hostname:e.domain??null})});a.ok&&r(s,(await a.json()).consentKey)}}}async function s(){if(typeof window>`u`||typeof fetch>`u`)return null;let t=window[e.o];if(t)return t;let n;try{n=new URL({}.url)}catch{return null}let r=a(n),s=r?.dataset.siteKey??n.searchParams.get(`siteKey`);if(!s)return null;let c=r?.dataset.configEndpoint??n.searchParams.get(`configEndpoint`)??`${n.origin}/cookie/bootstrap/${encodeURIComponent(s)}`;try{let e=await fetch(c,{headers:{"x-mineral-site-key":s}});if(!e.ok)return null;let t=await e.json(),a={...t,siteKey:t.siteKey??s,scanEndpoint:t.scanEndpoint??r?.dataset.scanEndpoint??n.searchParams.get(`scanEndpoint`)??void 0};return i(o(a,n,s)),a}catch{return null}}s().finally(()=>{e.t()}),exports.MCOOKIE_BOOTSTRAP_CONFIG_KEY=e.o,exports.MCOOKIE_CONSENT_CHANGE_EVENT=e.s,exports.MCOOKIE_RUNTIME_KEY=e.c,exports.MCOOKIE_RUNTIME_READY_EVENT=e.l,exports.autoBootstrapMCookieConsent=e.t,exports.bootstrapMCookieConsent=e.n,exports.readMCookieBootstrapConfig=e.r,exports.reportMCookieSurface=e.i,exports.scanMCookieSurface=e.a;
|
|
2
|
+
//# sourceMappingURL=cookie-consent-bootstrap.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cookie-consent-bootstrap.cjs","names":[],"sources":["../src/cookie-consent-bootstrap.ts"],"sourcesContent":["export * from './components/feedback/MCookie/MCookieBootstrap'\n\nimport {\n autoBootstrapMCookieConsent,\n MCOOKIE_BOOTSTRAP_CONFIG_KEY,\n MCOOKIE_RUNTIME_KEY,\n MCOOKIE_RUNTIME_READY_EVENT,\n} from './components/feedback/MCookie/MCookieBootstrap'\nimport type {\n MCookieBootstrapConfig,\n MCookieRuntime,\n} from './components/feedback/MCookie/MCookieBootstrap'\nimport type {MCookieConsentState} from './components/feedback/MCookie/MCookieConsentProvider'\n\nfunction getConsentKeyStorageKey(config: MCookieBootstrapConfig) {\n return `${config.storageKey ?? 'mineralui-cookie-consent'}-key`\n}\n\nfunction readStoredConsentKey(storageKey: string) {\n if (typeof window === 'undefined') {\n return null\n }\n\n try {\n return window.localStorage.getItem(storageKey)\n } catch {\n return null\n }\n}\n\nfunction writeStoredConsentKey(storageKey: string, consentKey: string | null | undefined) {\n if (typeof window === 'undefined' || !consentKey) {\n return\n }\n\n try {\n window.localStorage.setItem(storageKey, consentKey)\n } catch {\n // ignore storage issues\n }\n}\n\nfunction dispatchRuntimeReady(runtime: MCookieRuntime) {\n if (typeof window === 'undefined') {\n return\n }\n\n window[MCOOKIE_BOOTSTRAP_CONFIG_KEY] = runtime.config\n window[MCOOKIE_RUNTIME_KEY] = runtime\n window.dispatchEvent(new CustomEvent(MCOOKIE_RUNTIME_READY_EVENT))\n}\n\nfunction findBootstrapScriptElement(scriptUrl: URL) {\n if (typeof document === 'undefined') {\n return null\n }\n\n for (const candidate of Array.from(document.querySelectorAll<HTMLScriptElement>('script[src]'))) {\n try {\n const candidateUrl = new URL(candidate.src, window.location.href)\n\n if (candidateUrl.href === scriptUrl.href) {\n return candidate\n }\n\n if (candidateUrl.origin === scriptUrl.origin && candidateUrl.pathname === scriptUrl.pathname) {\n return candidate\n }\n } catch {\n // ignore invalid script urls\n }\n }\n\n return null\n}\n\nfunction createRuntime(config: MCookieBootstrapConfig, scriptUrl: URL, siteKey: string): MCookieRuntime {\n const cookieSiteBase = `${scriptUrl.origin}/cookie/sites/${encodeURIComponent(siteKey)}`\n const consentKeyStorage = getConsentKeyStorageKey(config)\n\n return {\n config,\n getDeclaration: async () => {\n const response = await fetch(`${cookieSiteBase}/declaration`)\n\n if (!response.ok) {\n return []\n }\n\n const payload = await response.json()\n return payload.items ?? []\n },\n getConsent: async () => {\n const consentKey = readStoredConsentKey(consentKeyStorage)\n\n if (!consentKey) {\n return null\n }\n\n const response = await fetch(`${cookieSiteBase}/consent?consentKey=${encodeURIComponent(consentKey)}`)\n\n if (!response.ok) {\n return null\n }\n\n const payload = await response.json()\n return payload.state ?? null\n },\n saveConsent: async (state: MCookieConsentState) => {\n const consentKey = readStoredConsentKey(consentKeyStorage)\n const response = await fetch(`${cookieSiteBase}/consent`, {\n method: 'POST',\n headers: {\n 'content-type': 'application/json',\n },\n body: JSON.stringify({\n ...(consentKey ? {consentKey} : {}),\n version: state.version,\n decidedAt: state.decidedAt,\n source: state.source,\n categories: state.categories,\n domain: typeof window !== 'undefined' ? window.location.hostname : config.domain ?? null,\n }),\n })\n\n if (!response.ok) {\n return\n }\n\n const payload = await response.json()\n writeStoredConsentKey(consentKeyStorage, payload.consentKey)\n },\n }\n}\n\nasync function resolveBootstrapConfigFromScript() {\n if (typeof window === 'undefined' || typeof fetch === 'undefined') {\n return null\n }\n\n const existingConfig = window[MCOOKIE_BOOTSTRAP_CONFIG_KEY]\n if (existingConfig) {\n return existingConfig\n }\n\n let scriptUrl: URL\n\n try {\n scriptUrl = new URL(import.meta.url)\n } catch {\n return null\n }\n\n const bootstrapScript = findBootstrapScriptElement(scriptUrl)\n const siteKey = bootstrapScript?.dataset.siteKey ?? scriptUrl.searchParams.get('siteKey')\n\n if (!siteKey) {\n return null\n }\n\n const configEndpoint =\n bootstrapScript?.dataset.configEndpoint ??\n scriptUrl.searchParams.get('configEndpoint') ??\n `${scriptUrl.origin}/cookie/bootstrap/${encodeURIComponent(siteKey)}`\n\n try {\n const response = await fetch(configEndpoint, {\n headers: {\n 'x-mineral-site-key': siteKey,\n },\n })\n\n if (!response.ok) {\n return null\n }\n\n const resolvedConfig = (await response.json()) as MCookieBootstrapConfig\n const mergedConfig: MCookieBootstrapConfig = {\n ...resolvedConfig,\n siteKey: resolvedConfig.siteKey ?? siteKey,\n scanEndpoint:\n resolvedConfig.scanEndpoint ??\n bootstrapScript?.dataset.scanEndpoint ??\n scriptUrl.searchParams.get('scanEndpoint') ??\n undefined,\n }\n\n dispatchRuntimeReady(createRuntime(mergedConfig, scriptUrl, siteKey))\n return mergedConfig\n } catch {\n return null\n }\n}\n\nvoid resolveBootstrapConfigFromScript().finally(() => {\n autoBootstrapMCookieConsent()\n})\n"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/feedback/MCookie/MCookieBootstrap';
|