@ryanhe919/lumen-ui 0.2.1 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/dist/LMBadge-BBDOGTps.js +126 -0
- package/dist/LMBadge-BBDOGTps.js.map +1 -0
- package/dist/LMBadge-D95iccla.cjs +125 -0
- package/dist/LMBadge-D95iccla.cjs.map +1 -0
- package/dist/LMButton-B258yfky.cjs +333 -0
- package/dist/LMButton-B258yfky.cjs.map +1 -0
- package/dist/LMButton-S4xQSohi.js +334 -0
- package/dist/LMButton-S4xQSohi.js.map +1 -0
- package/dist/LMCard-D7ABNC95.js +207 -0
- package/dist/LMCard-D7ABNC95.js.map +1 -0
- package/dist/LMCard-D_K051f2.cjs +206 -0
- package/dist/LMCard-D_K051f2.cjs.map +1 -0
- package/dist/LMCheckbox-C2YvEQ8f.cjs +197 -0
- package/dist/LMCheckbox-C2YvEQ8f.cjs.map +1 -0
- package/dist/LMCheckbox-DaaJRjKt.js +198 -0
- package/dist/LMCheckbox-DaaJRjKt.js.map +1 -0
- package/dist/LMDatePicker-BlUwN4On.cjs +565 -0
- package/dist/LMDatePicker-BlUwN4On.cjs.map +1 -0
- package/dist/LMDatePicker-DSv28BFH.js +566 -0
- package/dist/LMDatePicker-DSv28BFH.js.map +1 -0
- package/dist/LMDrawer--lFV_a3m.cjs +207 -0
- package/dist/LMDrawer--lFV_a3m.cjs.map +1 -0
- package/dist/LMDrawer-DJ5ugeZR.js +208 -0
- package/dist/LMDrawer-DJ5ugeZR.js.map +1 -0
- package/dist/LMDropdown-wiTMuyhU.js +285 -0
- package/dist/LMDropdown-wiTMuyhU.js.map +1 -0
- package/dist/LMDropdown-yl5l7qtz.cjs +284 -0
- package/dist/LMDropdown-yl5l7qtz.cjs.map +1 -0
- package/dist/LMEmpty-BedQxpbi.cjs +188 -0
- package/dist/LMEmpty-BedQxpbi.cjs.map +1 -0
- package/dist/LMEmpty-DzHM1fOb.js +189 -0
- package/dist/LMEmpty-DzHM1fOb.js.map +1 -0
- package/dist/LMField-BS-DSEya.js +67 -0
- package/dist/LMField-BS-DSEya.js.map +1 -0
- package/dist/LMField-DhDHj64z.cjs +66 -0
- package/dist/LMField-DhDHj64z.cjs.map +1 -0
- package/dist/LMInput-CVjawj1F.cjs +140 -0
- package/dist/LMInput-CVjawj1F.cjs.map +1 -0
- package/dist/LMInput-D9csGyhj.js +141 -0
- package/dist/LMInput-D9csGyhj.js.map +1 -0
- package/dist/LMMenu-IDAgZFuC.cjs +234 -0
- package/dist/LMMenu-IDAgZFuC.cjs.map +1 -0
- package/dist/LMMenu-yXadjQLQ.js +235 -0
- package/dist/LMMenu-yXadjQLQ.js.map +1 -0
- package/dist/LMModal-BCVVPLot.cjs +203 -0
- package/dist/LMModal-BCVVPLot.cjs.map +1 -0
- package/dist/LMModal-DCJPlfA4.js +204 -0
- package/dist/LMModal-DCJPlfA4.js.map +1 -0
- package/dist/LMNumberInput-B1tU7T_W.cjs +294 -0
- package/dist/LMNumberInput-B1tU7T_W.cjs.map +1 -0
- package/dist/LMNumberInput-BI5_OEx4.js +295 -0
- package/dist/LMNumberInput-BI5_OEx4.js.map +1 -0
- package/dist/LMPagination-BypfLRlF.js +305 -0
- package/dist/LMPagination-BypfLRlF.js.map +1 -0
- package/dist/LMPagination-CouDFIwd.cjs +304 -0
- package/dist/LMPagination-CouDFIwd.cjs.map +1 -0
- package/dist/LMRadio-CHn6nFSy.cjs +189 -0
- package/dist/LMRadio-CHn6nFSy.cjs.map +1 -0
- package/dist/LMRadio-UQLNgTMF.js +190 -0
- package/dist/LMRadio-UQLNgTMF.js.map +1 -0
- package/dist/LMSearchInput-CIvVkEf2.js +205 -0
- package/dist/LMSearchInput-CIvVkEf2.js.map +1 -0
- package/dist/LMSearchInput-nBlAX734.cjs +204 -0
- package/dist/LMSearchInput-nBlAX734.cjs.map +1 -0
- package/dist/LMSelect-B-MWX2JI.js +309 -0
- package/dist/LMSelect-B-MWX2JI.js.map +1 -0
- package/dist/LMSelect-ByQcUp2S.cjs +308 -0
- package/dist/LMSelect-ByQcUp2S.cjs.map +1 -0
- package/dist/LMStatCard-D5HV9r6d.js +348 -0
- package/dist/LMStatCard-D5HV9r6d.js.map +1 -0
- package/dist/LMStatCard-MXs9Z0qH.cjs +347 -0
- package/dist/LMStatCard-MXs9Z0qH.cjs.map +1 -0
- package/dist/LMSwitch-CP1_nrfU.js +207 -0
- package/dist/LMSwitch-CP1_nrfU.js.map +1 -0
- package/dist/LMSwitch-DYoSH6wE.cjs +206 -0
- package/dist/LMSwitch-DYoSH6wE.cjs.map +1 -0
- package/dist/LMTable-Cp8HZqiV.js +594 -0
- package/dist/LMTable-Cp8HZqiV.js.map +1 -0
- package/dist/LMTable-j1ZzAzXB.cjs +593 -0
- package/dist/LMTable-j1ZzAzXB.cjs.map +1 -0
- package/dist/LMTabs-D5n9lB8X.js +210 -0
- package/dist/LMTabs-D5n9lB8X.js.map +1 -0
- package/dist/LMTabs-NPmOzPat.cjs +209 -0
- package/dist/LMTabs-NPmOzPat.cjs.map +1 -0
- package/dist/LMTextarea-5dVVPeL2.js +136 -0
- package/dist/LMTextarea-5dVVPeL2.js.map +1 -0
- package/dist/LMTextarea-yG0OBZjA.cjs +135 -0
- package/dist/LMTextarea-yG0OBZjA.cjs.map +1 -0
- package/dist/LMTooltip-30_lOAnH.cjs +85 -0
- package/dist/LMTooltip-30_lOAnH.cjs.map +1 -0
- package/dist/LMTooltip-h47oYhl8.js +86 -0
- package/dist/LMTooltip-h47oYhl8.js.map +1 -0
- package/dist/LMUpload-BwXoxIfE.js +380 -0
- package/dist/LMUpload-BwXoxIfE.js.map +1 -0
- package/dist/LMUpload-CJopkWc6.cjs +379 -0
- package/dist/LMUpload-CJopkWc6.cjs.map +1 -0
- package/dist/componentSizes-CdWNL526.js +125 -0
- package/dist/componentSizes-CdWNL526.js.map +1 -0
- package/dist/componentSizes-DUTZ7uEM.cjs +124 -0
- package/dist/componentSizes-DUTZ7uEM.cjs.map +1 -0
- package/dist/components/Chat/LMChatBubble/LMChatBubble.d.ts +28 -0
- package/dist/components/Chat/LMChatBubble/LMChatBubble.d.ts.map +1 -0
- package/dist/components/Chat/LMChatBubble/LMChatBubble.stories.d.ts +25 -0
- package/dist/components/Chat/LMChatBubble/LMChatBubble.stories.d.ts.map +1 -0
- package/dist/components/Chat/LMChatBubble/index.d.ts +3 -0
- package/dist/components/Chat/LMChatBubble/index.d.ts.map +1 -0
- package/dist/components/Chat/LMChatContainer/LMChatContainer.d.ts +85 -0
- package/dist/components/Chat/LMChatContainer/LMChatContainer.d.ts.map +1 -0
- package/dist/components/Chat/LMChatContainer/LMChatContainer.stories.d.ts +23 -0
- package/dist/components/Chat/LMChatContainer/LMChatContainer.stories.d.ts.map +1 -0
- package/dist/components/Chat/LMChatContainer/index.d.ts +3 -0
- package/dist/components/Chat/LMChatContainer/index.d.ts.map +1 -0
- package/dist/components/Chat/LMChatInput/LMChatInput.d.ts +55 -0
- package/dist/components/Chat/LMChatInput/LMChatInput.d.ts.map +1 -0
- package/dist/components/Chat/LMChatInput/LMChatInput.stories.d.ts +27 -0
- package/dist/components/Chat/LMChatInput/LMChatInput.stories.d.ts.map +1 -0
- package/dist/components/Chat/LMChatInput/index.d.ts +3 -0
- package/dist/components/Chat/LMChatInput/index.d.ts.map +1 -0
- package/dist/components/Chat/LMChatList/LMChatList.d.ts +60 -0
- package/dist/components/Chat/LMChatList/LMChatList.d.ts.map +1 -0
- package/dist/components/Chat/LMChatList/LMChatList.stories.d.ts +21 -0
- package/dist/components/Chat/LMChatList/LMChatList.stories.d.ts.map +1 -0
- package/dist/components/Chat/LMChatList/index.d.ts +3 -0
- package/dist/components/Chat/LMChatList/index.d.ts.map +1 -0
- package/dist/components/Chat/LMChatMessage/LMChatMessage.d.ts +56 -0
- package/dist/components/Chat/LMChatMessage/LMChatMessage.d.ts.map +1 -0
- package/dist/components/Chat/LMChatMessage/LMChatMessage.stories.d.ts +27 -0
- package/dist/components/Chat/LMChatMessage/LMChatMessage.stories.d.ts.map +1 -0
- package/dist/components/Chat/LMChatMessage/index.d.ts +3 -0
- package/dist/components/Chat/LMChatMessage/index.d.ts.map +1 -0
- package/dist/components/Chat/LMCodeBlock/LMCodeBlock.d.ts +32 -0
- package/dist/components/Chat/LMCodeBlock/LMCodeBlock.d.ts.map +1 -0
- package/dist/components/Chat/LMCodeBlock/LMCodeBlock.stories.d.ts +27 -0
- package/dist/components/Chat/LMCodeBlock/LMCodeBlock.stories.d.ts.map +1 -0
- package/dist/components/Chat/LMCodeBlock/index.d.ts +3 -0
- package/dist/components/Chat/LMCodeBlock/index.d.ts.map +1 -0
- package/dist/components/Chat/LMMarkdownRenderer/LMMarkdownRenderer.d.ts +24 -0
- package/dist/components/Chat/LMMarkdownRenderer/LMMarkdownRenderer.d.ts.map +1 -0
- package/dist/components/Chat/LMMarkdownRenderer/LMMarkdownRenderer.stories.d.ts +23 -0
- package/dist/components/Chat/LMMarkdownRenderer/LMMarkdownRenderer.stories.d.ts.map +1 -0
- package/dist/components/Chat/LMMarkdownRenderer/index.d.ts +3 -0
- package/dist/components/Chat/LMMarkdownRenderer/index.d.ts.map +1 -0
- package/dist/components/Chat/LMTypingIndicator/LMTypingIndicator.d.ts +21 -0
- package/dist/components/Chat/LMTypingIndicator/LMTypingIndicator.d.ts.map +1 -0
- package/dist/components/Chat/LMTypingIndicator/LMTypingIndicator.stories.d.ts +25 -0
- package/dist/components/Chat/LMTypingIndicator/LMTypingIndicator.stories.d.ts.map +1 -0
- package/dist/components/Chat/LMTypingIndicator/index.d.ts +3 -0
- package/dist/components/Chat/LMTypingIndicator/index.d.ts.map +1 -0
- package/dist/components/Chat/index.d.ts +9 -0
- package/dist/components/Chat/index.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMCard/LMCard.d.ts +30 -0
- package/dist/components/DataDisplay/LMCard/LMCard.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMCard/LMCard.stories.d.ts +33 -0
- package/dist/components/DataDisplay/LMCard/LMCard.stories.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMCard/LMCard.test.d.ts +2 -0
- package/dist/components/DataDisplay/LMCard/LMCard.test.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMCard/index.d.ts +3 -0
- package/dist/components/DataDisplay/LMCard/index.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMEmpty/LMEmpty.d.ts +18 -0
- package/dist/components/DataDisplay/LMEmpty/LMEmpty.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMEmpty/LMEmpty.stories.d.ts +31 -0
- package/dist/components/DataDisplay/LMEmpty/LMEmpty.stories.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMEmpty/LMEmpty.test.d.ts +2 -0
- package/dist/components/DataDisplay/LMEmpty/LMEmpty.test.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMEmpty/index.d.ts +3 -0
- package/dist/components/DataDisplay/LMEmpty/index.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMStatCard/LMStatCard.d.ts +40 -0
- package/dist/components/DataDisplay/LMStatCard/LMStatCard.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMStatCard/LMStatCard.stories.d.ts +35 -0
- package/dist/components/DataDisplay/LMStatCard/LMStatCard.stories.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMStatCard/LMStatCard.test.d.ts +2 -0
- package/dist/components/DataDisplay/LMStatCard/LMStatCard.test.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMStatCard/index.d.ts +3 -0
- package/dist/components/DataDisplay/LMStatCard/index.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTable/LMTable.d.ts +93 -0
- package/dist/components/DataDisplay/LMTable/LMTable.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTable/LMTable.stories.d.ts +35 -0
- package/dist/components/DataDisplay/LMTable/LMTable.stories.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTable/LMTable.test.d.ts +2 -0
- package/dist/components/DataDisplay/LMTable/LMTable.test.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTable/index.d.ts +3 -0
- package/dist/components/DataDisplay/LMTable/index.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTabs/LMTabs.d.ts +40 -0
- package/dist/components/DataDisplay/LMTabs/LMTabs.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTabs/LMTabs.stories.d.ts +35 -0
- package/dist/components/DataDisplay/LMTabs/LMTabs.stories.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTabs/LMTabs.test.d.ts +2 -0
- package/dist/components/DataDisplay/LMTabs/LMTabs.test.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTabs/index.d.ts +3 -0
- package/dist/components/DataDisplay/LMTabs/index.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTooltip/LMTooltip.d.ts +18 -0
- package/dist/components/DataDisplay/LMTooltip/LMTooltip.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTooltip/LMTooltip.stories.d.ts +27 -0
- package/dist/components/DataDisplay/LMTooltip/LMTooltip.stories.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTooltip/LMTooltip.test.d.ts +2 -0
- package/dist/components/DataDisplay/LMTooltip/LMTooltip.test.d.ts.map +1 -0
- package/dist/components/DataDisplay/LMTooltip/index.d.ts +3 -0
- package/dist/components/DataDisplay/LMTooltip/index.d.ts.map +1 -0
- package/dist/components/DataDisplay/index.d.ts +7 -0
- package/dist/components/DataDisplay/index.d.ts.map +1 -0
- package/dist/components/Feedback/LMConfirm/LMConfirm.d.ts +25 -0
- package/dist/components/Feedback/LMConfirm/LMConfirm.d.ts.map +1 -0
- package/dist/components/Feedback/LMConfirm/LMConfirm.stories.d.ts +19 -0
- package/dist/components/Feedback/LMConfirm/LMConfirm.stories.d.ts.map +1 -0
- package/dist/components/Feedback/LMConfirm/LMConfirm.test.d.ts +2 -0
- package/dist/components/Feedback/LMConfirm/LMConfirm.test.d.ts.map +1 -0
- package/dist/components/Feedback/LMConfirm/index.d.ts +5 -0
- package/dist/components/Feedback/LMConfirm/index.d.ts.map +1 -0
- package/dist/components/Feedback/LMDrawer/LMDrawer.d.ts +38 -0
- package/dist/components/Feedback/LMDrawer/LMDrawer.d.ts.map +1 -0
- package/dist/components/Feedback/LMDrawer/LMDrawer.stories.d.ts +33 -0
- package/dist/components/Feedback/LMDrawer/LMDrawer.stories.d.ts.map +1 -0
- package/dist/components/Feedback/LMDrawer/LMDrawer.test.d.ts +2 -0
- package/dist/components/Feedback/LMDrawer/LMDrawer.test.d.ts.map +1 -0
- package/dist/components/Feedback/LMDrawer/index.d.ts +3 -0
- package/dist/components/Feedback/LMDrawer/index.d.ts.map +1 -0
- package/dist/components/Feedback/LMMessage/LMMessage.d.ts +31 -0
- package/dist/components/Feedback/LMMessage/LMMessage.d.ts.map +1 -0
- package/dist/components/Feedback/LMMessage/LMMessage.stories.d.ts +25 -0
- package/dist/components/Feedback/LMMessage/LMMessage.stories.d.ts.map +1 -0
- package/dist/components/Feedback/LMMessage/LMMessage.test.d.ts +2 -0
- package/dist/components/Feedback/LMMessage/LMMessage.test.d.ts.map +1 -0
- package/dist/components/Feedback/LMMessage/index.d.ts +5 -0
- package/dist/components/Feedback/LMMessage/index.d.ts.map +1 -0
- package/dist/components/Feedback/LMModal/LMModal.d.ts +62 -0
- package/dist/components/Feedback/LMModal/LMModal.d.ts.map +1 -0
- package/dist/components/Feedback/LMModal/LMModal.stories.d.ts +23 -0
- package/dist/components/Feedback/LMModal/LMModal.stories.d.ts.map +1 -0
- package/dist/components/Feedback/LMModal/LMModal.test.d.ts +2 -0
- package/dist/components/Feedback/LMModal/LMModal.test.d.ts.map +1 -0
- package/dist/components/Feedback/LMModal/index.d.ts +3 -0
- package/dist/components/Feedback/LMModal/index.d.ts.map +1 -0
- package/dist/components/Feedback/index.d.ts +5 -0
- package/dist/components/Feedback/index.d.ts.map +1 -0
- package/dist/components/Form/LMCheckbox/LMCheckbox.d.ts +18 -0
- package/dist/components/Form/LMCheckbox/LMCheckbox.d.ts.map +1 -0
- package/dist/components/Form/LMCheckbox/LMCheckbox.stories.d.ts +23 -0
- package/dist/components/Form/LMCheckbox/LMCheckbox.stories.d.ts.map +1 -0
- package/dist/components/Form/LMCheckbox/LMCheckbox.test.d.ts +2 -0
- package/dist/components/Form/LMCheckbox/LMCheckbox.test.d.ts.map +1 -0
- package/dist/components/Form/LMCheckbox/index.d.ts +3 -0
- package/dist/components/Form/LMCheckbox/index.d.ts.map +1 -0
- package/dist/components/Form/LMDatePicker/LMDatePicker.d.ts +52 -0
- package/dist/components/Form/LMDatePicker/LMDatePicker.d.ts.map +1 -0
- package/dist/components/Form/LMDatePicker/LMDatePicker.stories.d.ts +41 -0
- package/dist/components/Form/LMDatePicker/LMDatePicker.stories.d.ts.map +1 -0
- package/dist/components/Form/LMDatePicker/LMDatePicker.test.d.ts +2 -0
- package/dist/components/Form/LMDatePicker/LMDatePicker.test.d.ts.map +1 -0
- package/dist/components/Form/LMDatePicker/index.d.ts +3 -0
- package/dist/components/Form/LMDatePicker/index.d.ts.map +1 -0
- package/dist/components/Form/LMField/LMField.d.ts +19 -0
- package/dist/components/Form/LMField/LMField.d.ts.map +1 -0
- package/dist/components/Form/LMField/LMField.stories.d.ts +23 -0
- package/dist/components/Form/LMField/LMField.stories.d.ts.map +1 -0
- package/dist/components/Form/LMField/LMField.test.d.ts +2 -0
- package/dist/components/Form/LMField/LMField.test.d.ts.map +1 -0
- package/dist/components/Form/LMField/index.d.ts +3 -0
- package/dist/components/Form/LMField/index.d.ts.map +1 -0
- package/dist/components/Form/LMInput/LMInput.d.ts +20 -0
- package/dist/components/Form/LMInput/LMInput.d.ts.map +1 -0
- package/dist/components/Form/LMInput/LMInput.stories.d.ts +29 -0
- package/dist/components/Form/LMInput/LMInput.stories.d.ts.map +1 -0
- package/dist/components/Form/LMInput/LMInput.test.d.ts +2 -0
- package/dist/components/Form/LMInput/LMInput.test.d.ts.map +1 -0
- package/dist/components/Form/LMInput/index.d.ts +3 -0
- package/dist/components/Form/LMInput/index.d.ts.map +1 -0
- package/dist/components/Form/LMNumberInput/LMNumberInput.d.ts +40 -0
- package/dist/components/Form/LMNumberInput/LMNumberInput.d.ts.map +1 -0
- package/dist/components/Form/LMNumberInput/LMNumberInput.stories.d.ts +33 -0
- package/dist/components/Form/LMNumberInput/LMNumberInput.stories.d.ts.map +1 -0
- package/dist/components/Form/LMNumberInput/LMNumberInput.test.d.ts +2 -0
- package/dist/components/Form/LMNumberInput/LMNumberInput.test.d.ts.map +1 -0
- package/dist/components/Form/LMNumberInput/index.d.ts +3 -0
- package/dist/components/Form/LMNumberInput/index.d.ts.map +1 -0
- package/dist/components/Form/LMRadio/LMRadio.d.ts +18 -0
- package/dist/components/Form/LMRadio/LMRadio.d.ts.map +1 -0
- package/dist/components/Form/LMRadio/LMRadio.stories.d.ts +25 -0
- package/dist/components/Form/LMRadio/LMRadio.stories.d.ts.map +1 -0
- package/dist/components/Form/LMRadio/LMRadio.test.d.ts +2 -0
- package/dist/components/Form/LMRadio/LMRadio.test.d.ts.map +1 -0
- package/dist/components/Form/LMRadio/index.d.ts +3 -0
- package/dist/components/Form/LMRadio/index.d.ts.map +1 -0
- package/dist/components/Form/LMSearchInput/LMSearchInput.d.ts +36 -0
- package/dist/components/Form/LMSearchInput/LMSearchInput.d.ts.map +1 -0
- package/dist/components/Form/LMSearchInput/LMSearchInput.stories.d.ts +27 -0
- package/dist/components/Form/LMSearchInput/LMSearchInput.stories.d.ts.map +1 -0
- package/dist/components/Form/LMSearchInput/LMSearchInput.test.d.ts +2 -0
- package/dist/components/Form/LMSearchInput/LMSearchInput.test.d.ts.map +1 -0
- package/dist/components/Form/LMSearchInput/index.d.ts +3 -0
- package/dist/components/Form/LMSearchInput/index.d.ts.map +1 -0
- package/dist/components/Form/LMSelect/LMSelect.d.ts +37 -0
- package/dist/components/Form/LMSelect/LMSelect.d.ts.map +1 -0
- package/dist/components/Form/LMSelect/LMSelect.stories.d.ts +27 -0
- package/dist/components/Form/LMSelect/LMSelect.stories.d.ts.map +1 -0
- package/dist/components/Form/LMSelect/LMSelect.test.d.ts +2 -0
- package/dist/components/Form/LMSelect/LMSelect.test.d.ts.map +1 -0
- package/dist/components/Form/LMSelect/index.d.ts +3 -0
- package/dist/components/Form/LMSelect/index.d.ts.map +1 -0
- package/dist/components/Form/LMSwitch/LMSwitch.d.ts +18 -0
- package/dist/components/Form/LMSwitch/LMSwitch.d.ts.map +1 -0
- package/dist/components/Form/LMSwitch/LMSwitch.stories.d.ts +25 -0
- package/dist/components/Form/LMSwitch/LMSwitch.stories.d.ts.map +1 -0
- package/dist/components/Form/LMSwitch/LMSwitch.test.d.ts +2 -0
- package/dist/components/Form/LMSwitch/LMSwitch.test.d.ts.map +1 -0
- package/dist/components/Form/LMSwitch/index.d.ts +3 -0
- package/dist/components/Form/LMSwitch/index.d.ts.map +1 -0
- package/dist/components/Form/LMTextarea/LMTextarea.d.ts +14 -0
- package/dist/components/Form/LMTextarea/LMTextarea.d.ts.map +1 -0
- package/dist/components/Form/LMTextarea/LMTextarea.stories.d.ts +23 -0
- package/dist/components/Form/LMTextarea/LMTextarea.stories.d.ts.map +1 -0
- package/dist/components/Form/LMTextarea/LMTextarea.test.d.ts +2 -0
- package/dist/components/Form/LMTextarea/LMTextarea.test.d.ts.map +1 -0
- package/dist/components/Form/LMTextarea/index.d.ts +3 -0
- package/dist/components/Form/LMTextarea/index.d.ts.map +1 -0
- package/dist/components/Form/LMUpload/LMUpload.d.ts +68 -0
- package/dist/components/Form/LMUpload/LMUpload.d.ts.map +1 -0
- package/dist/components/Form/LMUpload/LMUpload.stories.d.ts +41 -0
- package/dist/components/Form/LMUpload/LMUpload.stories.d.ts.map +1 -0
- package/dist/components/Form/LMUpload/LMUpload.test.d.ts +2 -0
- package/dist/components/Form/LMUpload/LMUpload.test.d.ts.map +1 -0
- package/dist/components/Form/LMUpload/index.d.ts +3 -0
- package/dist/components/Form/LMUpload/index.d.ts.map +1 -0
- package/dist/components/Form/index.d.ts +12 -0
- package/dist/components/Form/index.d.ts.map +1 -0
- package/dist/components/General/LMBadge/LMBadge.d.ts +21 -0
- package/dist/components/General/LMBadge/LMBadge.d.ts.map +1 -0
- package/dist/components/General/LMBadge/LMBadge.stories.d.ts +31 -0
- package/dist/components/General/LMBadge/LMBadge.stories.d.ts.map +1 -0
- package/dist/components/General/LMBadge/LMBadge.test.d.ts +2 -0
- package/dist/components/General/LMBadge/LMBadge.test.d.ts.map +1 -0
- package/dist/components/General/LMBadge/index.d.ts +3 -0
- package/dist/components/General/LMBadge/index.d.ts.map +1 -0
- package/dist/components/General/LMButton/LMButton.d.ts +25 -0
- package/dist/components/General/LMButton/LMButton.d.ts.map +1 -0
- package/dist/components/General/LMButton/LMButton.stories.d.ts +39 -0
- package/dist/components/General/LMButton/LMButton.stories.d.ts.map +1 -0
- package/dist/components/General/LMButton/LMButton.test.d.ts +2 -0
- package/dist/components/General/LMButton/LMButton.test.d.ts.map +1 -0
- package/dist/components/General/LMButton/index.d.ts +3 -0
- package/dist/components/General/LMButton/index.d.ts.map +1 -0
- package/dist/components/General/index.d.ts +3 -0
- package/dist/components/General/index.d.ts.map +1 -0
- package/dist/components/Navigation/LMDropdown/LMDropdown.d.ts +40 -0
- package/dist/components/Navigation/LMDropdown/LMDropdown.d.ts.map +1 -0
- package/dist/components/Navigation/LMDropdown/LMDropdown.stories.d.ts +31 -0
- package/dist/components/Navigation/LMDropdown/LMDropdown.stories.d.ts.map +1 -0
- package/dist/components/Navigation/LMDropdown/LMDropdown.test.d.ts +2 -0
- package/dist/components/Navigation/LMDropdown/LMDropdown.test.d.ts.map +1 -0
- package/dist/components/Navigation/LMDropdown/index.d.ts +3 -0
- package/dist/components/Navigation/LMDropdown/index.d.ts.map +1 -0
- package/dist/components/Navigation/LMMenu/LMMenu.d.ts +48 -0
- package/dist/components/Navigation/LMMenu/LMMenu.d.ts.map +1 -0
- package/dist/components/Navigation/LMMenu/LMMenu.stories.d.ts +25 -0
- package/dist/components/Navigation/LMMenu/LMMenu.stories.d.ts.map +1 -0
- package/dist/components/Navigation/LMMenu/LMMenu.test.d.ts +2 -0
- package/dist/components/Navigation/LMMenu/LMMenu.test.d.ts.map +1 -0
- package/dist/components/Navigation/LMMenu/index.d.ts +3 -0
- package/dist/components/Navigation/LMMenu/index.d.ts.map +1 -0
- package/dist/components/Navigation/LMPagination/LMPagination.d.ts +32 -0
- package/dist/components/Navigation/LMPagination/LMPagination.d.ts.map +1 -0
- package/dist/components/Navigation/LMPagination/LMPagination.stories.d.ts +35 -0
- package/dist/components/Navigation/LMPagination/LMPagination.stories.d.ts.map +1 -0
- package/dist/components/Navigation/LMPagination/LMPagination.test.d.ts +2 -0
- package/dist/components/Navigation/LMPagination/LMPagination.test.d.ts.map +1 -0
- package/dist/components/Navigation/LMPagination/index.d.ts +3 -0
- package/dist/components/Navigation/LMPagination/index.d.ts.map +1 -0
- package/dist/components/Navigation/index.d.ts +4 -0
- package/dist/components/Navigation/index.d.ts.map +1 -0
- package/dist/components/badge/index.cjs +5 -0
- package/dist/components/badge/index.cjs.map +1 -0
- package/dist/components/badge/index.js +5 -0
- package/dist/components/badge/index.js.map +1 -0
- package/dist/components/button/index.cjs +5 -0
- package/dist/components/button/index.cjs.map +1 -0
- package/dist/components/button/index.js +5 -0
- package/dist/components/button/index.js.map +1 -0
- package/dist/components/card/index.cjs +5 -0
- package/dist/components/card/index.cjs.map +1 -0
- package/dist/components/card/index.js +5 -0
- package/dist/components/card/index.js.map +1 -0
- package/dist/components/checkbox/index.cjs +5 -0
- package/dist/components/checkbox/index.cjs.map +1 -0
- package/dist/components/checkbox/index.js +5 -0
- package/dist/components/checkbox/index.js.map +1 -0
- package/dist/components/confirm/index.cjs +6 -0
- package/dist/components/confirm/index.cjs.map +1 -0
- package/dist/components/confirm/index.js +6 -0
- package/dist/components/confirm/index.js.map +1 -0
- package/dist/components/date-picker/index.cjs +5 -0
- package/dist/components/date-picker/index.cjs.map +1 -0
- package/dist/components/date-picker/index.js +5 -0
- package/dist/components/date-picker/index.js.map +1 -0
- package/dist/components/drawer/index.cjs +5 -0
- package/dist/components/drawer/index.cjs.map +1 -0
- package/dist/components/drawer/index.js +5 -0
- package/dist/components/drawer/index.js.map +1 -0
- package/dist/components/dropdown/index.cjs +5 -0
- package/dist/components/dropdown/index.cjs.map +1 -0
- package/dist/components/dropdown/index.js +5 -0
- package/dist/components/dropdown/index.js.map +1 -0
- package/dist/components/empty/index.cjs +5 -0
- package/dist/components/empty/index.cjs.map +1 -0
- package/dist/components/empty/index.js +5 -0
- package/dist/components/empty/index.js.map +1 -0
- package/dist/components/field/index.cjs +5 -0
- package/dist/components/field/index.cjs.map +1 -0
- package/dist/components/field/index.js +5 -0
- package/dist/components/field/index.js.map +1 -0
- package/dist/components/input/index.cjs +5 -0
- package/dist/components/input/index.cjs.map +1 -0
- package/dist/components/input/index.js +5 -0
- package/dist/components/input/index.js.map +1 -0
- package/dist/components/menu/index.cjs +5 -0
- package/dist/components/menu/index.cjs.map +1 -0
- package/dist/components/menu/index.js +5 -0
- package/dist/components/menu/index.js.map +1 -0
- package/dist/components/message/index.cjs +7 -0
- package/dist/components/message/index.cjs.map +1 -0
- package/dist/components/message/index.js +7 -0
- package/dist/components/message/index.js.map +1 -0
- package/dist/components/modal/index.cjs +5 -0
- package/dist/components/modal/index.cjs.map +1 -0
- package/dist/components/modal/index.js +5 -0
- package/dist/components/modal/index.js.map +1 -0
- package/dist/components/number-input/index.cjs +5 -0
- package/dist/components/number-input/index.cjs.map +1 -0
- package/dist/components/number-input/index.js +5 -0
- package/dist/components/number-input/index.js.map +1 -0
- package/dist/components/pagination/index.cjs +5 -0
- package/dist/components/pagination/index.cjs.map +1 -0
- package/dist/components/pagination/index.js +5 -0
- package/dist/components/pagination/index.js.map +1 -0
- package/dist/components/radio/index.cjs +5 -0
- package/dist/components/radio/index.cjs.map +1 -0
- package/dist/components/radio/index.js +5 -0
- package/dist/components/radio/index.js.map +1 -0
- package/dist/components/search-input/index.cjs +5 -0
- package/dist/components/search-input/index.cjs.map +1 -0
- package/dist/components/search-input/index.js +5 -0
- package/dist/components/search-input/index.js.map +1 -0
- package/dist/components/select/index.cjs +5 -0
- package/dist/components/select/index.cjs.map +1 -0
- package/dist/components/select/index.js +5 -0
- package/dist/components/select/index.js.map +1 -0
- package/dist/components/stat-card/index.cjs +5 -0
- package/dist/components/stat-card/index.cjs.map +1 -0
- package/dist/components/stat-card/index.js +5 -0
- package/dist/components/stat-card/index.js.map +1 -0
- package/dist/components/switch/index.cjs +5 -0
- package/dist/components/switch/index.cjs.map +1 -0
- package/dist/components/switch/index.js +5 -0
- package/dist/components/switch/index.js.map +1 -0
- package/dist/components/table/index.cjs +5 -0
- package/dist/components/table/index.cjs.map +1 -0
- package/dist/components/table/index.js +5 -0
- package/dist/components/table/index.js.map +1 -0
- package/dist/components/tabs/index.cjs +5 -0
- package/dist/components/tabs/index.cjs.map +1 -0
- package/dist/components/tabs/index.js +5 -0
- package/dist/components/tabs/index.js.map +1 -0
- package/dist/components/textarea/index.cjs +5 -0
- package/dist/components/textarea/index.cjs.map +1 -0
- package/dist/components/textarea/index.js +5 -0
- package/dist/components/textarea/index.js.map +1 -0
- package/dist/components/tooltip/index.cjs +5 -0
- package/dist/components/tooltip/index.cjs.map +1 -0
- package/dist/components/tooltip/index.js +5 -0
- package/dist/components/tooltip/index.js.map +1 -0
- package/dist/components/upload/index.cjs +5 -0
- package/dist/components/upload/index.cjs.map +1 -0
- package/dist/components/upload/index.js +5 -0
- package/dist/components/upload/index.js.map +1 -0
- package/dist/hooks/index.d.ts +5 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/useConfirm.d.ts +17 -0
- package/dist/hooks/useConfirm.d.ts.map +1 -0
- package/dist/hooks/useMessage.d.ts +14 -0
- package/dist/hooks/useMessage.d.ts.map +1 -0
- package/dist/index.cjs +1907 -6229
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +10 -982
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +1906 -6227
- package/dist/index.js.map +1 -1
- package/dist/style.css +389 -60
- package/dist/types/index.d.ts +25 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/useConfirm-BIxTX3mT.js +218 -0
- package/dist/useConfirm-BIxTX3mT.js.map +1 -0
- package/dist/useConfirm-BO5Ch3Bf.cjs +217 -0
- package/dist/useConfirm-BO5Ch3Bf.cjs.map +1 -0
- package/dist/useMessage-BBxUPe8b.cjs +242 -0
- package/dist/useMessage-BBxUPe8b.cjs.map +1 -0
- package/dist/useMessage-CRsCgzDR.js +243 -0
- package/dist/useMessage-CRsCgzDR.js.map +1 -0
- package/dist/utils/cn.d.ts +8 -0
- package/dist/utils/cn.d.ts.map +1 -0
- package/dist/utils/componentSizes.d.ts +57 -0
- package/dist/utils/componentSizes.d.ts.map +1 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/package.json +270 -9
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const jsxRuntime = require("react/jsx-runtime");
|
|
3
|
+
const React = require("react");
|
|
4
|
+
const ICONS = {
|
|
5
|
+
success: /* @__PURE__ */ jsxRuntime.jsxs("svg", { viewBox: "0 0 24 24", className: "h-5 w-5", "aria-hidden": "true", children: [
|
|
6
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
7
|
+
"path",
|
|
8
|
+
{
|
|
9
|
+
d: "M12 22a10 10 0 1 1 0-20 10 10 0 0 1 0 20Z",
|
|
10
|
+
fill: "currentColor",
|
|
11
|
+
opacity: "0.15"
|
|
12
|
+
}
|
|
13
|
+
),
|
|
14
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
15
|
+
"path",
|
|
16
|
+
{
|
|
17
|
+
d: "M16.7 9.3a1 1 0 0 0-1.4-1.4L11 12.2 8.7 9.9a1 1 0 1 0-1.4 1.4l3 3a1 1 0 0 0 1.4 0l5-5Z",
|
|
18
|
+
fill: "currentColor"
|
|
19
|
+
}
|
|
20
|
+
)
|
|
21
|
+
] }),
|
|
22
|
+
error: /* @__PURE__ */ jsxRuntime.jsxs("svg", { viewBox: "0 0 24 24", className: "h-5 w-5", "aria-hidden": "true", children: [
|
|
23
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
24
|
+
"path",
|
|
25
|
+
{
|
|
26
|
+
d: "M12 22c5.5 0 10-4.5 10-10S17.5 2 12 2 2 6.5 2 12s4.5 10 10 10Z",
|
|
27
|
+
fill: "currentColor",
|
|
28
|
+
opacity: "0.15"
|
|
29
|
+
}
|
|
30
|
+
),
|
|
31
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
32
|
+
"path",
|
|
33
|
+
{
|
|
34
|
+
d: "M15.5 8.5l-7 7M8.5 8.5l7 7",
|
|
35
|
+
stroke: "currentColor",
|
|
36
|
+
strokeWidth: "1.8",
|
|
37
|
+
strokeLinecap: "round"
|
|
38
|
+
}
|
|
39
|
+
)
|
|
40
|
+
] }),
|
|
41
|
+
warning: /* @__PURE__ */ jsxRuntime.jsxs("svg", { viewBox: "0 0 24 24", className: "h-5 w-5", "aria-hidden": "true", children: [
|
|
42
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
43
|
+
"path",
|
|
44
|
+
{
|
|
45
|
+
d: "M12.9 4.5c-.4-.7-1.4-.7-1.8 0L3.5 18a1 1 0 0 0 .9 1.5h15.2a1 1 0 0 0 .9-1.5l-7.6-13.5Z",
|
|
46
|
+
fill: "currentColor",
|
|
47
|
+
opacity: "0.15"
|
|
48
|
+
}
|
|
49
|
+
),
|
|
50
|
+
/* @__PURE__ */ jsxRuntime.jsx("path", { d: "M12 9v5", stroke: "currentColor", strokeWidth: "1.8", strokeLinecap: "round" }),
|
|
51
|
+
/* @__PURE__ */ jsxRuntime.jsx("circle", { cx: "12", cy: "16.5", r: "1", fill: "currentColor" })
|
|
52
|
+
] }),
|
|
53
|
+
info: /* @__PURE__ */ jsxRuntime.jsxs("svg", { viewBox: "0 0 24 24", className: "h-5 w-5", "aria-hidden": "true", children: [
|
|
54
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
55
|
+
"path",
|
|
56
|
+
{
|
|
57
|
+
d: "M12 22a10 10 0 1 0 0-20 10 10 0 0 0 0 20Z",
|
|
58
|
+
fill: "currentColor",
|
|
59
|
+
opacity: "0.15"
|
|
60
|
+
}
|
|
61
|
+
),
|
|
62
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
63
|
+
"path",
|
|
64
|
+
{
|
|
65
|
+
d: "M12 10.5v5M12 7.5h.01",
|
|
66
|
+
stroke: "currentColor",
|
|
67
|
+
strokeWidth: "1.8",
|
|
68
|
+
strokeLinecap: "round"
|
|
69
|
+
}
|
|
70
|
+
)
|
|
71
|
+
] })
|
|
72
|
+
};
|
|
73
|
+
const useTone = (type) => {
|
|
74
|
+
switch (type) {
|
|
75
|
+
case "success":
|
|
76
|
+
return {
|
|
77
|
+
accent: "var(--lm-success-500)",
|
|
78
|
+
background: "color-mix(in srgb, var(--lm-success-100) 60%, transparent)",
|
|
79
|
+
text: "var(--lm-success-700)",
|
|
80
|
+
title: "var(--lm-success-800)"
|
|
81
|
+
};
|
|
82
|
+
case "error":
|
|
83
|
+
return {
|
|
84
|
+
accent: "var(--lm-error-500)",
|
|
85
|
+
background: "color-mix(in srgb, var(--lm-error-100) 60%, transparent)",
|
|
86
|
+
text: "var(--lm-error-700)",
|
|
87
|
+
title: "var(--lm-error-800)"
|
|
88
|
+
};
|
|
89
|
+
case "warning":
|
|
90
|
+
return {
|
|
91
|
+
accent: "var(--lm-warning-500)",
|
|
92
|
+
background: "color-mix(in srgb, var(--lm-warning-100) 60%, transparent)",
|
|
93
|
+
text: "var(--lm-warning-700)",
|
|
94
|
+
title: "var(--lm-warning-800)"
|
|
95
|
+
};
|
|
96
|
+
case "info":
|
|
97
|
+
default:
|
|
98
|
+
return {
|
|
99
|
+
accent: "var(--lm-primary-500)",
|
|
100
|
+
background: "color-mix(in srgb, var(--lm-primary-100) 60%, transparent)",
|
|
101
|
+
text: "var(--lm-primary-700)",
|
|
102
|
+
title: "var(--lm-primary-800)"
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
const LMMessage = ({ id, type, title, content, duration = 2e3, onClose }) => {
|
|
107
|
+
const tone = useTone(type);
|
|
108
|
+
React.useEffect(() => {
|
|
109
|
+
if (duration <= 0) return;
|
|
110
|
+
const timer = setTimeout(() => onClose(id), duration);
|
|
111
|
+
return () => clearTimeout(timer);
|
|
112
|
+
}, [id, duration, onClose]);
|
|
113
|
+
const icon = React.useMemo(() => ICONS[type], [type]);
|
|
114
|
+
const ariaRole = "status";
|
|
115
|
+
const ariaLabel = React.useMemo(() => {
|
|
116
|
+
switch (type) {
|
|
117
|
+
case "success":
|
|
118
|
+
return "Success message";
|
|
119
|
+
case "error":
|
|
120
|
+
return "Error message";
|
|
121
|
+
case "warning":
|
|
122
|
+
return "Warning message";
|
|
123
|
+
default:
|
|
124
|
+
return "Information message";
|
|
125
|
+
}
|
|
126
|
+
}, [type]);
|
|
127
|
+
return /* @__PURE__ */ jsxRuntime.jsx("div", { className: "max-w-sm mx-auto will-change-transform", role: ariaRole, "aria-label": ariaLabel, children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
128
|
+
"div",
|
|
129
|
+
{
|
|
130
|
+
className: "rounded-3xl shadow-lg p-5 mb-3 backdrop-blur-md border transition-all duration-300 ease-out",
|
|
131
|
+
style: {
|
|
132
|
+
backgroundColor: tone.background,
|
|
133
|
+
borderColor: "var(--lm-border-light)",
|
|
134
|
+
boxShadow: "var(--lm-shadow-lg)"
|
|
135
|
+
},
|
|
136
|
+
children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex items-start gap-4", children: [
|
|
137
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
138
|
+
"div",
|
|
139
|
+
{
|
|
140
|
+
className: "mt-0.5 flex h-10 w-10 items-center justify-center rounded-2xl",
|
|
141
|
+
style: {
|
|
142
|
+
color: tone.accent,
|
|
143
|
+
backgroundColor: "color-mix(in srgb, currentColor 12%, transparent)"
|
|
144
|
+
},
|
|
145
|
+
children: icon
|
|
146
|
+
}
|
|
147
|
+
),
|
|
148
|
+
/* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex-1 min-w-0", children: [
|
|
149
|
+
title && /* @__PURE__ */ jsxRuntime.jsx("h4", { className: "text-sm font-semibold mb-2 truncate", style: { color: tone.title }, children: title }),
|
|
150
|
+
/* @__PURE__ */ jsxRuntime.jsx("p", { className: "text-sm leading-relaxed wrap-break-word", style: { color: tone.text }, children: content })
|
|
151
|
+
] }),
|
|
152
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
153
|
+
"button",
|
|
154
|
+
{
|
|
155
|
+
onClick: () => onClose(id),
|
|
156
|
+
"aria-label": "Close message",
|
|
157
|
+
className: "shrink-0 p-2 rounded-xl transition-all duration-200 hover:bg-black/5 active:bg-black/10",
|
|
158
|
+
style: { color: tone.accent },
|
|
159
|
+
children: /* @__PURE__ */ jsxRuntime.jsx("svg", { viewBox: "0 0 24 24", className: "h-4 w-4", "aria-hidden": "true", children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
160
|
+
"path",
|
|
161
|
+
{
|
|
162
|
+
d: "M6 6l12 12M18 6L6 18",
|
|
163
|
+
stroke: "currentColor",
|
|
164
|
+
strokeWidth: "2",
|
|
165
|
+
strokeLinecap: "round"
|
|
166
|
+
}
|
|
167
|
+
) })
|
|
168
|
+
}
|
|
169
|
+
)
|
|
170
|
+
] })
|
|
171
|
+
}
|
|
172
|
+
) });
|
|
173
|
+
};
|
|
174
|
+
const LMMessageContainer = ({
|
|
175
|
+
messages,
|
|
176
|
+
onClose,
|
|
177
|
+
position = "top-right"
|
|
178
|
+
}) => {
|
|
179
|
+
if (messages.length === 0) return null;
|
|
180
|
+
const positionClasses = {
|
|
181
|
+
"top-right": "top-20 right-6",
|
|
182
|
+
"top-left": "top-20 left-6",
|
|
183
|
+
"top-center": "top-20 left-1/2 -translate-x-1/2",
|
|
184
|
+
"bottom-right": "bottom-6 right-6",
|
|
185
|
+
"bottom-left": "bottom-6 left-6",
|
|
186
|
+
"bottom-center": "bottom-6 left-1/2 -translate-x-1/2"
|
|
187
|
+
};
|
|
188
|
+
return /* @__PURE__ */ jsxRuntime.jsx("div", { className: `fixed z-50 space-y-3 ${positionClasses[position]}`, children: messages.map((message) => /* @__PURE__ */ jsxRuntime.jsx(LMMessage, { ...message, onClose }, message.id)) });
|
|
189
|
+
};
|
|
190
|
+
let messageIdCounter = 0;
|
|
191
|
+
const useMessage = () => {
|
|
192
|
+
const [messages, setMessages] = React.useState([]);
|
|
193
|
+
const addMessage = React.useCallback((message) => {
|
|
194
|
+
const id = `lm-message-${++messageIdCounter}`;
|
|
195
|
+
setMessages((prev) => [...prev, { ...message, id }]);
|
|
196
|
+
return id;
|
|
197
|
+
}, []);
|
|
198
|
+
const removeMessage = React.useCallback((id) => {
|
|
199
|
+
setMessages((prev) => prev.filter((m) => m.id !== id));
|
|
200
|
+
}, []);
|
|
201
|
+
const success = React.useCallback(
|
|
202
|
+
(content, title, duration) => {
|
|
203
|
+
return addMessage({ type: "success", content, title, duration });
|
|
204
|
+
},
|
|
205
|
+
[addMessage]
|
|
206
|
+
);
|
|
207
|
+
const error = React.useCallback(
|
|
208
|
+
(content, title, duration) => {
|
|
209
|
+
return addMessage({ type: "error", content, title, duration });
|
|
210
|
+
},
|
|
211
|
+
[addMessage]
|
|
212
|
+
);
|
|
213
|
+
const warning = React.useCallback(
|
|
214
|
+
(content, title, duration) => {
|
|
215
|
+
return addMessage({ type: "warning", content, title, duration });
|
|
216
|
+
},
|
|
217
|
+
[addMessage]
|
|
218
|
+
);
|
|
219
|
+
const info = React.useCallback(
|
|
220
|
+
(content, title, duration) => {
|
|
221
|
+
return addMessage({ type: "info", content, title, duration });
|
|
222
|
+
},
|
|
223
|
+
[addMessage]
|
|
224
|
+
);
|
|
225
|
+
const clearAll = React.useCallback(() => {
|
|
226
|
+
setMessages([]);
|
|
227
|
+
}, []);
|
|
228
|
+
return {
|
|
229
|
+
messages,
|
|
230
|
+
addMessage,
|
|
231
|
+
removeMessage,
|
|
232
|
+
success,
|
|
233
|
+
error,
|
|
234
|
+
warning,
|
|
235
|
+
info,
|
|
236
|
+
clearAll
|
|
237
|
+
};
|
|
238
|
+
};
|
|
239
|
+
exports.LMMessage = LMMessage;
|
|
240
|
+
exports.LMMessageContainer = LMMessageContainer;
|
|
241
|
+
exports.useMessage = useMessage;
|
|
242
|
+
//# sourceMappingURL=useMessage-BBxUPe8b.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useMessage-BBxUPe8b.cjs","sources":["../src/components/Feedback/LMMessage/LMMessage.tsx","../src/hooks/useMessage.ts"],"sourcesContent":["import React, { useEffect, useMemo } from 'react'\n\nexport type LMMessageType = 'success' | 'error' | 'warning' | 'info'\n\nexport interface LMMessageItem {\n id: string\n type: LMMessageType\n title?: string\n content: string\n duration?: number\n}\n\nexport interface LMMessageProps {\n id: string\n type: LMMessageType\n title?: string\n content: string\n /** Auto close duration in ms, 0 means no auto close */\n duration?: number\n onClose: (id: string) => void\n}\n\ninterface Tone {\n accent: string\n background: string\n text: string\n title: string\n}\n\nconst ICONS: Record<LMMessageType, React.ReactNode> = {\n success: (\n <svg viewBox=\"0 0 24 24\" className=\"h-5 w-5\" aria-hidden=\"true\">\n <path\n d=\"M12 22a10 10 0 1 1 0-20 10 10 0 0 1 0 20Z\"\n fill=\"currentColor\"\n opacity=\"0.15\"\n />\n <path\n d=\"M16.7 9.3a1 1 0 0 0-1.4-1.4L11 12.2 8.7 9.9a1 1 0 1 0-1.4 1.4l3 3a1 1 0 0 0 1.4 0l5-5Z\"\n fill=\"currentColor\"\n />\n </svg>\n ),\n error: (\n <svg viewBox=\"0 0 24 24\" className=\"h-5 w-5\" aria-hidden=\"true\">\n <path\n d=\"M12 22c5.5 0 10-4.5 10-10S17.5 2 12 2 2 6.5 2 12s4.5 10 10 10Z\"\n fill=\"currentColor\"\n opacity=\"0.15\"\n />\n <path\n d=\"M15.5 8.5l-7 7M8.5 8.5l7 7\"\n stroke=\"currentColor\"\n strokeWidth=\"1.8\"\n strokeLinecap=\"round\"\n />\n </svg>\n ),\n warning: (\n <svg viewBox=\"0 0 24 24\" className=\"h-5 w-5\" aria-hidden=\"true\">\n <path\n d=\"M12.9 4.5c-.4-.7-1.4-.7-1.8 0L3.5 18a1 1 0 0 0 .9 1.5h15.2a1 1 0 0 0 .9-1.5l-7.6-13.5Z\"\n fill=\"currentColor\"\n opacity=\"0.15\"\n />\n <path d=\"M12 9v5\" stroke=\"currentColor\" strokeWidth=\"1.8\" strokeLinecap=\"round\" />\n <circle cx=\"12\" cy=\"16.5\" r=\"1\" fill=\"currentColor\" />\n </svg>\n ),\n info: (\n <svg viewBox=\"0 0 24 24\" className=\"h-5 w-5\" aria-hidden=\"true\">\n <path\n d=\"M12 22a10 10 0 1 0 0-20 10 10 0 0 0 0 20Z\"\n fill=\"currentColor\"\n opacity=\"0.15\"\n />\n <path\n d=\"M12 10.5v5M12 7.5h.01\"\n stroke=\"currentColor\"\n strokeWidth=\"1.8\"\n strokeLinecap=\"round\"\n />\n </svg>\n ),\n}\n\nconst useTone = (type: LMMessageType): Tone => {\n switch (type) {\n case 'success':\n return {\n accent: 'var(--lm-success-500)',\n background: 'color-mix(in srgb, var(--lm-success-100) 60%, transparent)',\n text: 'var(--lm-success-700)',\n title: 'var(--lm-success-800)',\n }\n case 'error':\n return {\n accent: 'var(--lm-error-500)',\n background: 'color-mix(in srgb, var(--lm-error-100) 60%, transparent)',\n text: 'var(--lm-error-700)',\n title: 'var(--lm-error-800)',\n }\n case 'warning':\n return {\n accent: 'var(--lm-warning-500)',\n background: 'color-mix(in srgb, var(--lm-warning-100) 60%, transparent)',\n text: 'var(--lm-warning-700)',\n title: 'var(--lm-warning-800)',\n }\n case 'info':\n default:\n return {\n accent: 'var(--lm-primary-500)',\n background: 'color-mix(in srgb, var(--lm-primary-100) 60%, transparent)',\n text: 'var(--lm-primary-700)',\n title: 'var(--lm-primary-800)',\n }\n }\n}\n\nconst LMMessage: React.FC<LMMessageProps> = ({ id, type, title, content, duration = 2000, onClose }) => {\n const tone = useTone(type)\n\n useEffect(() => {\n if (duration <= 0) return\n const timer = setTimeout(() => onClose(id), duration)\n return () => clearTimeout(timer)\n }, [id, duration, onClose])\n\n const icon = useMemo(() => ICONS[type], [type])\n const ariaRole = 'status'\n const ariaLabel = useMemo(() => {\n switch (type) {\n case 'success':\n return 'Success message'\n case 'error':\n return 'Error message'\n case 'warning':\n return 'Warning message'\n default:\n return 'Information message'\n }\n }, [type])\n\n return (\n <div className=\"max-w-sm mx-auto will-change-transform\" role={ariaRole} aria-label={ariaLabel}>\n <div\n className=\"rounded-3xl shadow-lg p-5 mb-3 backdrop-blur-md border transition-all duration-300 ease-out\"\n style={{\n backgroundColor: tone.background,\n borderColor: 'var(--lm-border-light)',\n boxShadow: 'var(--lm-shadow-lg)',\n }}\n >\n <div className=\"flex items-start gap-4\">\n <div\n className=\"mt-0.5 flex h-10 w-10 items-center justify-center rounded-2xl\"\n style={{\n color: tone.accent,\n backgroundColor: 'color-mix(in srgb, currentColor 12%, transparent)',\n }}\n >\n {icon}\n </div>\n\n <div className=\"flex-1 min-w-0\">\n {title && (\n <h4 className=\"text-sm font-semibold mb-2 truncate\" style={{ color: tone.title }}>\n {title}\n </h4>\n )}\n <p className=\"text-sm leading-relaxed wrap-break-word\" style={{ color: tone.text }}>\n {content}\n </p>\n </div>\n\n <button\n onClick={() => onClose(id)}\n aria-label=\"Close message\"\n className=\"shrink-0 p-2 rounded-xl transition-all duration-200 hover:bg-black/5 active:bg-black/10\"\n style={{ color: tone.accent }}\n >\n <svg viewBox=\"0 0 24 24\" className=\"h-4 w-4\" aria-hidden=\"true\">\n <path\n d=\"M6 6l12 12M18 6L6 18\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n )\n}\n\nexport interface LMMessageContainerProps {\n /** Messages list */\n messages: LMMessageItem[]\n /** Close callback */\n onClose: (id: string) => void\n /** Position */\n position?: 'top-right' | 'top-left' | 'top-center' | 'bottom-right' | 'bottom-left' | 'bottom-center'\n}\n\nexport const LMMessageContainer: React.FC<LMMessageContainerProps> = ({\n messages,\n onClose,\n position = 'top-right',\n}) => {\n if (messages.length === 0) return null\n\n const positionClasses = {\n 'top-right': 'top-20 right-6',\n 'top-left': 'top-20 left-6',\n 'top-center': 'top-20 left-1/2 -translate-x-1/2',\n 'bottom-right': 'bottom-6 right-6',\n 'bottom-left': 'bottom-6 left-6',\n 'bottom-center': 'bottom-6 left-1/2 -translate-x-1/2',\n }\n\n return (\n <div className={`fixed z-50 space-y-3 ${positionClasses[position]}`}>\n {messages.map((message) => (\n <LMMessage key={message.id} {...message} onClose={onClose} />\n ))}\n </div>\n )\n}\n\nexport default LMMessage\n","import { useState, useCallback } from 'react'\nimport type { LMMessageItem } from '../components/Feedback/LMMessage/LMMessage'\n\nexport interface UseMessageReturn {\n messages: LMMessageItem[]\n addMessage: (message: Omit<LMMessageItem, 'id'>) => string\n removeMessage: (id: string) => void\n success: (content: string, title?: string, duration?: number) => string\n error: (content: string, title?: string, duration?: number) => string\n warning: (content: string, title?: string, duration?: number) => string\n info: (content: string, title?: string, duration?: number) => string\n clearAll: () => void\n}\n\nlet messageIdCounter = 0\n\nexport const useMessage = (): UseMessageReturn => {\n const [messages, setMessages] = useState<LMMessageItem[]>([])\n\n const addMessage = useCallback((message: Omit<LMMessageItem, 'id'>) => {\n const id = `lm-message-${++messageIdCounter}`\n setMessages((prev) => [...prev, { ...message, id }])\n return id\n }, [])\n\n const removeMessage = useCallback((id: string) => {\n setMessages((prev) => prev.filter((m) => m.id !== id))\n }, [])\n\n const success = useCallback(\n (content: string, title?: string, duration?: number) => {\n return addMessage({ type: 'success', content, title, duration })\n },\n [addMessage]\n )\n\n const error = useCallback(\n (content: string, title?: string, duration?: number) => {\n return addMessage({ type: 'error', content, title, duration })\n },\n [addMessage]\n )\n\n const warning = useCallback(\n (content: string, title?: string, duration?: number) => {\n return addMessage({ type: 'warning', content, title, duration })\n },\n [addMessage]\n )\n\n const info = useCallback(\n (content: string, title?: string, duration?: number) => {\n return addMessage({ type: 'info', content, title, duration })\n },\n [addMessage]\n )\n\n const clearAll = useCallback(() => {\n setMessages([])\n }, [])\n\n return {\n messages,\n addMessage,\n removeMessage,\n success,\n error,\n warning,\n info,\n clearAll,\n }\n}\n"],"names":["jsx","useEffect","useMemo","jsxs","useState","useCallback"],"mappings":"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"}
|
|
@@ -0,0 +1,243 @@
|
|
|
1
|
+
import { jsxs, jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useMemo, useState, useCallback } from "react";
|
|
3
|
+
const ICONS = {
|
|
4
|
+
success: /* @__PURE__ */ jsxs("svg", { viewBox: "0 0 24 24", className: "h-5 w-5", "aria-hidden": "true", children: [
|
|
5
|
+
/* @__PURE__ */ jsx(
|
|
6
|
+
"path",
|
|
7
|
+
{
|
|
8
|
+
d: "M12 22a10 10 0 1 1 0-20 10 10 0 0 1 0 20Z",
|
|
9
|
+
fill: "currentColor",
|
|
10
|
+
opacity: "0.15"
|
|
11
|
+
}
|
|
12
|
+
),
|
|
13
|
+
/* @__PURE__ */ jsx(
|
|
14
|
+
"path",
|
|
15
|
+
{
|
|
16
|
+
d: "M16.7 9.3a1 1 0 0 0-1.4-1.4L11 12.2 8.7 9.9a1 1 0 1 0-1.4 1.4l3 3a1 1 0 0 0 1.4 0l5-5Z",
|
|
17
|
+
fill: "currentColor"
|
|
18
|
+
}
|
|
19
|
+
)
|
|
20
|
+
] }),
|
|
21
|
+
error: /* @__PURE__ */ jsxs("svg", { viewBox: "0 0 24 24", className: "h-5 w-5", "aria-hidden": "true", children: [
|
|
22
|
+
/* @__PURE__ */ jsx(
|
|
23
|
+
"path",
|
|
24
|
+
{
|
|
25
|
+
d: "M12 22c5.5 0 10-4.5 10-10S17.5 2 12 2 2 6.5 2 12s4.5 10 10 10Z",
|
|
26
|
+
fill: "currentColor",
|
|
27
|
+
opacity: "0.15"
|
|
28
|
+
}
|
|
29
|
+
),
|
|
30
|
+
/* @__PURE__ */ jsx(
|
|
31
|
+
"path",
|
|
32
|
+
{
|
|
33
|
+
d: "M15.5 8.5l-7 7M8.5 8.5l7 7",
|
|
34
|
+
stroke: "currentColor",
|
|
35
|
+
strokeWidth: "1.8",
|
|
36
|
+
strokeLinecap: "round"
|
|
37
|
+
}
|
|
38
|
+
)
|
|
39
|
+
] }),
|
|
40
|
+
warning: /* @__PURE__ */ jsxs("svg", { viewBox: "0 0 24 24", className: "h-5 w-5", "aria-hidden": "true", children: [
|
|
41
|
+
/* @__PURE__ */ jsx(
|
|
42
|
+
"path",
|
|
43
|
+
{
|
|
44
|
+
d: "M12.9 4.5c-.4-.7-1.4-.7-1.8 0L3.5 18a1 1 0 0 0 .9 1.5h15.2a1 1 0 0 0 .9-1.5l-7.6-13.5Z",
|
|
45
|
+
fill: "currentColor",
|
|
46
|
+
opacity: "0.15"
|
|
47
|
+
}
|
|
48
|
+
),
|
|
49
|
+
/* @__PURE__ */ jsx("path", { d: "M12 9v5", stroke: "currentColor", strokeWidth: "1.8", strokeLinecap: "round" }),
|
|
50
|
+
/* @__PURE__ */ jsx("circle", { cx: "12", cy: "16.5", r: "1", fill: "currentColor" })
|
|
51
|
+
] }),
|
|
52
|
+
info: /* @__PURE__ */ jsxs("svg", { viewBox: "0 0 24 24", className: "h-5 w-5", "aria-hidden": "true", children: [
|
|
53
|
+
/* @__PURE__ */ jsx(
|
|
54
|
+
"path",
|
|
55
|
+
{
|
|
56
|
+
d: "M12 22a10 10 0 1 0 0-20 10 10 0 0 0 0 20Z",
|
|
57
|
+
fill: "currentColor",
|
|
58
|
+
opacity: "0.15"
|
|
59
|
+
}
|
|
60
|
+
),
|
|
61
|
+
/* @__PURE__ */ jsx(
|
|
62
|
+
"path",
|
|
63
|
+
{
|
|
64
|
+
d: "M12 10.5v5M12 7.5h.01",
|
|
65
|
+
stroke: "currentColor",
|
|
66
|
+
strokeWidth: "1.8",
|
|
67
|
+
strokeLinecap: "round"
|
|
68
|
+
}
|
|
69
|
+
)
|
|
70
|
+
] })
|
|
71
|
+
};
|
|
72
|
+
const useTone = (type) => {
|
|
73
|
+
switch (type) {
|
|
74
|
+
case "success":
|
|
75
|
+
return {
|
|
76
|
+
accent: "var(--lm-success-500)",
|
|
77
|
+
background: "color-mix(in srgb, var(--lm-success-100) 60%, transparent)",
|
|
78
|
+
text: "var(--lm-success-700)",
|
|
79
|
+
title: "var(--lm-success-800)"
|
|
80
|
+
};
|
|
81
|
+
case "error":
|
|
82
|
+
return {
|
|
83
|
+
accent: "var(--lm-error-500)",
|
|
84
|
+
background: "color-mix(in srgb, var(--lm-error-100) 60%, transparent)",
|
|
85
|
+
text: "var(--lm-error-700)",
|
|
86
|
+
title: "var(--lm-error-800)"
|
|
87
|
+
};
|
|
88
|
+
case "warning":
|
|
89
|
+
return {
|
|
90
|
+
accent: "var(--lm-warning-500)",
|
|
91
|
+
background: "color-mix(in srgb, var(--lm-warning-100) 60%, transparent)",
|
|
92
|
+
text: "var(--lm-warning-700)",
|
|
93
|
+
title: "var(--lm-warning-800)"
|
|
94
|
+
};
|
|
95
|
+
case "info":
|
|
96
|
+
default:
|
|
97
|
+
return {
|
|
98
|
+
accent: "var(--lm-primary-500)",
|
|
99
|
+
background: "color-mix(in srgb, var(--lm-primary-100) 60%, transparent)",
|
|
100
|
+
text: "var(--lm-primary-700)",
|
|
101
|
+
title: "var(--lm-primary-800)"
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
const LMMessage = ({ id, type, title, content, duration = 2e3, onClose }) => {
|
|
106
|
+
const tone = useTone(type);
|
|
107
|
+
useEffect(() => {
|
|
108
|
+
if (duration <= 0) return;
|
|
109
|
+
const timer = setTimeout(() => onClose(id), duration);
|
|
110
|
+
return () => clearTimeout(timer);
|
|
111
|
+
}, [id, duration, onClose]);
|
|
112
|
+
const icon = useMemo(() => ICONS[type], [type]);
|
|
113
|
+
const ariaRole = "status";
|
|
114
|
+
const ariaLabel = useMemo(() => {
|
|
115
|
+
switch (type) {
|
|
116
|
+
case "success":
|
|
117
|
+
return "Success message";
|
|
118
|
+
case "error":
|
|
119
|
+
return "Error message";
|
|
120
|
+
case "warning":
|
|
121
|
+
return "Warning message";
|
|
122
|
+
default:
|
|
123
|
+
return "Information message";
|
|
124
|
+
}
|
|
125
|
+
}, [type]);
|
|
126
|
+
return /* @__PURE__ */ jsx("div", { className: "max-w-sm mx-auto will-change-transform", role: ariaRole, "aria-label": ariaLabel, children: /* @__PURE__ */ jsx(
|
|
127
|
+
"div",
|
|
128
|
+
{
|
|
129
|
+
className: "rounded-3xl shadow-lg p-5 mb-3 backdrop-blur-md border transition-all duration-300 ease-out",
|
|
130
|
+
style: {
|
|
131
|
+
backgroundColor: tone.background,
|
|
132
|
+
borderColor: "var(--lm-border-light)",
|
|
133
|
+
boxShadow: "var(--lm-shadow-lg)"
|
|
134
|
+
},
|
|
135
|
+
children: /* @__PURE__ */ jsxs("div", { className: "flex items-start gap-4", children: [
|
|
136
|
+
/* @__PURE__ */ jsx(
|
|
137
|
+
"div",
|
|
138
|
+
{
|
|
139
|
+
className: "mt-0.5 flex h-10 w-10 items-center justify-center rounded-2xl",
|
|
140
|
+
style: {
|
|
141
|
+
color: tone.accent,
|
|
142
|
+
backgroundColor: "color-mix(in srgb, currentColor 12%, transparent)"
|
|
143
|
+
},
|
|
144
|
+
children: icon
|
|
145
|
+
}
|
|
146
|
+
),
|
|
147
|
+
/* @__PURE__ */ jsxs("div", { className: "flex-1 min-w-0", children: [
|
|
148
|
+
title && /* @__PURE__ */ jsx("h4", { className: "text-sm font-semibold mb-2 truncate", style: { color: tone.title }, children: title }),
|
|
149
|
+
/* @__PURE__ */ jsx("p", { className: "text-sm leading-relaxed wrap-break-word", style: { color: tone.text }, children: content })
|
|
150
|
+
] }),
|
|
151
|
+
/* @__PURE__ */ jsx(
|
|
152
|
+
"button",
|
|
153
|
+
{
|
|
154
|
+
onClick: () => onClose(id),
|
|
155
|
+
"aria-label": "Close message",
|
|
156
|
+
className: "shrink-0 p-2 rounded-xl transition-all duration-200 hover:bg-black/5 active:bg-black/10",
|
|
157
|
+
style: { color: tone.accent },
|
|
158
|
+
children: /* @__PURE__ */ jsx("svg", { viewBox: "0 0 24 24", className: "h-4 w-4", "aria-hidden": "true", children: /* @__PURE__ */ jsx(
|
|
159
|
+
"path",
|
|
160
|
+
{
|
|
161
|
+
d: "M6 6l12 12M18 6L6 18",
|
|
162
|
+
stroke: "currentColor",
|
|
163
|
+
strokeWidth: "2",
|
|
164
|
+
strokeLinecap: "round"
|
|
165
|
+
}
|
|
166
|
+
) })
|
|
167
|
+
}
|
|
168
|
+
)
|
|
169
|
+
] })
|
|
170
|
+
}
|
|
171
|
+
) });
|
|
172
|
+
};
|
|
173
|
+
const LMMessageContainer = ({
|
|
174
|
+
messages,
|
|
175
|
+
onClose,
|
|
176
|
+
position = "top-right"
|
|
177
|
+
}) => {
|
|
178
|
+
if (messages.length === 0) return null;
|
|
179
|
+
const positionClasses = {
|
|
180
|
+
"top-right": "top-20 right-6",
|
|
181
|
+
"top-left": "top-20 left-6",
|
|
182
|
+
"top-center": "top-20 left-1/2 -translate-x-1/2",
|
|
183
|
+
"bottom-right": "bottom-6 right-6",
|
|
184
|
+
"bottom-left": "bottom-6 left-6",
|
|
185
|
+
"bottom-center": "bottom-6 left-1/2 -translate-x-1/2"
|
|
186
|
+
};
|
|
187
|
+
return /* @__PURE__ */ jsx("div", { className: `fixed z-50 space-y-3 ${positionClasses[position]}`, children: messages.map((message) => /* @__PURE__ */ jsx(LMMessage, { ...message, onClose }, message.id)) });
|
|
188
|
+
};
|
|
189
|
+
let messageIdCounter = 0;
|
|
190
|
+
const useMessage = () => {
|
|
191
|
+
const [messages, setMessages] = useState([]);
|
|
192
|
+
const addMessage = useCallback((message) => {
|
|
193
|
+
const id = `lm-message-${++messageIdCounter}`;
|
|
194
|
+
setMessages((prev) => [...prev, { ...message, id }]);
|
|
195
|
+
return id;
|
|
196
|
+
}, []);
|
|
197
|
+
const removeMessage = useCallback((id) => {
|
|
198
|
+
setMessages((prev) => prev.filter((m) => m.id !== id));
|
|
199
|
+
}, []);
|
|
200
|
+
const success = useCallback(
|
|
201
|
+
(content, title, duration) => {
|
|
202
|
+
return addMessage({ type: "success", content, title, duration });
|
|
203
|
+
},
|
|
204
|
+
[addMessage]
|
|
205
|
+
);
|
|
206
|
+
const error = useCallback(
|
|
207
|
+
(content, title, duration) => {
|
|
208
|
+
return addMessage({ type: "error", content, title, duration });
|
|
209
|
+
},
|
|
210
|
+
[addMessage]
|
|
211
|
+
);
|
|
212
|
+
const warning = useCallback(
|
|
213
|
+
(content, title, duration) => {
|
|
214
|
+
return addMessage({ type: "warning", content, title, duration });
|
|
215
|
+
},
|
|
216
|
+
[addMessage]
|
|
217
|
+
);
|
|
218
|
+
const info = useCallback(
|
|
219
|
+
(content, title, duration) => {
|
|
220
|
+
return addMessage({ type: "info", content, title, duration });
|
|
221
|
+
},
|
|
222
|
+
[addMessage]
|
|
223
|
+
);
|
|
224
|
+
const clearAll = useCallback(() => {
|
|
225
|
+
setMessages([]);
|
|
226
|
+
}, []);
|
|
227
|
+
return {
|
|
228
|
+
messages,
|
|
229
|
+
addMessage,
|
|
230
|
+
removeMessage,
|
|
231
|
+
success,
|
|
232
|
+
error,
|
|
233
|
+
warning,
|
|
234
|
+
info,
|
|
235
|
+
clearAll
|
|
236
|
+
};
|
|
237
|
+
};
|
|
238
|
+
export {
|
|
239
|
+
LMMessage as L,
|
|
240
|
+
LMMessageContainer as a,
|
|
241
|
+
useMessage as u
|
|
242
|
+
};
|
|
243
|
+
//# sourceMappingURL=useMessage-CRsCgzDR.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useMessage-CRsCgzDR.js","sources":["../src/components/Feedback/LMMessage/LMMessage.tsx","../src/hooks/useMessage.ts"],"sourcesContent":["import React, { useEffect, useMemo } from 'react'\n\nexport type LMMessageType = 'success' | 'error' | 'warning' | 'info'\n\nexport interface LMMessageItem {\n id: string\n type: LMMessageType\n title?: string\n content: string\n duration?: number\n}\n\nexport interface LMMessageProps {\n id: string\n type: LMMessageType\n title?: string\n content: string\n /** Auto close duration in ms, 0 means no auto close */\n duration?: number\n onClose: (id: string) => void\n}\n\ninterface Tone {\n accent: string\n background: string\n text: string\n title: string\n}\n\nconst ICONS: Record<LMMessageType, React.ReactNode> = {\n success: (\n <svg viewBox=\"0 0 24 24\" className=\"h-5 w-5\" aria-hidden=\"true\">\n <path\n d=\"M12 22a10 10 0 1 1 0-20 10 10 0 0 1 0 20Z\"\n fill=\"currentColor\"\n opacity=\"0.15\"\n />\n <path\n d=\"M16.7 9.3a1 1 0 0 0-1.4-1.4L11 12.2 8.7 9.9a1 1 0 1 0-1.4 1.4l3 3a1 1 0 0 0 1.4 0l5-5Z\"\n fill=\"currentColor\"\n />\n </svg>\n ),\n error: (\n <svg viewBox=\"0 0 24 24\" className=\"h-5 w-5\" aria-hidden=\"true\">\n <path\n d=\"M12 22c5.5 0 10-4.5 10-10S17.5 2 12 2 2 6.5 2 12s4.5 10 10 10Z\"\n fill=\"currentColor\"\n opacity=\"0.15\"\n />\n <path\n d=\"M15.5 8.5l-7 7M8.5 8.5l7 7\"\n stroke=\"currentColor\"\n strokeWidth=\"1.8\"\n strokeLinecap=\"round\"\n />\n </svg>\n ),\n warning: (\n <svg viewBox=\"0 0 24 24\" className=\"h-5 w-5\" aria-hidden=\"true\">\n <path\n d=\"M12.9 4.5c-.4-.7-1.4-.7-1.8 0L3.5 18a1 1 0 0 0 .9 1.5h15.2a1 1 0 0 0 .9-1.5l-7.6-13.5Z\"\n fill=\"currentColor\"\n opacity=\"0.15\"\n />\n <path d=\"M12 9v5\" stroke=\"currentColor\" strokeWidth=\"1.8\" strokeLinecap=\"round\" />\n <circle cx=\"12\" cy=\"16.5\" r=\"1\" fill=\"currentColor\" />\n </svg>\n ),\n info: (\n <svg viewBox=\"0 0 24 24\" className=\"h-5 w-5\" aria-hidden=\"true\">\n <path\n d=\"M12 22a10 10 0 1 0 0-20 10 10 0 0 0 0 20Z\"\n fill=\"currentColor\"\n opacity=\"0.15\"\n />\n <path\n d=\"M12 10.5v5M12 7.5h.01\"\n stroke=\"currentColor\"\n strokeWidth=\"1.8\"\n strokeLinecap=\"round\"\n />\n </svg>\n ),\n}\n\nconst useTone = (type: LMMessageType): Tone => {\n switch (type) {\n case 'success':\n return {\n accent: 'var(--lm-success-500)',\n background: 'color-mix(in srgb, var(--lm-success-100) 60%, transparent)',\n text: 'var(--lm-success-700)',\n title: 'var(--lm-success-800)',\n }\n case 'error':\n return {\n accent: 'var(--lm-error-500)',\n background: 'color-mix(in srgb, var(--lm-error-100) 60%, transparent)',\n text: 'var(--lm-error-700)',\n title: 'var(--lm-error-800)',\n }\n case 'warning':\n return {\n accent: 'var(--lm-warning-500)',\n background: 'color-mix(in srgb, var(--lm-warning-100) 60%, transparent)',\n text: 'var(--lm-warning-700)',\n title: 'var(--lm-warning-800)',\n }\n case 'info':\n default:\n return {\n accent: 'var(--lm-primary-500)',\n background: 'color-mix(in srgb, var(--lm-primary-100) 60%, transparent)',\n text: 'var(--lm-primary-700)',\n title: 'var(--lm-primary-800)',\n }\n }\n}\n\nconst LMMessage: React.FC<LMMessageProps> = ({ id, type, title, content, duration = 2000, onClose }) => {\n const tone = useTone(type)\n\n useEffect(() => {\n if (duration <= 0) return\n const timer = setTimeout(() => onClose(id), duration)\n return () => clearTimeout(timer)\n }, [id, duration, onClose])\n\n const icon = useMemo(() => ICONS[type], [type])\n const ariaRole = 'status'\n const ariaLabel = useMemo(() => {\n switch (type) {\n case 'success':\n return 'Success message'\n case 'error':\n return 'Error message'\n case 'warning':\n return 'Warning message'\n default:\n return 'Information message'\n }\n }, [type])\n\n return (\n <div className=\"max-w-sm mx-auto will-change-transform\" role={ariaRole} aria-label={ariaLabel}>\n <div\n className=\"rounded-3xl shadow-lg p-5 mb-3 backdrop-blur-md border transition-all duration-300 ease-out\"\n style={{\n backgroundColor: tone.background,\n borderColor: 'var(--lm-border-light)',\n boxShadow: 'var(--lm-shadow-lg)',\n }}\n >\n <div className=\"flex items-start gap-4\">\n <div\n className=\"mt-0.5 flex h-10 w-10 items-center justify-center rounded-2xl\"\n style={{\n color: tone.accent,\n backgroundColor: 'color-mix(in srgb, currentColor 12%, transparent)',\n }}\n >\n {icon}\n </div>\n\n <div className=\"flex-1 min-w-0\">\n {title && (\n <h4 className=\"text-sm font-semibold mb-2 truncate\" style={{ color: tone.title }}>\n {title}\n </h4>\n )}\n <p className=\"text-sm leading-relaxed wrap-break-word\" style={{ color: tone.text }}>\n {content}\n </p>\n </div>\n\n <button\n onClick={() => onClose(id)}\n aria-label=\"Close message\"\n className=\"shrink-0 p-2 rounded-xl transition-all duration-200 hover:bg-black/5 active:bg-black/10\"\n style={{ color: tone.accent }}\n >\n <svg viewBox=\"0 0 24 24\" className=\"h-4 w-4\" aria-hidden=\"true\">\n <path\n d=\"M6 6l12 12M18 6L6 18\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n )\n}\n\nexport interface LMMessageContainerProps {\n /** Messages list */\n messages: LMMessageItem[]\n /** Close callback */\n onClose: (id: string) => void\n /** Position */\n position?: 'top-right' | 'top-left' | 'top-center' | 'bottom-right' | 'bottom-left' | 'bottom-center'\n}\n\nexport const LMMessageContainer: React.FC<LMMessageContainerProps> = ({\n messages,\n onClose,\n position = 'top-right',\n}) => {\n if (messages.length === 0) return null\n\n const positionClasses = {\n 'top-right': 'top-20 right-6',\n 'top-left': 'top-20 left-6',\n 'top-center': 'top-20 left-1/2 -translate-x-1/2',\n 'bottom-right': 'bottom-6 right-6',\n 'bottom-left': 'bottom-6 left-6',\n 'bottom-center': 'bottom-6 left-1/2 -translate-x-1/2',\n }\n\n return (\n <div className={`fixed z-50 space-y-3 ${positionClasses[position]}`}>\n {messages.map((message) => (\n <LMMessage key={message.id} {...message} onClose={onClose} />\n ))}\n </div>\n )\n}\n\nexport default LMMessage\n","import { useState, useCallback } from 'react'\nimport type { LMMessageItem } from '../components/Feedback/LMMessage/LMMessage'\n\nexport interface UseMessageReturn {\n messages: LMMessageItem[]\n addMessage: (message: Omit<LMMessageItem, 'id'>) => string\n removeMessage: (id: string) => void\n success: (content: string, title?: string, duration?: number) => string\n error: (content: string, title?: string, duration?: number) => string\n warning: (content: string, title?: string, duration?: number) => string\n info: (content: string, title?: string, duration?: number) => string\n clearAll: () => void\n}\n\nlet messageIdCounter = 0\n\nexport const useMessage = (): UseMessageReturn => {\n const [messages, setMessages] = useState<LMMessageItem[]>([])\n\n const addMessage = useCallback((message: Omit<LMMessageItem, 'id'>) => {\n const id = `lm-message-${++messageIdCounter}`\n setMessages((prev) => [...prev, { ...message, id }])\n return id\n }, [])\n\n const removeMessage = useCallback((id: string) => {\n setMessages((prev) => prev.filter((m) => m.id !== id))\n }, [])\n\n const success = useCallback(\n (content: string, title?: string, duration?: number) => {\n return addMessage({ type: 'success', content, title, duration })\n },\n [addMessage]\n )\n\n const error = useCallback(\n (content: string, title?: string, duration?: number) => {\n return addMessage({ type: 'error', content, title, duration })\n },\n [addMessage]\n )\n\n const warning = useCallback(\n (content: string, title?: string, duration?: number) => {\n return addMessage({ type: 'warning', content, title, duration })\n },\n [addMessage]\n )\n\n const info = useCallback(\n (content: string, title?: string, duration?: number) => {\n return addMessage({ type: 'info', content, title, duration })\n },\n [addMessage]\n )\n\n const clearAll = useCallback(() => {\n setMessages([])\n }, [])\n\n return {\n messages,\n addMessage,\n removeMessage,\n success,\n error,\n warning,\n info,\n clearAll,\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Utility for merging class names
|
|
3
|
+
* Simple implementation without external dependencies
|
|
4
|
+
*/
|
|
5
|
+
type ClassValue = string | undefined | null | false | ClassValue[];
|
|
6
|
+
export declare function cn(...inputs: ClassValue[]): string;
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=cn.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cn.d.ts","sourceRoot":"","sources":["../../src/utils/cn.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,KAAK,UAAU,GAAG,MAAM,GAAG,SAAS,GAAG,IAAI,GAAG,KAAK,GAAG,UAAU,EAAE,CAAA;AAElE,wBAAgB,EAAE,CAAC,GAAG,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,CAKlD"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @file Component size utilities
|
|
3
|
+
* @description Shared size tokens for LumenUI components
|
|
4
|
+
*/
|
|
5
|
+
export type ComponentSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl';
|
|
6
|
+
/** Size order for iteration */
|
|
7
|
+
export declare const COMPONENT_SIZE_ORDER: ComponentSize[];
|
|
8
|
+
/** Text size classes with Apple-like line heights */
|
|
9
|
+
export declare const SIZE_TEXT_CLASSES: Record<ComponentSize, string>;
|
|
10
|
+
/** Heading size classes with tight tracking */
|
|
11
|
+
export declare const SIZE_HEADING_CLASSES: Record<ComponentSize, string>;
|
|
12
|
+
/** Display size classes with extra tight tracking */
|
|
13
|
+
export declare const SIZE_DISPLAY_CLASSES: Record<ComponentSize, string>;
|
|
14
|
+
/** Gap classes */
|
|
15
|
+
export declare const SIZE_GAP_CLASSES: Record<ComponentSize, string>;
|
|
16
|
+
/** Padding classes */
|
|
17
|
+
export declare const SIZE_PADDING_CLASSES: Record<ComponentSize, string>;
|
|
18
|
+
/** Button size config */
|
|
19
|
+
export declare const SIZE_BUTTON_CONFIG: Record<ComponentSize, {
|
|
20
|
+
padding: string;
|
|
21
|
+
height: string;
|
|
22
|
+
}>;
|
|
23
|
+
/** Input size config */
|
|
24
|
+
export declare const SIZE_INPUT_CONFIG: Record<ComponentSize, {
|
|
25
|
+
padding: string;
|
|
26
|
+
height: string;
|
|
27
|
+
fontSize: string;
|
|
28
|
+
}>;
|
|
29
|
+
/** Selector size config */
|
|
30
|
+
export declare const SIZE_SELECTOR_CONFIG: Record<ComponentSize, {
|
|
31
|
+
padding: string;
|
|
32
|
+
height: string;
|
|
33
|
+
fontSize: string;
|
|
34
|
+
}>;
|
|
35
|
+
/** Modal size config */
|
|
36
|
+
export declare const SIZE_MODAL_CONFIG: Record<ComponentSize, {
|
|
37
|
+
width: string;
|
|
38
|
+
maxWidth: string;
|
|
39
|
+
}>;
|
|
40
|
+
/** Tooltip size config */
|
|
41
|
+
export declare const SIZE_TOOLTIP_CONFIG: Record<ComponentSize, {
|
|
42
|
+
paddingClass: string;
|
|
43
|
+
textClass: string;
|
|
44
|
+
maxWidth: number;
|
|
45
|
+
}>;
|
|
46
|
+
/** Icon size config */
|
|
47
|
+
export declare const SIZE_ICON_CONFIG: Record<ComponentSize, string>;
|
|
48
|
+
/** Table size config */
|
|
49
|
+
export declare const SIZE_TABLE_CONFIG: Record<ComponentSize, {
|
|
50
|
+
cellPadding: string;
|
|
51
|
+
rowHeight: string;
|
|
52
|
+
}>;
|
|
53
|
+
/**
|
|
54
|
+
* Clamp size to allowed values
|
|
55
|
+
*/
|
|
56
|
+
export declare const clampComponentSize: (size: ComponentSize | undefined, allowedSizes: ComponentSize[], fallback?: ComponentSize) => ComponentSize;
|
|
57
|
+
//# sourceMappingURL=componentSizes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"componentSizes.d.ts","sourceRoot":"","sources":["../../src/utils/componentSizes.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,MAAM,aAAa,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,KAAK,CAAA;AAEpE,+BAA+B;AAC/B,eAAO,MAAM,oBAAoB,EAAE,aAAa,EAO/C,CAAA;AAED,qDAAqD;AACrD,eAAO,MAAM,iBAAiB,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAO3D,CAAA;AAED,+CAA+C;AAC/C,eAAO,MAAM,oBAAoB,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAO9D,CAAA;AAED,qDAAqD;AACrD,eAAO,MAAM,oBAAoB,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAO9D,CAAA;AAED,kBAAkB;AAClB,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAO1D,CAAA;AAED,sBAAsB;AACtB,eAAO,MAAM,oBAAoB,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAO9D,CAAA;AAED,yBAAyB;AACzB,eAAO,MAAM,kBAAkB,EAAE,MAAM,CACrC,aAAa,EACb;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAQpC,CAAA;AAED,wBAAwB;AACxB,eAAO,MAAM,iBAAiB,EAAE,MAAM,CACpC,aAAa,EACb;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAQtD,CAAA;AAED,2BAA2B;AAC3B,eAAO,MAAM,oBAAoB,EAAE,MAAM,CACvC,aAAa,EACb;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAQtD,CAAA;AAED,wBAAwB;AACxB,eAAO,MAAM,iBAAiB,EAAE,MAAM,CACpC,aAAa,EACb;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAQpC,CAAA;AAED,0BAA0B;AAC1B,eAAO,MAAM,mBAAmB,EAAE,MAAM,CACtC,aAAa,EACb;IAAE,YAAY,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAQ9D,CAAA;AAED,uBAAuB;AACvB,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAO1D,CAAA;AAED,wBAAwB;AACxB,eAAO,MAAM,iBAAiB,EAAE,MAAM,CACpC,aAAa,EACb;IAAE,WAAW,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,CAQ3C,CAAA;AAED;;GAEG;AACH,eAAO,MAAM,kBAAkB,GAC7B,MAAM,aAAa,GAAG,SAAS,EAC/B,cAAc,aAAa,EAAE,EAC7B,WAAU,aAAoB,KAC7B,aAGF,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA;AAChC,cAAc,MAAM,CAAA"}
|