@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.
Files changed (503) hide show
  1. package/LICENSE +21 -0
  2. package/dist/LMBadge-BBDOGTps.js +126 -0
  3. package/dist/LMBadge-BBDOGTps.js.map +1 -0
  4. package/dist/LMBadge-D95iccla.cjs +125 -0
  5. package/dist/LMBadge-D95iccla.cjs.map +1 -0
  6. package/dist/LMButton-B258yfky.cjs +333 -0
  7. package/dist/LMButton-B258yfky.cjs.map +1 -0
  8. package/dist/LMButton-S4xQSohi.js +334 -0
  9. package/dist/LMButton-S4xQSohi.js.map +1 -0
  10. package/dist/LMCard-D7ABNC95.js +207 -0
  11. package/dist/LMCard-D7ABNC95.js.map +1 -0
  12. package/dist/LMCard-D_K051f2.cjs +206 -0
  13. package/dist/LMCard-D_K051f2.cjs.map +1 -0
  14. package/dist/LMCheckbox-C2YvEQ8f.cjs +197 -0
  15. package/dist/LMCheckbox-C2YvEQ8f.cjs.map +1 -0
  16. package/dist/LMCheckbox-DaaJRjKt.js +198 -0
  17. package/dist/LMCheckbox-DaaJRjKt.js.map +1 -0
  18. package/dist/LMDatePicker-BlUwN4On.cjs +565 -0
  19. package/dist/LMDatePicker-BlUwN4On.cjs.map +1 -0
  20. package/dist/LMDatePicker-DSv28BFH.js +566 -0
  21. package/dist/LMDatePicker-DSv28BFH.js.map +1 -0
  22. package/dist/LMDrawer--lFV_a3m.cjs +207 -0
  23. package/dist/LMDrawer--lFV_a3m.cjs.map +1 -0
  24. package/dist/LMDrawer-DJ5ugeZR.js +208 -0
  25. package/dist/LMDrawer-DJ5ugeZR.js.map +1 -0
  26. package/dist/LMDropdown-wiTMuyhU.js +285 -0
  27. package/dist/LMDropdown-wiTMuyhU.js.map +1 -0
  28. package/dist/LMDropdown-yl5l7qtz.cjs +284 -0
  29. package/dist/LMDropdown-yl5l7qtz.cjs.map +1 -0
  30. package/dist/LMEmpty-BedQxpbi.cjs +188 -0
  31. package/dist/LMEmpty-BedQxpbi.cjs.map +1 -0
  32. package/dist/LMEmpty-DzHM1fOb.js +189 -0
  33. package/dist/LMEmpty-DzHM1fOb.js.map +1 -0
  34. package/dist/LMField-BS-DSEya.js +67 -0
  35. package/dist/LMField-BS-DSEya.js.map +1 -0
  36. package/dist/LMField-DhDHj64z.cjs +66 -0
  37. package/dist/LMField-DhDHj64z.cjs.map +1 -0
  38. package/dist/LMInput-CVjawj1F.cjs +140 -0
  39. package/dist/LMInput-CVjawj1F.cjs.map +1 -0
  40. package/dist/LMInput-D9csGyhj.js +141 -0
  41. package/dist/LMInput-D9csGyhj.js.map +1 -0
  42. package/dist/LMMenu-IDAgZFuC.cjs +234 -0
  43. package/dist/LMMenu-IDAgZFuC.cjs.map +1 -0
  44. package/dist/LMMenu-yXadjQLQ.js +235 -0
  45. package/dist/LMMenu-yXadjQLQ.js.map +1 -0
  46. package/dist/LMModal-BCVVPLot.cjs +203 -0
  47. package/dist/LMModal-BCVVPLot.cjs.map +1 -0
  48. package/dist/LMModal-DCJPlfA4.js +204 -0
  49. package/dist/LMModal-DCJPlfA4.js.map +1 -0
  50. package/dist/LMNumberInput-B1tU7T_W.cjs +294 -0
  51. package/dist/LMNumberInput-B1tU7T_W.cjs.map +1 -0
  52. package/dist/LMNumberInput-BI5_OEx4.js +295 -0
  53. package/dist/LMNumberInput-BI5_OEx4.js.map +1 -0
  54. package/dist/LMPagination-BypfLRlF.js +305 -0
  55. package/dist/LMPagination-BypfLRlF.js.map +1 -0
  56. package/dist/LMPagination-CouDFIwd.cjs +304 -0
  57. package/dist/LMPagination-CouDFIwd.cjs.map +1 -0
  58. package/dist/LMRadio-CHn6nFSy.cjs +189 -0
  59. package/dist/LMRadio-CHn6nFSy.cjs.map +1 -0
  60. package/dist/LMRadio-UQLNgTMF.js +190 -0
  61. package/dist/LMRadio-UQLNgTMF.js.map +1 -0
  62. package/dist/LMSearchInput-CIvVkEf2.js +205 -0
  63. package/dist/LMSearchInput-CIvVkEf2.js.map +1 -0
  64. package/dist/LMSearchInput-nBlAX734.cjs +204 -0
  65. package/dist/LMSearchInput-nBlAX734.cjs.map +1 -0
  66. package/dist/LMSelect-B-MWX2JI.js +309 -0
  67. package/dist/LMSelect-B-MWX2JI.js.map +1 -0
  68. package/dist/LMSelect-ByQcUp2S.cjs +308 -0
  69. package/dist/LMSelect-ByQcUp2S.cjs.map +1 -0
  70. package/dist/LMStatCard-D5HV9r6d.js +348 -0
  71. package/dist/LMStatCard-D5HV9r6d.js.map +1 -0
  72. package/dist/LMStatCard-MXs9Z0qH.cjs +347 -0
  73. package/dist/LMStatCard-MXs9Z0qH.cjs.map +1 -0
  74. package/dist/LMSwitch-CP1_nrfU.js +207 -0
  75. package/dist/LMSwitch-CP1_nrfU.js.map +1 -0
  76. package/dist/LMSwitch-DYoSH6wE.cjs +206 -0
  77. package/dist/LMSwitch-DYoSH6wE.cjs.map +1 -0
  78. package/dist/LMTable-Cp8HZqiV.js +594 -0
  79. package/dist/LMTable-Cp8HZqiV.js.map +1 -0
  80. package/dist/LMTable-j1ZzAzXB.cjs +593 -0
  81. package/dist/LMTable-j1ZzAzXB.cjs.map +1 -0
  82. package/dist/LMTabs-D5n9lB8X.js +210 -0
  83. package/dist/LMTabs-D5n9lB8X.js.map +1 -0
  84. package/dist/LMTabs-NPmOzPat.cjs +209 -0
  85. package/dist/LMTabs-NPmOzPat.cjs.map +1 -0
  86. package/dist/LMTextarea-5dVVPeL2.js +136 -0
  87. package/dist/LMTextarea-5dVVPeL2.js.map +1 -0
  88. package/dist/LMTextarea-yG0OBZjA.cjs +135 -0
  89. package/dist/LMTextarea-yG0OBZjA.cjs.map +1 -0
  90. package/dist/LMTooltip-30_lOAnH.cjs +85 -0
  91. package/dist/LMTooltip-30_lOAnH.cjs.map +1 -0
  92. package/dist/LMTooltip-h47oYhl8.js +86 -0
  93. package/dist/LMTooltip-h47oYhl8.js.map +1 -0
  94. package/dist/LMUpload-BwXoxIfE.js +380 -0
  95. package/dist/LMUpload-BwXoxIfE.js.map +1 -0
  96. package/dist/LMUpload-CJopkWc6.cjs +379 -0
  97. package/dist/LMUpload-CJopkWc6.cjs.map +1 -0
  98. package/dist/componentSizes-CdWNL526.js +125 -0
  99. package/dist/componentSizes-CdWNL526.js.map +1 -0
  100. package/dist/componentSizes-DUTZ7uEM.cjs +124 -0
  101. package/dist/componentSizes-DUTZ7uEM.cjs.map +1 -0
  102. package/dist/components/Chat/LMChatBubble/LMChatBubble.d.ts +28 -0
  103. package/dist/components/Chat/LMChatBubble/LMChatBubble.d.ts.map +1 -0
  104. package/dist/components/Chat/LMChatBubble/LMChatBubble.stories.d.ts +25 -0
  105. package/dist/components/Chat/LMChatBubble/LMChatBubble.stories.d.ts.map +1 -0
  106. package/dist/components/Chat/LMChatBubble/index.d.ts +3 -0
  107. package/dist/components/Chat/LMChatBubble/index.d.ts.map +1 -0
  108. package/dist/components/Chat/LMChatContainer/LMChatContainer.d.ts +85 -0
  109. package/dist/components/Chat/LMChatContainer/LMChatContainer.d.ts.map +1 -0
  110. package/dist/components/Chat/LMChatContainer/LMChatContainer.stories.d.ts +23 -0
  111. package/dist/components/Chat/LMChatContainer/LMChatContainer.stories.d.ts.map +1 -0
  112. package/dist/components/Chat/LMChatContainer/index.d.ts +3 -0
  113. package/dist/components/Chat/LMChatContainer/index.d.ts.map +1 -0
  114. package/dist/components/Chat/LMChatInput/LMChatInput.d.ts +55 -0
  115. package/dist/components/Chat/LMChatInput/LMChatInput.d.ts.map +1 -0
  116. package/dist/components/Chat/LMChatInput/LMChatInput.stories.d.ts +27 -0
  117. package/dist/components/Chat/LMChatInput/LMChatInput.stories.d.ts.map +1 -0
  118. package/dist/components/Chat/LMChatInput/index.d.ts +3 -0
  119. package/dist/components/Chat/LMChatInput/index.d.ts.map +1 -0
  120. package/dist/components/Chat/LMChatList/LMChatList.d.ts +60 -0
  121. package/dist/components/Chat/LMChatList/LMChatList.d.ts.map +1 -0
  122. package/dist/components/Chat/LMChatList/LMChatList.stories.d.ts +21 -0
  123. package/dist/components/Chat/LMChatList/LMChatList.stories.d.ts.map +1 -0
  124. package/dist/components/Chat/LMChatList/index.d.ts +3 -0
  125. package/dist/components/Chat/LMChatList/index.d.ts.map +1 -0
  126. package/dist/components/Chat/LMChatMessage/LMChatMessage.d.ts +56 -0
  127. package/dist/components/Chat/LMChatMessage/LMChatMessage.d.ts.map +1 -0
  128. package/dist/components/Chat/LMChatMessage/LMChatMessage.stories.d.ts +27 -0
  129. package/dist/components/Chat/LMChatMessage/LMChatMessage.stories.d.ts.map +1 -0
  130. package/dist/components/Chat/LMChatMessage/index.d.ts +3 -0
  131. package/dist/components/Chat/LMChatMessage/index.d.ts.map +1 -0
  132. package/dist/components/Chat/LMCodeBlock/LMCodeBlock.d.ts +32 -0
  133. package/dist/components/Chat/LMCodeBlock/LMCodeBlock.d.ts.map +1 -0
  134. package/dist/components/Chat/LMCodeBlock/LMCodeBlock.stories.d.ts +27 -0
  135. package/dist/components/Chat/LMCodeBlock/LMCodeBlock.stories.d.ts.map +1 -0
  136. package/dist/components/Chat/LMCodeBlock/index.d.ts +3 -0
  137. package/dist/components/Chat/LMCodeBlock/index.d.ts.map +1 -0
  138. package/dist/components/Chat/LMMarkdownRenderer/LMMarkdownRenderer.d.ts +24 -0
  139. package/dist/components/Chat/LMMarkdownRenderer/LMMarkdownRenderer.d.ts.map +1 -0
  140. package/dist/components/Chat/LMMarkdownRenderer/LMMarkdownRenderer.stories.d.ts +23 -0
  141. package/dist/components/Chat/LMMarkdownRenderer/LMMarkdownRenderer.stories.d.ts.map +1 -0
  142. package/dist/components/Chat/LMMarkdownRenderer/index.d.ts +3 -0
  143. package/dist/components/Chat/LMMarkdownRenderer/index.d.ts.map +1 -0
  144. package/dist/components/Chat/LMTypingIndicator/LMTypingIndicator.d.ts +21 -0
  145. package/dist/components/Chat/LMTypingIndicator/LMTypingIndicator.d.ts.map +1 -0
  146. package/dist/components/Chat/LMTypingIndicator/LMTypingIndicator.stories.d.ts +25 -0
  147. package/dist/components/Chat/LMTypingIndicator/LMTypingIndicator.stories.d.ts.map +1 -0
  148. package/dist/components/Chat/LMTypingIndicator/index.d.ts +3 -0
  149. package/dist/components/Chat/LMTypingIndicator/index.d.ts.map +1 -0
  150. package/dist/components/Chat/index.d.ts +9 -0
  151. package/dist/components/Chat/index.d.ts.map +1 -0
  152. package/dist/components/DataDisplay/LMCard/LMCard.d.ts +30 -0
  153. package/dist/components/DataDisplay/LMCard/LMCard.d.ts.map +1 -0
  154. package/dist/components/DataDisplay/LMCard/LMCard.stories.d.ts +33 -0
  155. package/dist/components/DataDisplay/LMCard/LMCard.stories.d.ts.map +1 -0
  156. package/dist/components/DataDisplay/LMCard/LMCard.test.d.ts +2 -0
  157. package/dist/components/DataDisplay/LMCard/LMCard.test.d.ts.map +1 -0
  158. package/dist/components/DataDisplay/LMCard/index.d.ts +3 -0
  159. package/dist/components/DataDisplay/LMCard/index.d.ts.map +1 -0
  160. package/dist/components/DataDisplay/LMEmpty/LMEmpty.d.ts +18 -0
  161. package/dist/components/DataDisplay/LMEmpty/LMEmpty.d.ts.map +1 -0
  162. package/dist/components/DataDisplay/LMEmpty/LMEmpty.stories.d.ts +31 -0
  163. package/dist/components/DataDisplay/LMEmpty/LMEmpty.stories.d.ts.map +1 -0
  164. package/dist/components/DataDisplay/LMEmpty/LMEmpty.test.d.ts +2 -0
  165. package/dist/components/DataDisplay/LMEmpty/LMEmpty.test.d.ts.map +1 -0
  166. package/dist/components/DataDisplay/LMEmpty/index.d.ts +3 -0
  167. package/dist/components/DataDisplay/LMEmpty/index.d.ts.map +1 -0
  168. package/dist/components/DataDisplay/LMStatCard/LMStatCard.d.ts +40 -0
  169. package/dist/components/DataDisplay/LMStatCard/LMStatCard.d.ts.map +1 -0
  170. package/dist/components/DataDisplay/LMStatCard/LMStatCard.stories.d.ts +35 -0
  171. package/dist/components/DataDisplay/LMStatCard/LMStatCard.stories.d.ts.map +1 -0
  172. package/dist/components/DataDisplay/LMStatCard/LMStatCard.test.d.ts +2 -0
  173. package/dist/components/DataDisplay/LMStatCard/LMStatCard.test.d.ts.map +1 -0
  174. package/dist/components/DataDisplay/LMStatCard/index.d.ts +3 -0
  175. package/dist/components/DataDisplay/LMStatCard/index.d.ts.map +1 -0
  176. package/dist/components/DataDisplay/LMTable/LMTable.d.ts +93 -0
  177. package/dist/components/DataDisplay/LMTable/LMTable.d.ts.map +1 -0
  178. package/dist/components/DataDisplay/LMTable/LMTable.stories.d.ts +35 -0
  179. package/dist/components/DataDisplay/LMTable/LMTable.stories.d.ts.map +1 -0
  180. package/dist/components/DataDisplay/LMTable/LMTable.test.d.ts +2 -0
  181. package/dist/components/DataDisplay/LMTable/LMTable.test.d.ts.map +1 -0
  182. package/dist/components/DataDisplay/LMTable/index.d.ts +3 -0
  183. package/dist/components/DataDisplay/LMTable/index.d.ts.map +1 -0
  184. package/dist/components/DataDisplay/LMTabs/LMTabs.d.ts +40 -0
  185. package/dist/components/DataDisplay/LMTabs/LMTabs.d.ts.map +1 -0
  186. package/dist/components/DataDisplay/LMTabs/LMTabs.stories.d.ts +35 -0
  187. package/dist/components/DataDisplay/LMTabs/LMTabs.stories.d.ts.map +1 -0
  188. package/dist/components/DataDisplay/LMTabs/LMTabs.test.d.ts +2 -0
  189. package/dist/components/DataDisplay/LMTabs/LMTabs.test.d.ts.map +1 -0
  190. package/dist/components/DataDisplay/LMTabs/index.d.ts +3 -0
  191. package/dist/components/DataDisplay/LMTabs/index.d.ts.map +1 -0
  192. package/dist/components/DataDisplay/LMTooltip/LMTooltip.d.ts +18 -0
  193. package/dist/components/DataDisplay/LMTooltip/LMTooltip.d.ts.map +1 -0
  194. package/dist/components/DataDisplay/LMTooltip/LMTooltip.stories.d.ts +27 -0
  195. package/dist/components/DataDisplay/LMTooltip/LMTooltip.stories.d.ts.map +1 -0
  196. package/dist/components/DataDisplay/LMTooltip/LMTooltip.test.d.ts +2 -0
  197. package/dist/components/DataDisplay/LMTooltip/LMTooltip.test.d.ts.map +1 -0
  198. package/dist/components/DataDisplay/LMTooltip/index.d.ts +3 -0
  199. package/dist/components/DataDisplay/LMTooltip/index.d.ts.map +1 -0
  200. package/dist/components/DataDisplay/index.d.ts +7 -0
  201. package/dist/components/DataDisplay/index.d.ts.map +1 -0
  202. package/dist/components/Feedback/LMConfirm/LMConfirm.d.ts +25 -0
  203. package/dist/components/Feedback/LMConfirm/LMConfirm.d.ts.map +1 -0
  204. package/dist/components/Feedback/LMConfirm/LMConfirm.stories.d.ts +19 -0
  205. package/dist/components/Feedback/LMConfirm/LMConfirm.stories.d.ts.map +1 -0
  206. package/dist/components/Feedback/LMConfirm/LMConfirm.test.d.ts +2 -0
  207. package/dist/components/Feedback/LMConfirm/LMConfirm.test.d.ts.map +1 -0
  208. package/dist/components/Feedback/LMConfirm/index.d.ts +5 -0
  209. package/dist/components/Feedback/LMConfirm/index.d.ts.map +1 -0
  210. package/dist/components/Feedback/LMDrawer/LMDrawer.d.ts +38 -0
  211. package/dist/components/Feedback/LMDrawer/LMDrawer.d.ts.map +1 -0
  212. package/dist/components/Feedback/LMDrawer/LMDrawer.stories.d.ts +33 -0
  213. package/dist/components/Feedback/LMDrawer/LMDrawer.stories.d.ts.map +1 -0
  214. package/dist/components/Feedback/LMDrawer/LMDrawer.test.d.ts +2 -0
  215. package/dist/components/Feedback/LMDrawer/LMDrawer.test.d.ts.map +1 -0
  216. package/dist/components/Feedback/LMDrawer/index.d.ts +3 -0
  217. package/dist/components/Feedback/LMDrawer/index.d.ts.map +1 -0
  218. package/dist/components/Feedback/LMMessage/LMMessage.d.ts +31 -0
  219. package/dist/components/Feedback/LMMessage/LMMessage.d.ts.map +1 -0
  220. package/dist/components/Feedback/LMMessage/LMMessage.stories.d.ts +25 -0
  221. package/dist/components/Feedback/LMMessage/LMMessage.stories.d.ts.map +1 -0
  222. package/dist/components/Feedback/LMMessage/LMMessage.test.d.ts +2 -0
  223. package/dist/components/Feedback/LMMessage/LMMessage.test.d.ts.map +1 -0
  224. package/dist/components/Feedback/LMMessage/index.d.ts +5 -0
  225. package/dist/components/Feedback/LMMessage/index.d.ts.map +1 -0
  226. package/dist/components/Feedback/LMModal/LMModal.d.ts +62 -0
  227. package/dist/components/Feedback/LMModal/LMModal.d.ts.map +1 -0
  228. package/dist/components/Feedback/LMModal/LMModal.stories.d.ts +23 -0
  229. package/dist/components/Feedback/LMModal/LMModal.stories.d.ts.map +1 -0
  230. package/dist/components/Feedback/LMModal/LMModal.test.d.ts +2 -0
  231. package/dist/components/Feedback/LMModal/LMModal.test.d.ts.map +1 -0
  232. package/dist/components/Feedback/LMModal/index.d.ts +3 -0
  233. package/dist/components/Feedback/LMModal/index.d.ts.map +1 -0
  234. package/dist/components/Feedback/index.d.ts +5 -0
  235. package/dist/components/Feedback/index.d.ts.map +1 -0
  236. package/dist/components/Form/LMCheckbox/LMCheckbox.d.ts +18 -0
  237. package/dist/components/Form/LMCheckbox/LMCheckbox.d.ts.map +1 -0
  238. package/dist/components/Form/LMCheckbox/LMCheckbox.stories.d.ts +23 -0
  239. package/dist/components/Form/LMCheckbox/LMCheckbox.stories.d.ts.map +1 -0
  240. package/dist/components/Form/LMCheckbox/LMCheckbox.test.d.ts +2 -0
  241. package/dist/components/Form/LMCheckbox/LMCheckbox.test.d.ts.map +1 -0
  242. package/dist/components/Form/LMCheckbox/index.d.ts +3 -0
  243. package/dist/components/Form/LMCheckbox/index.d.ts.map +1 -0
  244. package/dist/components/Form/LMDatePicker/LMDatePicker.d.ts +52 -0
  245. package/dist/components/Form/LMDatePicker/LMDatePicker.d.ts.map +1 -0
  246. package/dist/components/Form/LMDatePicker/LMDatePicker.stories.d.ts +41 -0
  247. package/dist/components/Form/LMDatePicker/LMDatePicker.stories.d.ts.map +1 -0
  248. package/dist/components/Form/LMDatePicker/LMDatePicker.test.d.ts +2 -0
  249. package/dist/components/Form/LMDatePicker/LMDatePicker.test.d.ts.map +1 -0
  250. package/dist/components/Form/LMDatePicker/index.d.ts +3 -0
  251. package/dist/components/Form/LMDatePicker/index.d.ts.map +1 -0
  252. package/dist/components/Form/LMField/LMField.d.ts +19 -0
  253. package/dist/components/Form/LMField/LMField.d.ts.map +1 -0
  254. package/dist/components/Form/LMField/LMField.stories.d.ts +23 -0
  255. package/dist/components/Form/LMField/LMField.stories.d.ts.map +1 -0
  256. package/dist/components/Form/LMField/LMField.test.d.ts +2 -0
  257. package/dist/components/Form/LMField/LMField.test.d.ts.map +1 -0
  258. package/dist/components/Form/LMField/index.d.ts +3 -0
  259. package/dist/components/Form/LMField/index.d.ts.map +1 -0
  260. package/dist/components/Form/LMInput/LMInput.d.ts +20 -0
  261. package/dist/components/Form/LMInput/LMInput.d.ts.map +1 -0
  262. package/dist/components/Form/LMInput/LMInput.stories.d.ts +29 -0
  263. package/dist/components/Form/LMInput/LMInput.stories.d.ts.map +1 -0
  264. package/dist/components/Form/LMInput/LMInput.test.d.ts +2 -0
  265. package/dist/components/Form/LMInput/LMInput.test.d.ts.map +1 -0
  266. package/dist/components/Form/LMInput/index.d.ts +3 -0
  267. package/dist/components/Form/LMInput/index.d.ts.map +1 -0
  268. package/dist/components/Form/LMNumberInput/LMNumberInput.d.ts +40 -0
  269. package/dist/components/Form/LMNumberInput/LMNumberInput.d.ts.map +1 -0
  270. package/dist/components/Form/LMNumberInput/LMNumberInput.stories.d.ts +33 -0
  271. package/dist/components/Form/LMNumberInput/LMNumberInput.stories.d.ts.map +1 -0
  272. package/dist/components/Form/LMNumberInput/LMNumberInput.test.d.ts +2 -0
  273. package/dist/components/Form/LMNumberInput/LMNumberInput.test.d.ts.map +1 -0
  274. package/dist/components/Form/LMNumberInput/index.d.ts +3 -0
  275. package/dist/components/Form/LMNumberInput/index.d.ts.map +1 -0
  276. package/dist/components/Form/LMRadio/LMRadio.d.ts +18 -0
  277. package/dist/components/Form/LMRadio/LMRadio.d.ts.map +1 -0
  278. package/dist/components/Form/LMRadio/LMRadio.stories.d.ts +25 -0
  279. package/dist/components/Form/LMRadio/LMRadio.stories.d.ts.map +1 -0
  280. package/dist/components/Form/LMRadio/LMRadio.test.d.ts +2 -0
  281. package/dist/components/Form/LMRadio/LMRadio.test.d.ts.map +1 -0
  282. package/dist/components/Form/LMRadio/index.d.ts +3 -0
  283. package/dist/components/Form/LMRadio/index.d.ts.map +1 -0
  284. package/dist/components/Form/LMSearchInput/LMSearchInput.d.ts +36 -0
  285. package/dist/components/Form/LMSearchInput/LMSearchInput.d.ts.map +1 -0
  286. package/dist/components/Form/LMSearchInput/LMSearchInput.stories.d.ts +27 -0
  287. package/dist/components/Form/LMSearchInput/LMSearchInput.stories.d.ts.map +1 -0
  288. package/dist/components/Form/LMSearchInput/LMSearchInput.test.d.ts +2 -0
  289. package/dist/components/Form/LMSearchInput/LMSearchInput.test.d.ts.map +1 -0
  290. package/dist/components/Form/LMSearchInput/index.d.ts +3 -0
  291. package/dist/components/Form/LMSearchInput/index.d.ts.map +1 -0
  292. package/dist/components/Form/LMSelect/LMSelect.d.ts +37 -0
  293. package/dist/components/Form/LMSelect/LMSelect.d.ts.map +1 -0
  294. package/dist/components/Form/LMSelect/LMSelect.stories.d.ts +27 -0
  295. package/dist/components/Form/LMSelect/LMSelect.stories.d.ts.map +1 -0
  296. package/dist/components/Form/LMSelect/LMSelect.test.d.ts +2 -0
  297. package/dist/components/Form/LMSelect/LMSelect.test.d.ts.map +1 -0
  298. package/dist/components/Form/LMSelect/index.d.ts +3 -0
  299. package/dist/components/Form/LMSelect/index.d.ts.map +1 -0
  300. package/dist/components/Form/LMSwitch/LMSwitch.d.ts +18 -0
  301. package/dist/components/Form/LMSwitch/LMSwitch.d.ts.map +1 -0
  302. package/dist/components/Form/LMSwitch/LMSwitch.stories.d.ts +25 -0
  303. package/dist/components/Form/LMSwitch/LMSwitch.stories.d.ts.map +1 -0
  304. package/dist/components/Form/LMSwitch/LMSwitch.test.d.ts +2 -0
  305. package/dist/components/Form/LMSwitch/LMSwitch.test.d.ts.map +1 -0
  306. package/dist/components/Form/LMSwitch/index.d.ts +3 -0
  307. package/dist/components/Form/LMSwitch/index.d.ts.map +1 -0
  308. package/dist/components/Form/LMTextarea/LMTextarea.d.ts +14 -0
  309. package/dist/components/Form/LMTextarea/LMTextarea.d.ts.map +1 -0
  310. package/dist/components/Form/LMTextarea/LMTextarea.stories.d.ts +23 -0
  311. package/dist/components/Form/LMTextarea/LMTextarea.stories.d.ts.map +1 -0
  312. package/dist/components/Form/LMTextarea/LMTextarea.test.d.ts +2 -0
  313. package/dist/components/Form/LMTextarea/LMTextarea.test.d.ts.map +1 -0
  314. package/dist/components/Form/LMTextarea/index.d.ts +3 -0
  315. package/dist/components/Form/LMTextarea/index.d.ts.map +1 -0
  316. package/dist/components/Form/LMUpload/LMUpload.d.ts +68 -0
  317. package/dist/components/Form/LMUpload/LMUpload.d.ts.map +1 -0
  318. package/dist/components/Form/LMUpload/LMUpload.stories.d.ts +41 -0
  319. package/dist/components/Form/LMUpload/LMUpload.stories.d.ts.map +1 -0
  320. package/dist/components/Form/LMUpload/LMUpload.test.d.ts +2 -0
  321. package/dist/components/Form/LMUpload/LMUpload.test.d.ts.map +1 -0
  322. package/dist/components/Form/LMUpload/index.d.ts +3 -0
  323. package/dist/components/Form/LMUpload/index.d.ts.map +1 -0
  324. package/dist/components/Form/index.d.ts +12 -0
  325. package/dist/components/Form/index.d.ts.map +1 -0
  326. package/dist/components/General/LMBadge/LMBadge.d.ts +21 -0
  327. package/dist/components/General/LMBadge/LMBadge.d.ts.map +1 -0
  328. package/dist/components/General/LMBadge/LMBadge.stories.d.ts +31 -0
  329. package/dist/components/General/LMBadge/LMBadge.stories.d.ts.map +1 -0
  330. package/dist/components/General/LMBadge/LMBadge.test.d.ts +2 -0
  331. package/dist/components/General/LMBadge/LMBadge.test.d.ts.map +1 -0
  332. package/dist/components/General/LMBadge/index.d.ts +3 -0
  333. package/dist/components/General/LMBadge/index.d.ts.map +1 -0
  334. package/dist/components/General/LMButton/LMButton.d.ts +25 -0
  335. package/dist/components/General/LMButton/LMButton.d.ts.map +1 -0
  336. package/dist/components/General/LMButton/LMButton.stories.d.ts +39 -0
  337. package/dist/components/General/LMButton/LMButton.stories.d.ts.map +1 -0
  338. package/dist/components/General/LMButton/LMButton.test.d.ts +2 -0
  339. package/dist/components/General/LMButton/LMButton.test.d.ts.map +1 -0
  340. package/dist/components/General/LMButton/index.d.ts +3 -0
  341. package/dist/components/General/LMButton/index.d.ts.map +1 -0
  342. package/dist/components/General/index.d.ts +3 -0
  343. package/dist/components/General/index.d.ts.map +1 -0
  344. package/dist/components/Navigation/LMDropdown/LMDropdown.d.ts +40 -0
  345. package/dist/components/Navigation/LMDropdown/LMDropdown.d.ts.map +1 -0
  346. package/dist/components/Navigation/LMDropdown/LMDropdown.stories.d.ts +31 -0
  347. package/dist/components/Navigation/LMDropdown/LMDropdown.stories.d.ts.map +1 -0
  348. package/dist/components/Navigation/LMDropdown/LMDropdown.test.d.ts +2 -0
  349. package/dist/components/Navigation/LMDropdown/LMDropdown.test.d.ts.map +1 -0
  350. package/dist/components/Navigation/LMDropdown/index.d.ts +3 -0
  351. package/dist/components/Navigation/LMDropdown/index.d.ts.map +1 -0
  352. package/dist/components/Navigation/LMMenu/LMMenu.d.ts +48 -0
  353. package/dist/components/Navigation/LMMenu/LMMenu.d.ts.map +1 -0
  354. package/dist/components/Navigation/LMMenu/LMMenu.stories.d.ts +25 -0
  355. package/dist/components/Navigation/LMMenu/LMMenu.stories.d.ts.map +1 -0
  356. package/dist/components/Navigation/LMMenu/LMMenu.test.d.ts +2 -0
  357. package/dist/components/Navigation/LMMenu/LMMenu.test.d.ts.map +1 -0
  358. package/dist/components/Navigation/LMMenu/index.d.ts +3 -0
  359. package/dist/components/Navigation/LMMenu/index.d.ts.map +1 -0
  360. package/dist/components/Navigation/LMPagination/LMPagination.d.ts +32 -0
  361. package/dist/components/Navigation/LMPagination/LMPagination.d.ts.map +1 -0
  362. package/dist/components/Navigation/LMPagination/LMPagination.stories.d.ts +35 -0
  363. package/dist/components/Navigation/LMPagination/LMPagination.stories.d.ts.map +1 -0
  364. package/dist/components/Navigation/LMPagination/LMPagination.test.d.ts +2 -0
  365. package/dist/components/Navigation/LMPagination/LMPagination.test.d.ts.map +1 -0
  366. package/dist/components/Navigation/LMPagination/index.d.ts +3 -0
  367. package/dist/components/Navigation/LMPagination/index.d.ts.map +1 -0
  368. package/dist/components/Navigation/index.d.ts +4 -0
  369. package/dist/components/Navigation/index.d.ts.map +1 -0
  370. package/dist/components/badge/index.cjs +5 -0
  371. package/dist/components/badge/index.cjs.map +1 -0
  372. package/dist/components/badge/index.js +5 -0
  373. package/dist/components/badge/index.js.map +1 -0
  374. package/dist/components/button/index.cjs +5 -0
  375. package/dist/components/button/index.cjs.map +1 -0
  376. package/dist/components/button/index.js +5 -0
  377. package/dist/components/button/index.js.map +1 -0
  378. package/dist/components/card/index.cjs +5 -0
  379. package/dist/components/card/index.cjs.map +1 -0
  380. package/dist/components/card/index.js +5 -0
  381. package/dist/components/card/index.js.map +1 -0
  382. package/dist/components/checkbox/index.cjs +5 -0
  383. package/dist/components/checkbox/index.cjs.map +1 -0
  384. package/dist/components/checkbox/index.js +5 -0
  385. package/dist/components/checkbox/index.js.map +1 -0
  386. package/dist/components/confirm/index.cjs +6 -0
  387. package/dist/components/confirm/index.cjs.map +1 -0
  388. package/dist/components/confirm/index.js +6 -0
  389. package/dist/components/confirm/index.js.map +1 -0
  390. package/dist/components/date-picker/index.cjs +5 -0
  391. package/dist/components/date-picker/index.cjs.map +1 -0
  392. package/dist/components/date-picker/index.js +5 -0
  393. package/dist/components/date-picker/index.js.map +1 -0
  394. package/dist/components/drawer/index.cjs +5 -0
  395. package/dist/components/drawer/index.cjs.map +1 -0
  396. package/dist/components/drawer/index.js +5 -0
  397. package/dist/components/drawer/index.js.map +1 -0
  398. package/dist/components/dropdown/index.cjs +5 -0
  399. package/dist/components/dropdown/index.cjs.map +1 -0
  400. package/dist/components/dropdown/index.js +5 -0
  401. package/dist/components/dropdown/index.js.map +1 -0
  402. package/dist/components/empty/index.cjs +5 -0
  403. package/dist/components/empty/index.cjs.map +1 -0
  404. package/dist/components/empty/index.js +5 -0
  405. package/dist/components/empty/index.js.map +1 -0
  406. package/dist/components/field/index.cjs +5 -0
  407. package/dist/components/field/index.cjs.map +1 -0
  408. package/dist/components/field/index.js +5 -0
  409. package/dist/components/field/index.js.map +1 -0
  410. package/dist/components/input/index.cjs +5 -0
  411. package/dist/components/input/index.cjs.map +1 -0
  412. package/dist/components/input/index.js +5 -0
  413. package/dist/components/input/index.js.map +1 -0
  414. package/dist/components/menu/index.cjs +5 -0
  415. package/dist/components/menu/index.cjs.map +1 -0
  416. package/dist/components/menu/index.js +5 -0
  417. package/dist/components/menu/index.js.map +1 -0
  418. package/dist/components/message/index.cjs +7 -0
  419. package/dist/components/message/index.cjs.map +1 -0
  420. package/dist/components/message/index.js +7 -0
  421. package/dist/components/message/index.js.map +1 -0
  422. package/dist/components/modal/index.cjs +5 -0
  423. package/dist/components/modal/index.cjs.map +1 -0
  424. package/dist/components/modal/index.js +5 -0
  425. package/dist/components/modal/index.js.map +1 -0
  426. package/dist/components/number-input/index.cjs +5 -0
  427. package/dist/components/number-input/index.cjs.map +1 -0
  428. package/dist/components/number-input/index.js +5 -0
  429. package/dist/components/number-input/index.js.map +1 -0
  430. package/dist/components/pagination/index.cjs +5 -0
  431. package/dist/components/pagination/index.cjs.map +1 -0
  432. package/dist/components/pagination/index.js +5 -0
  433. package/dist/components/pagination/index.js.map +1 -0
  434. package/dist/components/radio/index.cjs +5 -0
  435. package/dist/components/radio/index.cjs.map +1 -0
  436. package/dist/components/radio/index.js +5 -0
  437. package/dist/components/radio/index.js.map +1 -0
  438. package/dist/components/search-input/index.cjs +5 -0
  439. package/dist/components/search-input/index.cjs.map +1 -0
  440. package/dist/components/search-input/index.js +5 -0
  441. package/dist/components/search-input/index.js.map +1 -0
  442. package/dist/components/select/index.cjs +5 -0
  443. package/dist/components/select/index.cjs.map +1 -0
  444. package/dist/components/select/index.js +5 -0
  445. package/dist/components/select/index.js.map +1 -0
  446. package/dist/components/stat-card/index.cjs +5 -0
  447. package/dist/components/stat-card/index.cjs.map +1 -0
  448. package/dist/components/stat-card/index.js +5 -0
  449. package/dist/components/stat-card/index.js.map +1 -0
  450. package/dist/components/switch/index.cjs +5 -0
  451. package/dist/components/switch/index.cjs.map +1 -0
  452. package/dist/components/switch/index.js +5 -0
  453. package/dist/components/switch/index.js.map +1 -0
  454. package/dist/components/table/index.cjs +5 -0
  455. package/dist/components/table/index.cjs.map +1 -0
  456. package/dist/components/table/index.js +5 -0
  457. package/dist/components/table/index.js.map +1 -0
  458. package/dist/components/tabs/index.cjs +5 -0
  459. package/dist/components/tabs/index.cjs.map +1 -0
  460. package/dist/components/tabs/index.js +5 -0
  461. package/dist/components/tabs/index.js.map +1 -0
  462. package/dist/components/textarea/index.cjs +5 -0
  463. package/dist/components/textarea/index.cjs.map +1 -0
  464. package/dist/components/textarea/index.js +5 -0
  465. package/dist/components/textarea/index.js.map +1 -0
  466. package/dist/components/tooltip/index.cjs +5 -0
  467. package/dist/components/tooltip/index.cjs.map +1 -0
  468. package/dist/components/tooltip/index.js +5 -0
  469. package/dist/components/tooltip/index.js.map +1 -0
  470. package/dist/components/upload/index.cjs +5 -0
  471. package/dist/components/upload/index.cjs.map +1 -0
  472. package/dist/components/upload/index.js +5 -0
  473. package/dist/components/upload/index.js.map +1 -0
  474. package/dist/hooks/index.d.ts +5 -0
  475. package/dist/hooks/index.d.ts.map +1 -0
  476. package/dist/hooks/useConfirm.d.ts +17 -0
  477. package/dist/hooks/useConfirm.d.ts.map +1 -0
  478. package/dist/hooks/useMessage.d.ts +14 -0
  479. package/dist/hooks/useMessage.d.ts.map +1 -0
  480. package/dist/index.cjs +1907 -6229
  481. package/dist/index.cjs.map +1 -1
  482. package/dist/index.d.ts +10 -982
  483. package/dist/index.d.ts.map +1 -0
  484. package/dist/index.js +1906 -6227
  485. package/dist/index.js.map +1 -1
  486. package/dist/style.css +389 -60
  487. package/dist/types/index.d.ts +25 -0
  488. package/dist/types/index.d.ts.map +1 -0
  489. package/dist/useConfirm-BIxTX3mT.js +218 -0
  490. package/dist/useConfirm-BIxTX3mT.js.map +1 -0
  491. package/dist/useConfirm-BO5Ch3Bf.cjs +217 -0
  492. package/dist/useConfirm-BO5Ch3Bf.cjs.map +1 -0
  493. package/dist/useMessage-BBxUPe8b.cjs +242 -0
  494. package/dist/useMessage-BBxUPe8b.cjs.map +1 -0
  495. package/dist/useMessage-CRsCgzDR.js +243 -0
  496. package/dist/useMessage-CRsCgzDR.js.map +1 -0
  497. package/dist/utils/cn.d.ts +8 -0
  498. package/dist/utils/cn.d.ts.map +1 -0
  499. package/dist/utils/componentSizes.d.ts +57 -0
  500. package/dist/utils/componentSizes.d.ts.map +1 -0
  501. package/dist/utils/index.d.ts +3 -0
  502. package/dist/utils/index.d.ts.map +1 -0
  503. 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,3 @@
1
+ export * from './componentSizes';
2
+ export * from './cn';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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"}