@ryanhe919/lumen-ui 0.2.1 → 0.2.2

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 (452) hide show
  1. package/dist/LMBadge-1rGc3lqC.cjs +125 -0
  2. package/dist/LMBadge-1rGc3lqC.cjs.map +1 -0
  3. package/dist/LMBadge-OEGi87jW.js +126 -0
  4. package/dist/LMBadge-OEGi87jW.js.map +1 -0
  5. package/dist/LMButton-B258yfky.cjs +333 -0
  6. package/dist/LMButton-B258yfky.cjs.map +1 -0
  7. package/dist/LMButton-S4xQSohi.js +334 -0
  8. package/dist/LMButton-S4xQSohi.js.map +1 -0
  9. package/dist/LMCard-C48UclOk.cjs +206 -0
  10. package/dist/LMCard-C48UclOk.cjs.map +1 -0
  11. package/dist/LMCard-Sulq0Yjh.js +207 -0
  12. package/dist/LMCard-Sulq0Yjh.js.map +1 -0
  13. package/dist/LMCheckbox-C2YvEQ8f.cjs +197 -0
  14. package/dist/LMCheckbox-C2YvEQ8f.cjs.map +1 -0
  15. package/dist/LMCheckbox-DaaJRjKt.js +198 -0
  16. package/dist/LMCheckbox-DaaJRjKt.js.map +1 -0
  17. package/dist/LMDatePicker-BlKctoyr.cjs +565 -0
  18. package/dist/LMDatePicker-BlKctoyr.cjs.map +1 -0
  19. package/dist/LMDatePicker-CXiYSome.js +566 -0
  20. package/dist/LMDatePicker-CXiYSome.js.map +1 -0
  21. package/dist/LMDrawer-BcVtcYCN.cjs +207 -0
  22. package/dist/LMDrawer-BcVtcYCN.cjs.map +1 -0
  23. package/dist/LMDrawer-DcPqwiuo.js +208 -0
  24. package/dist/LMDrawer-DcPqwiuo.js.map +1 -0
  25. package/dist/LMDropdown-wiTMuyhU.js +285 -0
  26. package/dist/LMDropdown-wiTMuyhU.js.map +1 -0
  27. package/dist/LMDropdown-yl5l7qtz.cjs +284 -0
  28. package/dist/LMDropdown-yl5l7qtz.cjs.map +1 -0
  29. package/dist/LMEmpty-BedQxpbi.cjs +188 -0
  30. package/dist/LMEmpty-BedQxpbi.cjs.map +1 -0
  31. package/dist/LMEmpty-DzHM1fOb.js +189 -0
  32. package/dist/LMEmpty-DzHM1fOb.js.map +1 -0
  33. package/dist/LMField-BS-DSEya.js +67 -0
  34. package/dist/LMField-BS-DSEya.js.map +1 -0
  35. package/dist/LMField-DhDHj64z.cjs +66 -0
  36. package/dist/LMField-DhDHj64z.cjs.map +1 -0
  37. package/dist/LMInput-CVjawj1F.cjs +140 -0
  38. package/dist/LMInput-CVjawj1F.cjs.map +1 -0
  39. package/dist/LMInput-D9csGyhj.js +141 -0
  40. package/dist/LMInput-D9csGyhj.js.map +1 -0
  41. package/dist/LMMenu-IDAgZFuC.cjs +234 -0
  42. package/dist/LMMenu-IDAgZFuC.cjs.map +1 -0
  43. package/dist/LMMenu-yXadjQLQ.js +235 -0
  44. package/dist/LMMenu-yXadjQLQ.js.map +1 -0
  45. package/dist/LMModal-BCVVPLot.cjs +203 -0
  46. package/dist/LMModal-BCVVPLot.cjs.map +1 -0
  47. package/dist/LMModal-DCJPlfA4.js +204 -0
  48. package/dist/LMModal-DCJPlfA4.js.map +1 -0
  49. package/dist/LMNumberInput-B1tU7T_W.cjs +294 -0
  50. package/dist/LMNumberInput-B1tU7T_W.cjs.map +1 -0
  51. package/dist/LMNumberInput-BI5_OEx4.js +295 -0
  52. package/dist/LMNumberInput-BI5_OEx4.js.map +1 -0
  53. package/dist/LMPagination-BypfLRlF.js +305 -0
  54. package/dist/LMPagination-BypfLRlF.js.map +1 -0
  55. package/dist/LMPagination-CouDFIwd.cjs +304 -0
  56. package/dist/LMPagination-CouDFIwd.cjs.map +1 -0
  57. package/dist/LMRadio-CHn6nFSy.cjs +189 -0
  58. package/dist/LMRadio-CHn6nFSy.cjs.map +1 -0
  59. package/dist/LMRadio-UQLNgTMF.js +190 -0
  60. package/dist/LMRadio-UQLNgTMF.js.map +1 -0
  61. package/dist/LMSearchInput-CIvVkEf2.js +205 -0
  62. package/dist/LMSearchInput-CIvVkEf2.js.map +1 -0
  63. package/dist/LMSearchInput-nBlAX734.cjs +204 -0
  64. package/dist/LMSearchInput-nBlAX734.cjs.map +1 -0
  65. package/dist/LMSelect-B-MWX2JI.js +309 -0
  66. package/dist/LMSelect-B-MWX2JI.js.map +1 -0
  67. package/dist/LMSelect-ByQcUp2S.cjs +308 -0
  68. package/dist/LMSelect-ByQcUp2S.cjs.map +1 -0
  69. package/dist/LMStatCard-4mDqhlHt.js +348 -0
  70. package/dist/LMStatCard-4mDqhlHt.js.map +1 -0
  71. package/dist/LMStatCard-Du5Mti-p.cjs +347 -0
  72. package/dist/LMStatCard-Du5Mti-p.cjs.map +1 -0
  73. package/dist/LMSwitch-CKnrY30F.cjs +206 -0
  74. package/dist/LMSwitch-CKnrY30F.cjs.map +1 -0
  75. package/dist/LMSwitch-CVFdgSPh.js +207 -0
  76. package/dist/LMSwitch-CVFdgSPh.js.map +1 -0
  77. package/dist/LMTable-Cp8HZqiV.js +594 -0
  78. package/dist/LMTable-Cp8HZqiV.js.map +1 -0
  79. package/dist/LMTable-j1ZzAzXB.cjs +593 -0
  80. package/dist/LMTable-j1ZzAzXB.cjs.map +1 -0
  81. package/dist/LMTabs-DCVaqbrn.cjs +209 -0
  82. package/dist/LMTabs-DCVaqbrn.cjs.map +1 -0
  83. package/dist/LMTabs-DZFAU58t.js +210 -0
  84. package/dist/LMTabs-DZFAU58t.js.map +1 -0
  85. package/dist/LMTextarea-5dVVPeL2.js +136 -0
  86. package/dist/LMTextarea-5dVVPeL2.js.map +1 -0
  87. package/dist/LMTextarea-yG0OBZjA.cjs +135 -0
  88. package/dist/LMTextarea-yG0OBZjA.cjs.map +1 -0
  89. package/dist/LMTooltip-30_lOAnH.cjs +85 -0
  90. package/dist/LMTooltip-30_lOAnH.cjs.map +1 -0
  91. package/dist/LMTooltip-h47oYhl8.js +86 -0
  92. package/dist/LMTooltip-h47oYhl8.js.map +1 -0
  93. package/dist/LMUpload-B_GA4O8W.js +380 -0
  94. package/dist/LMUpload-B_GA4O8W.js.map +1 -0
  95. package/dist/LMUpload-BpISVQGz.cjs +379 -0
  96. package/dist/LMUpload-BpISVQGz.cjs.map +1 -0
  97. package/dist/componentSizes-CdWNL526.js +125 -0
  98. package/dist/componentSizes-CdWNL526.js.map +1 -0
  99. package/dist/componentSizes-DUTZ7uEM.cjs +124 -0
  100. package/dist/componentSizes-DUTZ7uEM.cjs.map +1 -0
  101. package/dist/components/DataDisplay/LMCard/LMCard.d.ts +30 -0
  102. package/dist/components/DataDisplay/LMCard/LMCard.d.ts.map +1 -0
  103. package/dist/components/DataDisplay/LMCard/LMCard.stories.d.ts +33 -0
  104. package/dist/components/DataDisplay/LMCard/LMCard.stories.d.ts.map +1 -0
  105. package/dist/components/DataDisplay/LMCard/LMCard.test.d.ts +2 -0
  106. package/dist/components/DataDisplay/LMCard/LMCard.test.d.ts.map +1 -0
  107. package/dist/components/DataDisplay/LMCard/index.d.ts +3 -0
  108. package/dist/components/DataDisplay/LMCard/index.d.ts.map +1 -0
  109. package/dist/components/DataDisplay/LMEmpty/LMEmpty.d.ts +18 -0
  110. package/dist/components/DataDisplay/LMEmpty/LMEmpty.d.ts.map +1 -0
  111. package/dist/components/DataDisplay/LMEmpty/LMEmpty.stories.d.ts +31 -0
  112. package/dist/components/DataDisplay/LMEmpty/LMEmpty.stories.d.ts.map +1 -0
  113. package/dist/components/DataDisplay/LMEmpty/LMEmpty.test.d.ts +2 -0
  114. package/dist/components/DataDisplay/LMEmpty/LMEmpty.test.d.ts.map +1 -0
  115. package/dist/components/DataDisplay/LMEmpty/index.d.ts +3 -0
  116. package/dist/components/DataDisplay/LMEmpty/index.d.ts.map +1 -0
  117. package/dist/components/DataDisplay/LMStatCard/LMStatCard.d.ts +40 -0
  118. package/dist/components/DataDisplay/LMStatCard/LMStatCard.d.ts.map +1 -0
  119. package/dist/components/DataDisplay/LMStatCard/LMStatCard.stories.d.ts +35 -0
  120. package/dist/components/DataDisplay/LMStatCard/LMStatCard.stories.d.ts.map +1 -0
  121. package/dist/components/DataDisplay/LMStatCard/LMStatCard.test.d.ts +2 -0
  122. package/dist/components/DataDisplay/LMStatCard/LMStatCard.test.d.ts.map +1 -0
  123. package/dist/components/DataDisplay/LMStatCard/index.d.ts +3 -0
  124. package/dist/components/DataDisplay/LMStatCard/index.d.ts.map +1 -0
  125. package/dist/components/DataDisplay/LMTable/LMTable.d.ts +93 -0
  126. package/dist/components/DataDisplay/LMTable/LMTable.d.ts.map +1 -0
  127. package/dist/components/DataDisplay/LMTable/LMTable.stories.d.ts +35 -0
  128. package/dist/components/DataDisplay/LMTable/LMTable.stories.d.ts.map +1 -0
  129. package/dist/components/DataDisplay/LMTable/LMTable.test.d.ts +2 -0
  130. package/dist/components/DataDisplay/LMTable/LMTable.test.d.ts.map +1 -0
  131. package/dist/components/DataDisplay/LMTable/index.d.ts +3 -0
  132. package/dist/components/DataDisplay/LMTable/index.d.ts.map +1 -0
  133. package/dist/components/DataDisplay/LMTabs/LMTabs.d.ts +40 -0
  134. package/dist/components/DataDisplay/LMTabs/LMTabs.d.ts.map +1 -0
  135. package/dist/components/DataDisplay/LMTabs/LMTabs.stories.d.ts +35 -0
  136. package/dist/components/DataDisplay/LMTabs/LMTabs.stories.d.ts.map +1 -0
  137. package/dist/components/DataDisplay/LMTabs/LMTabs.test.d.ts +2 -0
  138. package/dist/components/DataDisplay/LMTabs/LMTabs.test.d.ts.map +1 -0
  139. package/dist/components/DataDisplay/LMTabs/index.d.ts +3 -0
  140. package/dist/components/DataDisplay/LMTabs/index.d.ts.map +1 -0
  141. package/dist/components/DataDisplay/LMTooltip/LMTooltip.d.ts +18 -0
  142. package/dist/components/DataDisplay/LMTooltip/LMTooltip.d.ts.map +1 -0
  143. package/dist/components/DataDisplay/LMTooltip/LMTooltip.stories.d.ts +27 -0
  144. package/dist/components/DataDisplay/LMTooltip/LMTooltip.stories.d.ts.map +1 -0
  145. package/dist/components/DataDisplay/LMTooltip/LMTooltip.test.d.ts +2 -0
  146. package/dist/components/DataDisplay/LMTooltip/LMTooltip.test.d.ts.map +1 -0
  147. package/dist/components/DataDisplay/LMTooltip/index.d.ts +3 -0
  148. package/dist/components/DataDisplay/LMTooltip/index.d.ts.map +1 -0
  149. package/dist/components/DataDisplay/index.d.ts +7 -0
  150. package/dist/components/DataDisplay/index.d.ts.map +1 -0
  151. package/dist/components/Feedback/LMConfirm/LMConfirm.d.ts +25 -0
  152. package/dist/components/Feedback/LMConfirm/LMConfirm.d.ts.map +1 -0
  153. package/dist/components/Feedback/LMConfirm/LMConfirm.stories.d.ts +19 -0
  154. package/dist/components/Feedback/LMConfirm/LMConfirm.stories.d.ts.map +1 -0
  155. package/dist/components/Feedback/LMConfirm/LMConfirm.test.d.ts +2 -0
  156. package/dist/components/Feedback/LMConfirm/LMConfirm.test.d.ts.map +1 -0
  157. package/dist/components/Feedback/LMConfirm/index.d.ts +5 -0
  158. package/dist/components/Feedback/LMConfirm/index.d.ts.map +1 -0
  159. package/dist/components/Feedback/LMDrawer/LMDrawer.d.ts +38 -0
  160. package/dist/components/Feedback/LMDrawer/LMDrawer.d.ts.map +1 -0
  161. package/dist/components/Feedback/LMDrawer/LMDrawer.stories.d.ts +33 -0
  162. package/dist/components/Feedback/LMDrawer/LMDrawer.stories.d.ts.map +1 -0
  163. package/dist/components/Feedback/LMDrawer/LMDrawer.test.d.ts +2 -0
  164. package/dist/components/Feedback/LMDrawer/LMDrawer.test.d.ts.map +1 -0
  165. package/dist/components/Feedback/LMDrawer/index.d.ts +3 -0
  166. package/dist/components/Feedback/LMDrawer/index.d.ts.map +1 -0
  167. package/dist/components/Feedback/LMMessage/LMMessage.d.ts +31 -0
  168. package/dist/components/Feedback/LMMessage/LMMessage.d.ts.map +1 -0
  169. package/dist/components/Feedback/LMMessage/LMMessage.stories.d.ts +25 -0
  170. package/dist/components/Feedback/LMMessage/LMMessage.stories.d.ts.map +1 -0
  171. package/dist/components/Feedback/LMMessage/LMMessage.test.d.ts +2 -0
  172. package/dist/components/Feedback/LMMessage/LMMessage.test.d.ts.map +1 -0
  173. package/dist/components/Feedback/LMMessage/index.d.ts +5 -0
  174. package/dist/components/Feedback/LMMessage/index.d.ts.map +1 -0
  175. package/dist/components/Feedback/LMModal/LMModal.d.ts +62 -0
  176. package/dist/components/Feedback/LMModal/LMModal.d.ts.map +1 -0
  177. package/dist/components/Feedback/LMModal/LMModal.stories.d.ts +23 -0
  178. package/dist/components/Feedback/LMModal/LMModal.stories.d.ts.map +1 -0
  179. package/dist/components/Feedback/LMModal/LMModal.test.d.ts +2 -0
  180. package/dist/components/Feedback/LMModal/LMModal.test.d.ts.map +1 -0
  181. package/dist/components/Feedback/LMModal/index.d.ts +3 -0
  182. package/dist/components/Feedback/LMModal/index.d.ts.map +1 -0
  183. package/dist/components/Feedback/index.d.ts +5 -0
  184. package/dist/components/Feedback/index.d.ts.map +1 -0
  185. package/dist/components/Form/LMCheckbox/LMCheckbox.d.ts +18 -0
  186. package/dist/components/Form/LMCheckbox/LMCheckbox.d.ts.map +1 -0
  187. package/dist/components/Form/LMCheckbox/LMCheckbox.stories.d.ts +23 -0
  188. package/dist/components/Form/LMCheckbox/LMCheckbox.stories.d.ts.map +1 -0
  189. package/dist/components/Form/LMCheckbox/LMCheckbox.test.d.ts +2 -0
  190. package/dist/components/Form/LMCheckbox/LMCheckbox.test.d.ts.map +1 -0
  191. package/dist/components/Form/LMCheckbox/index.d.ts +3 -0
  192. package/dist/components/Form/LMCheckbox/index.d.ts.map +1 -0
  193. package/dist/components/Form/LMDatePicker/LMDatePicker.d.ts +52 -0
  194. package/dist/components/Form/LMDatePicker/LMDatePicker.d.ts.map +1 -0
  195. package/dist/components/Form/LMDatePicker/LMDatePicker.stories.d.ts +41 -0
  196. package/dist/components/Form/LMDatePicker/LMDatePicker.stories.d.ts.map +1 -0
  197. package/dist/components/Form/LMDatePicker/LMDatePicker.test.d.ts +2 -0
  198. package/dist/components/Form/LMDatePicker/LMDatePicker.test.d.ts.map +1 -0
  199. package/dist/components/Form/LMDatePicker/index.d.ts +3 -0
  200. package/dist/components/Form/LMDatePicker/index.d.ts.map +1 -0
  201. package/dist/components/Form/LMField/LMField.d.ts +19 -0
  202. package/dist/components/Form/LMField/LMField.d.ts.map +1 -0
  203. package/dist/components/Form/LMField/LMField.stories.d.ts +23 -0
  204. package/dist/components/Form/LMField/LMField.stories.d.ts.map +1 -0
  205. package/dist/components/Form/LMField/LMField.test.d.ts +2 -0
  206. package/dist/components/Form/LMField/LMField.test.d.ts.map +1 -0
  207. package/dist/components/Form/LMField/index.d.ts +3 -0
  208. package/dist/components/Form/LMField/index.d.ts.map +1 -0
  209. package/dist/components/Form/LMInput/LMInput.d.ts +20 -0
  210. package/dist/components/Form/LMInput/LMInput.d.ts.map +1 -0
  211. package/dist/components/Form/LMInput/LMInput.stories.d.ts +29 -0
  212. package/dist/components/Form/LMInput/LMInput.stories.d.ts.map +1 -0
  213. package/dist/components/Form/LMInput/LMInput.test.d.ts +2 -0
  214. package/dist/components/Form/LMInput/LMInput.test.d.ts.map +1 -0
  215. package/dist/components/Form/LMInput/index.d.ts +3 -0
  216. package/dist/components/Form/LMInput/index.d.ts.map +1 -0
  217. package/dist/components/Form/LMNumberInput/LMNumberInput.d.ts +40 -0
  218. package/dist/components/Form/LMNumberInput/LMNumberInput.d.ts.map +1 -0
  219. package/dist/components/Form/LMNumberInput/LMNumberInput.stories.d.ts +33 -0
  220. package/dist/components/Form/LMNumberInput/LMNumberInput.stories.d.ts.map +1 -0
  221. package/dist/components/Form/LMNumberInput/LMNumberInput.test.d.ts +2 -0
  222. package/dist/components/Form/LMNumberInput/LMNumberInput.test.d.ts.map +1 -0
  223. package/dist/components/Form/LMNumberInput/index.d.ts +3 -0
  224. package/dist/components/Form/LMNumberInput/index.d.ts.map +1 -0
  225. package/dist/components/Form/LMRadio/LMRadio.d.ts +18 -0
  226. package/dist/components/Form/LMRadio/LMRadio.d.ts.map +1 -0
  227. package/dist/components/Form/LMRadio/LMRadio.stories.d.ts +25 -0
  228. package/dist/components/Form/LMRadio/LMRadio.stories.d.ts.map +1 -0
  229. package/dist/components/Form/LMRadio/LMRadio.test.d.ts +2 -0
  230. package/dist/components/Form/LMRadio/LMRadio.test.d.ts.map +1 -0
  231. package/dist/components/Form/LMRadio/index.d.ts +3 -0
  232. package/dist/components/Form/LMRadio/index.d.ts.map +1 -0
  233. package/dist/components/Form/LMSearchInput/LMSearchInput.d.ts +36 -0
  234. package/dist/components/Form/LMSearchInput/LMSearchInput.d.ts.map +1 -0
  235. package/dist/components/Form/LMSearchInput/LMSearchInput.stories.d.ts +27 -0
  236. package/dist/components/Form/LMSearchInput/LMSearchInput.stories.d.ts.map +1 -0
  237. package/dist/components/Form/LMSearchInput/LMSearchInput.test.d.ts +2 -0
  238. package/dist/components/Form/LMSearchInput/LMSearchInput.test.d.ts.map +1 -0
  239. package/dist/components/Form/LMSearchInput/index.d.ts +3 -0
  240. package/dist/components/Form/LMSearchInput/index.d.ts.map +1 -0
  241. package/dist/components/Form/LMSelect/LMSelect.d.ts +37 -0
  242. package/dist/components/Form/LMSelect/LMSelect.d.ts.map +1 -0
  243. package/dist/components/Form/LMSelect/LMSelect.stories.d.ts +27 -0
  244. package/dist/components/Form/LMSelect/LMSelect.stories.d.ts.map +1 -0
  245. package/dist/components/Form/LMSelect/LMSelect.test.d.ts +2 -0
  246. package/dist/components/Form/LMSelect/LMSelect.test.d.ts.map +1 -0
  247. package/dist/components/Form/LMSelect/index.d.ts +3 -0
  248. package/dist/components/Form/LMSelect/index.d.ts.map +1 -0
  249. package/dist/components/Form/LMSwitch/LMSwitch.d.ts +18 -0
  250. package/dist/components/Form/LMSwitch/LMSwitch.d.ts.map +1 -0
  251. package/dist/components/Form/LMSwitch/LMSwitch.stories.d.ts +25 -0
  252. package/dist/components/Form/LMSwitch/LMSwitch.stories.d.ts.map +1 -0
  253. package/dist/components/Form/LMSwitch/LMSwitch.test.d.ts +2 -0
  254. package/dist/components/Form/LMSwitch/LMSwitch.test.d.ts.map +1 -0
  255. package/dist/components/Form/LMSwitch/index.d.ts +3 -0
  256. package/dist/components/Form/LMSwitch/index.d.ts.map +1 -0
  257. package/dist/components/Form/LMTextarea/LMTextarea.d.ts +14 -0
  258. package/dist/components/Form/LMTextarea/LMTextarea.d.ts.map +1 -0
  259. package/dist/components/Form/LMTextarea/LMTextarea.stories.d.ts +23 -0
  260. package/dist/components/Form/LMTextarea/LMTextarea.stories.d.ts.map +1 -0
  261. package/dist/components/Form/LMTextarea/LMTextarea.test.d.ts +2 -0
  262. package/dist/components/Form/LMTextarea/LMTextarea.test.d.ts.map +1 -0
  263. package/dist/components/Form/LMTextarea/index.d.ts +3 -0
  264. package/dist/components/Form/LMTextarea/index.d.ts.map +1 -0
  265. package/dist/components/Form/LMUpload/LMUpload.d.ts +68 -0
  266. package/dist/components/Form/LMUpload/LMUpload.d.ts.map +1 -0
  267. package/dist/components/Form/LMUpload/LMUpload.stories.d.ts +41 -0
  268. package/dist/components/Form/LMUpload/LMUpload.stories.d.ts.map +1 -0
  269. package/dist/components/Form/LMUpload/LMUpload.test.d.ts +2 -0
  270. package/dist/components/Form/LMUpload/LMUpload.test.d.ts.map +1 -0
  271. package/dist/components/Form/LMUpload/index.d.ts +3 -0
  272. package/dist/components/Form/LMUpload/index.d.ts.map +1 -0
  273. package/dist/components/Form/index.d.ts +12 -0
  274. package/dist/components/Form/index.d.ts.map +1 -0
  275. package/dist/components/General/LMBadge/LMBadge.d.ts +21 -0
  276. package/dist/components/General/LMBadge/LMBadge.d.ts.map +1 -0
  277. package/dist/components/General/LMBadge/LMBadge.stories.d.ts +31 -0
  278. package/dist/components/General/LMBadge/LMBadge.stories.d.ts.map +1 -0
  279. package/dist/components/General/LMBadge/LMBadge.test.d.ts +2 -0
  280. package/dist/components/General/LMBadge/LMBadge.test.d.ts.map +1 -0
  281. package/dist/components/General/LMBadge/index.d.ts +3 -0
  282. package/dist/components/General/LMBadge/index.d.ts.map +1 -0
  283. package/dist/components/General/LMButton/LMButton.d.ts +25 -0
  284. package/dist/components/General/LMButton/LMButton.d.ts.map +1 -0
  285. package/dist/components/General/LMButton/LMButton.stories.d.ts +39 -0
  286. package/dist/components/General/LMButton/LMButton.stories.d.ts.map +1 -0
  287. package/dist/components/General/LMButton/LMButton.test.d.ts +2 -0
  288. package/dist/components/General/LMButton/LMButton.test.d.ts.map +1 -0
  289. package/dist/components/General/LMButton/index.d.ts +3 -0
  290. package/dist/components/General/LMButton/index.d.ts.map +1 -0
  291. package/dist/components/General/index.d.ts +3 -0
  292. package/dist/components/General/index.d.ts.map +1 -0
  293. package/dist/components/Navigation/LMDropdown/LMDropdown.d.ts +40 -0
  294. package/dist/components/Navigation/LMDropdown/LMDropdown.d.ts.map +1 -0
  295. package/dist/components/Navigation/LMDropdown/LMDropdown.stories.d.ts +31 -0
  296. package/dist/components/Navigation/LMDropdown/LMDropdown.stories.d.ts.map +1 -0
  297. package/dist/components/Navigation/LMDropdown/LMDropdown.test.d.ts +2 -0
  298. package/dist/components/Navigation/LMDropdown/LMDropdown.test.d.ts.map +1 -0
  299. package/dist/components/Navigation/LMDropdown/index.d.ts +3 -0
  300. package/dist/components/Navigation/LMDropdown/index.d.ts.map +1 -0
  301. package/dist/components/Navigation/LMMenu/LMMenu.d.ts +48 -0
  302. package/dist/components/Navigation/LMMenu/LMMenu.d.ts.map +1 -0
  303. package/dist/components/Navigation/LMMenu/LMMenu.stories.d.ts +25 -0
  304. package/dist/components/Navigation/LMMenu/LMMenu.stories.d.ts.map +1 -0
  305. package/dist/components/Navigation/LMMenu/LMMenu.test.d.ts +2 -0
  306. package/dist/components/Navigation/LMMenu/LMMenu.test.d.ts.map +1 -0
  307. package/dist/components/Navigation/LMMenu/index.d.ts +3 -0
  308. package/dist/components/Navigation/LMMenu/index.d.ts.map +1 -0
  309. package/dist/components/Navigation/LMPagination/LMPagination.d.ts +32 -0
  310. package/dist/components/Navigation/LMPagination/LMPagination.d.ts.map +1 -0
  311. package/dist/components/Navigation/LMPagination/LMPagination.stories.d.ts +35 -0
  312. package/dist/components/Navigation/LMPagination/LMPagination.stories.d.ts.map +1 -0
  313. package/dist/components/Navigation/LMPagination/LMPagination.test.d.ts +2 -0
  314. package/dist/components/Navigation/LMPagination/LMPagination.test.d.ts.map +1 -0
  315. package/dist/components/Navigation/LMPagination/index.d.ts +3 -0
  316. package/dist/components/Navigation/LMPagination/index.d.ts.map +1 -0
  317. package/dist/components/Navigation/index.d.ts +4 -0
  318. package/dist/components/Navigation/index.d.ts.map +1 -0
  319. package/dist/components/badge/index.cjs +5 -0
  320. package/dist/components/badge/index.cjs.map +1 -0
  321. package/dist/components/badge/index.js +5 -0
  322. package/dist/components/badge/index.js.map +1 -0
  323. package/dist/components/button/index.cjs +5 -0
  324. package/dist/components/button/index.cjs.map +1 -0
  325. package/dist/components/button/index.js +5 -0
  326. package/dist/components/button/index.js.map +1 -0
  327. package/dist/components/card/index.cjs +5 -0
  328. package/dist/components/card/index.cjs.map +1 -0
  329. package/dist/components/card/index.js +5 -0
  330. package/dist/components/card/index.js.map +1 -0
  331. package/dist/components/checkbox/index.cjs +5 -0
  332. package/dist/components/checkbox/index.cjs.map +1 -0
  333. package/dist/components/checkbox/index.js +5 -0
  334. package/dist/components/checkbox/index.js.map +1 -0
  335. package/dist/components/confirm/index.cjs +6 -0
  336. package/dist/components/confirm/index.cjs.map +1 -0
  337. package/dist/components/confirm/index.js +6 -0
  338. package/dist/components/confirm/index.js.map +1 -0
  339. package/dist/components/date-picker/index.cjs +5 -0
  340. package/dist/components/date-picker/index.cjs.map +1 -0
  341. package/dist/components/date-picker/index.js +5 -0
  342. package/dist/components/date-picker/index.js.map +1 -0
  343. package/dist/components/drawer/index.cjs +5 -0
  344. package/dist/components/drawer/index.cjs.map +1 -0
  345. package/dist/components/drawer/index.js +5 -0
  346. package/dist/components/drawer/index.js.map +1 -0
  347. package/dist/components/dropdown/index.cjs +5 -0
  348. package/dist/components/dropdown/index.cjs.map +1 -0
  349. package/dist/components/dropdown/index.js +5 -0
  350. package/dist/components/dropdown/index.js.map +1 -0
  351. package/dist/components/empty/index.cjs +5 -0
  352. package/dist/components/empty/index.cjs.map +1 -0
  353. package/dist/components/empty/index.js +5 -0
  354. package/dist/components/empty/index.js.map +1 -0
  355. package/dist/components/field/index.cjs +5 -0
  356. package/dist/components/field/index.cjs.map +1 -0
  357. package/dist/components/field/index.js +5 -0
  358. package/dist/components/field/index.js.map +1 -0
  359. package/dist/components/input/index.cjs +5 -0
  360. package/dist/components/input/index.cjs.map +1 -0
  361. package/dist/components/input/index.js +5 -0
  362. package/dist/components/input/index.js.map +1 -0
  363. package/dist/components/menu/index.cjs +5 -0
  364. package/dist/components/menu/index.cjs.map +1 -0
  365. package/dist/components/menu/index.js +5 -0
  366. package/dist/components/menu/index.js.map +1 -0
  367. package/dist/components/message/index.cjs +7 -0
  368. package/dist/components/message/index.cjs.map +1 -0
  369. package/dist/components/message/index.js +7 -0
  370. package/dist/components/message/index.js.map +1 -0
  371. package/dist/components/modal/index.cjs +5 -0
  372. package/dist/components/modal/index.cjs.map +1 -0
  373. package/dist/components/modal/index.js +5 -0
  374. package/dist/components/modal/index.js.map +1 -0
  375. package/dist/components/number-input/index.cjs +5 -0
  376. package/dist/components/number-input/index.cjs.map +1 -0
  377. package/dist/components/number-input/index.js +5 -0
  378. package/dist/components/number-input/index.js.map +1 -0
  379. package/dist/components/pagination/index.cjs +5 -0
  380. package/dist/components/pagination/index.cjs.map +1 -0
  381. package/dist/components/pagination/index.js +5 -0
  382. package/dist/components/pagination/index.js.map +1 -0
  383. package/dist/components/radio/index.cjs +5 -0
  384. package/dist/components/radio/index.cjs.map +1 -0
  385. package/dist/components/radio/index.js +5 -0
  386. package/dist/components/radio/index.js.map +1 -0
  387. package/dist/components/search-input/index.cjs +5 -0
  388. package/dist/components/search-input/index.cjs.map +1 -0
  389. package/dist/components/search-input/index.js +5 -0
  390. package/dist/components/search-input/index.js.map +1 -0
  391. package/dist/components/select/index.cjs +5 -0
  392. package/dist/components/select/index.cjs.map +1 -0
  393. package/dist/components/select/index.js +5 -0
  394. package/dist/components/select/index.js.map +1 -0
  395. package/dist/components/stat-card/index.cjs +5 -0
  396. package/dist/components/stat-card/index.cjs.map +1 -0
  397. package/dist/components/stat-card/index.js +5 -0
  398. package/dist/components/stat-card/index.js.map +1 -0
  399. package/dist/components/switch/index.cjs +5 -0
  400. package/dist/components/switch/index.cjs.map +1 -0
  401. package/dist/components/switch/index.js +5 -0
  402. package/dist/components/switch/index.js.map +1 -0
  403. package/dist/components/table/index.cjs +5 -0
  404. package/dist/components/table/index.cjs.map +1 -0
  405. package/dist/components/table/index.js +5 -0
  406. package/dist/components/table/index.js.map +1 -0
  407. package/dist/components/tabs/index.cjs +5 -0
  408. package/dist/components/tabs/index.cjs.map +1 -0
  409. package/dist/components/tabs/index.js +5 -0
  410. package/dist/components/tabs/index.js.map +1 -0
  411. package/dist/components/textarea/index.cjs +5 -0
  412. package/dist/components/textarea/index.cjs.map +1 -0
  413. package/dist/components/textarea/index.js +5 -0
  414. package/dist/components/textarea/index.js.map +1 -0
  415. package/dist/components/tooltip/index.cjs +5 -0
  416. package/dist/components/tooltip/index.cjs.map +1 -0
  417. package/dist/components/tooltip/index.js +5 -0
  418. package/dist/components/tooltip/index.js.map +1 -0
  419. package/dist/components/upload/index.cjs +5 -0
  420. package/dist/components/upload/index.cjs.map +1 -0
  421. package/dist/components/upload/index.js +5 -0
  422. package/dist/components/upload/index.js.map +1 -0
  423. package/dist/hooks/index.d.ts +5 -0
  424. package/dist/hooks/index.d.ts.map +1 -0
  425. package/dist/hooks/useConfirm.d.ts +17 -0
  426. package/dist/hooks/useConfirm.d.ts.map +1 -0
  427. package/dist/hooks/useMessage.d.ts +14 -0
  428. package/dist/hooks/useMessage.d.ts.map +1 -0
  429. package/dist/index.cjs +70 -6401
  430. package/dist/index.cjs.map +1 -1
  431. package/dist/index.d.ts +9 -982
  432. package/dist/index.d.ts.map +1 -0
  433. package/dist/index.js +70 -6401
  434. package/dist/index.js.map +1 -1
  435. package/dist/style.css +137 -60
  436. package/dist/types/index.d.ts +25 -0
  437. package/dist/types/index.d.ts.map +1 -0
  438. package/dist/useConfirm-BIxTX3mT.js +218 -0
  439. package/dist/useConfirm-BIxTX3mT.js.map +1 -0
  440. package/dist/useConfirm-BO5Ch3Bf.cjs +217 -0
  441. package/dist/useConfirm-BO5Ch3Bf.cjs.map +1 -0
  442. package/dist/useMessage-BBxUPe8b.cjs +242 -0
  443. package/dist/useMessage-BBxUPe8b.cjs.map +1 -0
  444. package/dist/useMessage-CRsCgzDR.js +243 -0
  445. package/dist/useMessage-CRsCgzDR.js.map +1 -0
  446. package/dist/utils/cn.d.ts +8 -0
  447. package/dist/utils/cn.d.ts.map +1 -0
  448. package/dist/utils/componentSizes.d.ts +57 -0
  449. package/dist/utils/componentSizes.d.ts.map +1 -0
  450. package/dist/utils/index.d.ts +3 -0
  451. package/dist/utils/index.d.ts.map +1 -0
  452. package/package.json +264 -3
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LMSearchInput-nBlAX734.cjs","sources":["../src/components/Form/LMSearchInput/LMSearchInput.tsx"],"sourcesContent":["import React, { useState, useRef, useEffect } from 'react'\nimport { SIZE_INPUT_CONFIG } from '../../../utils/componentSizes'\nimport type { ComponentSize } from '../../../utils/componentSizes'\n\nexport interface LMSearchInputProps {\n /** Current search value */\n value?: string\n /** Change callback */\n onChange?: (value: string) => void\n /** Search submit callback */\n onSearch?: (value: string) => void\n /** Error state */\n error?: boolean\n /** Error message */\n errorMessage?: string\n /** Placeholder */\n placeholder?: string\n /** Disabled state */\n disabled?: boolean\n /** Class name */\n className?: string\n /** Form field name */\n name?: string\n /** Size */\n size?: ComponentSize\n /** Show clear button */\n showClear?: boolean\n /** Show search button */\n showSearchButton?: boolean\n /** Search button text */\n searchButtonText?: string\n /** Debounce delay (ms) */\n debounceDelay?: number\n}\n\nconst LMSearchInput: React.FC<LMSearchInputProps> = ({\n value,\n onChange,\n onSearch,\n error = false,\n errorMessage,\n placeholder = 'Search...',\n disabled = false,\n className = '',\n name,\n size = 'md',\n showClear = true,\n showSearchButton = true,\n searchButtonText = 'Search',\n debounceDelay = 300,\n}) => {\n const [inputValue, setInputValue] = useState(value || '')\n const [isFocused, setIsFocused] = useState(false)\n const debounceRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n const inputRef = useRef<HTMLInputElement>(null)\n const searchBtnRef = useRef<HTMLButtonElement>(null)\n const [searchBtnWidth, setSearchBtnWidth] = useState(0)\n\n useEffect(() => {\n if (value !== undefined && value !== null) setInputValue(value)\n }, [value])\n\n useEffect(() => {\n if (showSearchButton && searchBtnRef.current) {\n setSearchBtnWidth(searchBtnRef.current.offsetWidth || 0)\n } else {\n setSearchBtnWidth(0)\n }\n }, [showSearchButton, searchButtonText])\n\n const baseClassName = `\n w-full ${SIZE_INPUT_CONFIG[size].padding} ${SIZE_INPUT_CONFIG[size].height} backdrop-blur-md border rounded-2xl\n focus:ring-2 focus:outline-none transition-all duration-300\n shadow-sm\n ${showSearchButton ? 'pr-20' : showClear ? 'pr-10' : 'pr-4'}\n pl-12\n ${className}\n `\n .trim()\n .replace(/\\s+/g, ' ')\n\n const getSearchInputStyles = () => {\n const baseStyles = {\n backgroundColor: 'var(--lm-bg-elevated)',\n color: 'var(--lm-text-primary)',\n borderColor: error\n ? 'var(--lm-error-300)'\n : isFocused\n ? 'var(--lm-primary-400)'\n : 'var(--lm-border-default)',\n boxShadow: 'var(--lm-shadow-sm)',\n } as React.CSSProperties\n\n return {\n ...baseStyles,\n '--tw-ring-color': error\n ? 'var(--lm-error-400)'\n : 'var(--lm-primary-400)',\n '--tw-ring-opacity': '0.3',\n }\n }\n\n const getDisabledStyles = () =>\n disabled\n ? {\n backgroundColor: 'var(--lm-bg-paper)',\n color: 'var(--lm-text-disabled)',\n cursor: 'not-allowed',\n opacity: 0.6,\n }\n : {}\n\n const getIconStyles = () => {\n if (error) return { color: 'var(--lm-error-400)' }\n if (isFocused) return { color: 'var(--lm-primary-500)' }\n return { color: 'var(--lm-text-secondary)' }\n }\n\n const getButtonStyles = () => ({\n backgroundColor: 'var(--lm-primary-500)',\n color: 'white',\n })\n\n const getClearButtonStyles = () => ({\n backgroundColor: 'var(--lm-bg-paper)',\n color: 'var(--lm-text-secondary)',\n })\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = event.target.value\n setInputValue(newValue)\n onChange?.(newValue)\n\n if (debounceRef.current) clearTimeout(debounceRef.current)\n debounceRef.current = setTimeout(() => {\n onSearch?.(newValue)\n }, debounceDelay)\n }\n\n const handleSearch = () => onSearch?.(inputValue)\n\n const handleClear = () => {\n setInputValue('')\n onChange?.('')\n onSearch?.('')\n inputRef.current?.focus()\n }\n\n const handleKeyDown = (event: React.KeyboardEvent) => {\n if (event.key === 'Enter') {\n event.preventDefault()\n handleSearch()\n }\n }\n\n const clearBtnSizeClass =\n size === 'sm'\n ? 'w-7 h-7 text-xs'\n : size === 'lg'\n ? 'w-9 h-9 text-sm'\n : 'w-8 h-8 text-sm'\n\n const clearRightPx = showSearchButton ? searchBtnWidth + 8 : 8\n\n const SearchIcon = () => (\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z\" />\n </svg>\n )\n\n const ClearIcon = () => (\n <svg className=\"w-3 h-3\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n )\n\n return (\n <div className=\"space-y-2\">\n <div className=\"relative group\">\n <div className=\"absolute inset-y-0 left-0 pl-4 flex items-center pointer-events-none z-10\">\n <span style={getIconStyles()}>\n <SearchIcon />\n </span>\n </div>\n\n <input\n ref={inputRef}\n type=\"search\"\n name={name}\n value={inputValue}\n placeholder={placeholder}\n disabled={disabled}\n className={baseClassName}\n style={{\n ...getSearchInputStyles(),\n ...getDisabledStyles(),\n } as React.CSSProperties}\n onChange={handleInputChange}\n onKeyDown={handleKeyDown}\n onFocus={() => setIsFocused(true)}\n onBlur={() => setIsFocused(false)}\n onMouseEnter={(e) => {\n if (!disabled && !error && !isFocused) {\n e.currentTarget.style.borderColor = 'var(--lm-border-strong)'\n }\n }}\n onMouseLeave={(e) => {\n if (!disabled && !error && !isFocused) {\n e.currentTarget.style.borderColor = 'var(--lm-border-default)'\n }\n }}\n />\n\n <style>{`\n input[type='search']::-webkit-search-cancel-button {\n -webkit-appearance: none;\n appearance: none;\n }\n `}</style>\n\n {showClear && inputValue && !disabled && (\n <button\n onClick={handleClear}\n className={`absolute top-1/2 -translate-y-1/2 z-10 rounded-full flex items-center justify-center ${clearBtnSizeClass}`}\n style={{\n ...getClearButtonStyles(),\n right: `${clearRightPx}px`,\n }}\n onMouseEnter={(e) => {\n e.currentTarget.style.backgroundColor = 'var(--lm-bg-elevated)'\n e.currentTarget.style.color = 'var(--lm-text-primary)'\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.backgroundColor = 'var(--lm-bg-paper)'\n e.currentTarget.style.color = 'var(--lm-text-secondary)'\n }}\n aria-label=\"Clear\"\n type=\"button\"\n >\n <ClearIcon />\n </button>\n )}\n\n {showSearchButton && !disabled && (\n <button\n ref={searchBtnRef}\n onClick={handleSearch}\n className=\"absolute inset-y-0 right-0 px-4 rounded-r-2xl transition-colors duration-200 z-20\"\n style={getButtonStyles()}\n onMouseEnter={(e) => {\n e.currentTarget.style.backgroundColor = 'var(--lm-primary-600)'\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.backgroundColor = 'var(--lm-primary-500)'\n }}\n type=\"button\"\n >\n <span className=\"text-sm font-medium\">{searchButtonText}</span>\n </button>\n )}\n </div>\n\n {errorMessage && (\n <p\n className=\"text-xs flex items-center gap-1\"\n style={{ color: 'var(--lm-error-500)' }}\n >\n <svg className=\"w-3 h-3\" fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path\n fillRule=\"evenodd\"\n d=\"M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z\"\n clipRule=\"evenodd\"\n />\n </svg>\n {errorMessage}\n </p>\n )}\n </div>\n )\n}\n\nexport default LMSearchInput\n"],"names":["useState","useRef","useEffect","SIZE_INPUT_CONFIG","jsx","jsxs"],"mappings":"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"}
@@ -0,0 +1,309 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import { useState, useRef, useEffect } from "react";
3
+ import { d as SIZE_SELECTOR_CONFIG } from "./componentSizes-CdWNL526.js";
4
+ const SIZE_DROPDOWN_CONFIG = {
5
+ xs: { maxHeight: "max-h-32", optionPadding: "px-3 py-1.5", optionTextSize: "text-xs" },
6
+ sm: { maxHeight: "max-h-40", optionPadding: "px-3 py-2", optionTextSize: "text-xs" },
7
+ md: { maxHeight: "max-h-48", optionPadding: "px-4 py-2.5", optionTextSize: "text-sm" },
8
+ lg: { maxHeight: "max-h-56", optionPadding: "px-4 py-3", optionTextSize: "text-sm" },
9
+ xl: { maxHeight: "max-h-64", optionPadding: "px-5 py-3", optionTextSize: "text-base" },
10
+ "2xl": { maxHeight: "max-h-72", optionPadding: "px-6 py-4", optionTextSize: "text-lg" }
11
+ };
12
+ const LMSelect = ({
13
+ options,
14
+ value,
15
+ onChange,
16
+ onDropdownVisibleChange,
17
+ error = false,
18
+ errorMessage,
19
+ placeholder = "Select...",
20
+ disabled = false,
21
+ className = "",
22
+ name,
23
+ size = "md",
24
+ multiple = false
25
+ }) => {
26
+ const [isOpen, setIsOpen] = useState(false);
27
+ const [selectedOption, setSelectedOption] = useState(null);
28
+ const [selectedOptions, setSelectedOptions] = useState([]);
29
+ const dropdownRef = useRef(null);
30
+ useEffect(() => {
31
+ if (!multiple) {
32
+ if (value !== void 0 && value !== null && !Array.isArray(value)) {
33
+ const option = options.find((opt) => opt.value === value);
34
+ setSelectedOption(option || null);
35
+ } else {
36
+ setSelectedOption(null);
37
+ }
38
+ }
39
+ }, [value, options, multiple]);
40
+ useEffect(() => {
41
+ if (multiple && Array.isArray(value)) {
42
+ const selectedOpts = options.filter((opt) => value.includes(opt.value));
43
+ setSelectedOptions(selectedOpts);
44
+ } else if (multiple) {
45
+ setSelectedOptions([]);
46
+ }
47
+ }, [value, options, multiple]);
48
+ useEffect(() => {
49
+ const handleClickOutside = (event) => {
50
+ if (dropdownRef.current && !dropdownRef.current.contains(event.target)) {
51
+ setIsOpen(false);
52
+ onDropdownVisibleChange == null ? void 0 : onDropdownVisibleChange(false);
53
+ }
54
+ };
55
+ if (isOpen) {
56
+ document.addEventListener("mousedown", handleClickOutside);
57
+ return () => document.removeEventListener("mousedown", handleClickOutside);
58
+ }
59
+ }, [isOpen, onDropdownVisibleChange]);
60
+ const handleSelect = (option) => {
61
+ if (option.disabled) return;
62
+ if (multiple) {
63
+ const currentValues = Array.isArray(value) ? value : [];
64
+ const isSelected = currentValues.includes(option.value);
65
+ const newValues = isSelected ? currentValues.filter((v) => v !== option.value) : [...currentValues, option.value];
66
+ onChange == null ? void 0 : onChange(newValues);
67
+ } else {
68
+ setSelectedOption(option);
69
+ onChange == null ? void 0 : onChange(option.value);
70
+ setIsOpen(false);
71
+ onDropdownVisibleChange == null ? void 0 : onDropdownVisibleChange(false);
72
+ }
73
+ };
74
+ const toggleDropdown = () => {
75
+ if (!disabled) {
76
+ const newIsOpen = !isOpen;
77
+ setIsOpen(newIsOpen);
78
+ onDropdownVisibleChange == null ? void 0 : onDropdownVisibleChange(newIsOpen);
79
+ }
80
+ };
81
+ const baseClassName = `
82
+ w-full ${SIZE_SELECTOR_CONFIG[size].padding} ${SIZE_SELECTOR_CONFIG[size].height} ${SIZE_SELECTOR_CONFIG[size].fontSize}
83
+ border rounded-xl
84
+ cursor-pointer select-none
85
+ flex items-center justify-between
86
+ ${className}
87
+ `.trim().replace(/\s+/g, " ");
88
+ const getSelectorStyles = () => {
89
+ const baseStyles = {
90
+ backgroundColor: "var(--lm-bg-elevated)",
91
+ color: "var(--lm-text-primary)",
92
+ borderColor: error ? "var(--lm-error-300)" : "var(--lm-border-default)",
93
+ boxShadow: "var(--lm-shadow-sm)",
94
+ transition: "all var(--lm-transition-fast) var(--lm-ease-out)"
95
+ };
96
+ return {
97
+ ...baseStyles,
98
+ "--tw-ring-color": error ? "var(--lm-error-400)" : "var(--lm-primary-400)",
99
+ "--tw-ring-opacity": "0.4"
100
+ };
101
+ };
102
+ const getDisabledStyles = () => disabled ? {
103
+ backgroundColor: "var(--lm-bg-paper)",
104
+ color: "var(--lm-text-disabled)",
105
+ cursor: "not-allowed",
106
+ opacity: 0.6
107
+ } : {};
108
+ const getIconStyles = () => error ? { color: "var(--lm-error-400)" } : { color: "var(--lm-text-secondary)" };
109
+ const getDropdownStyles = () => ({
110
+ backgroundColor: "var(--lm-bg-elevated)",
111
+ borderColor: "var(--lm-border-default)",
112
+ boxShadow: "var(--lm-shadow-lg)",
113
+ backdropFilter: "blur(20px) saturate(180%)",
114
+ WebkitBackdropFilter: "blur(20px) saturate(180%)"
115
+ });
116
+ const isOptionSelected = (optionValue) => {
117
+ if (multiple) {
118
+ return Array.isArray(value) && value.includes(optionValue);
119
+ }
120
+ return (selectedOption == null ? void 0 : selectedOption.value) === optionValue;
121
+ };
122
+ const getOptionStyles = (option) => {
123
+ const baseStyles = {
124
+ color: option.disabled ? "var(--lm-text-disabled)" : "var(--lm-text-primary)",
125
+ backgroundColor: option.disabled ? "var(--lm-bg-paper)" : "transparent"
126
+ };
127
+ if (isOptionSelected(option.value)) {
128
+ return {
129
+ ...baseStyles,
130
+ backgroundColor: "var(--lm-primary-50)",
131
+ color: "var(--lm-primary-700)"
132
+ };
133
+ }
134
+ return baseStyles;
135
+ };
136
+ const getHoverOptionStyles = (option) => {
137
+ if (option.disabled) return {};
138
+ if (isOptionSelected(option.value)) {
139
+ return { backgroundColor: "var(--lm-primary-100)" };
140
+ }
141
+ return { backgroundColor: "var(--lm-bg-paper)" };
142
+ };
143
+ const getDisplayText = () => {
144
+ if (multiple) {
145
+ if (selectedOptions.length === 0) return placeholder;
146
+ if (selectedOptions.length === 1) return selectedOptions[0].label;
147
+ return `${selectedOptions.length} selected`;
148
+ }
149
+ return selectedOption ? selectedOption.label : placeholder;
150
+ };
151
+ const ChevronDown = () => /* @__PURE__ */ jsx(
152
+ "svg",
153
+ {
154
+ className: `w-4 h-4 transition-transform duration-200 ${isOpen ? "rotate-180" : ""}`,
155
+ fill: "none",
156
+ stroke: "currentColor",
157
+ viewBox: "0 0 24 24",
158
+ style: getIconStyles(),
159
+ children: /* @__PURE__ */ jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M19 9l-7 7-7-7" })
160
+ }
161
+ );
162
+ const CheckIcon = () => /* @__PURE__ */ jsx("svg", { className: "w-4 h-4", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: /* @__PURE__ */ jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M5 13l4 4L19 7" }) });
163
+ return /* @__PURE__ */ jsxs("div", { className: "relative", ref: dropdownRef, children: [
164
+ /* @__PURE__ */ jsx(
165
+ "select",
166
+ {
167
+ name,
168
+ value: multiple ? Array.isArray(value) ? value.map(String) : [] : value !== void 0 && value !== null && !Array.isArray(value) ? String(value) : "",
169
+ onChange: () => {
170
+ },
171
+ className: "sr-only",
172
+ disabled,
173
+ tabIndex: -1,
174
+ multiple,
175
+ children: options.map((option) => /* @__PURE__ */ jsx("option", { value: option.value, disabled: option.disabled, children: option.label }, option.value))
176
+ }
177
+ ),
178
+ /* @__PURE__ */ jsxs(
179
+ "div",
180
+ {
181
+ className: baseClassName,
182
+ onClick: toggleDropdown,
183
+ role: "button",
184
+ tabIndex: disabled ? -1 : 0,
185
+ style: {
186
+ ...getSelectorStyles(),
187
+ ...getDisabledStyles()
188
+ },
189
+ onMouseEnter: (e) => {
190
+ if (!disabled && !error) {
191
+ e.currentTarget.style.borderColor = "var(--lm-border-strong)";
192
+ }
193
+ },
194
+ onMouseLeave: (e) => {
195
+ if (!disabled && !error) {
196
+ e.currentTarget.style.borderColor = "var(--lm-border-default)";
197
+ }
198
+ },
199
+ onFocus: (e) => {
200
+ if (!disabled) {
201
+ e.currentTarget.style.borderColor = error ? "var(--lm-error-400)" : "var(--lm-primary-400)";
202
+ }
203
+ },
204
+ onBlur: (e) => {
205
+ if (!disabled) {
206
+ e.currentTarget.style.borderColor = error ? "var(--lm-error-300)" : "var(--lm-border-default)";
207
+ }
208
+ },
209
+ onKeyDown: (e) => {
210
+ if (e.key === "Enter" || e.key === " ") {
211
+ e.preventDefault();
212
+ toggleDropdown();
213
+ }
214
+ },
215
+ children: [
216
+ /* @__PURE__ */ jsx(
217
+ "span",
218
+ {
219
+ style: {
220
+ color: multiple && selectedOptions.length > 0 || selectedOption ? "var(--lm-text-primary)" : "var(--lm-text-secondary)"
221
+ },
222
+ children: getDisplayText()
223
+ }
224
+ ),
225
+ /* @__PURE__ */ jsx(ChevronDown, {})
226
+ ]
227
+ }
228
+ ),
229
+ isOpen && /* @__PURE__ */ jsx(
230
+ "div",
231
+ {
232
+ className: `absolute left-0 right-0 z-50 border rounded-xl overflow-y-auto ${SIZE_DROPDOWN_CONFIG[size].maxHeight}`,
233
+ style: {
234
+ ...getDropdownStyles(),
235
+ top: "calc(100% + 4px)"
236
+ },
237
+ children: options.map((option, index) => /* @__PURE__ */ jsx(
238
+ "div",
239
+ {
240
+ className: `
241
+ ${SIZE_DROPDOWN_CONFIG[size].optionPadding} ${SIZE_DROPDOWN_CONFIG[size].optionTextSize} font-medium
242
+ cursor-pointer transition-all duration-150
243
+ ${option.disabled ? "cursor-not-allowed" : ""}
244
+ ${index === 0 ? "rounded-t-xl" : ""}
245
+ ${index === options.length - 1 ? "rounded-b-xl" : ""}
246
+ ${index > 0 ? "border-t" : ""}
247
+ `,
248
+ style: {
249
+ ...getOptionStyles(option),
250
+ borderTopColor: index > 0 ? "var(--lm-border-light)" : "transparent"
251
+ },
252
+ onMouseEnter: (e) => {
253
+ if (!option.disabled) {
254
+ Object.assign(e.currentTarget.style, getHoverOptionStyles(option));
255
+ }
256
+ },
257
+ onMouseLeave: (e) => {
258
+ if (!option.disabled) {
259
+ Object.assign(e.currentTarget.style, getOptionStyles(option));
260
+ }
261
+ },
262
+ onClick: () => handleSelect(option),
263
+ role: "option",
264
+ "aria-selected": isOptionSelected(option.value),
265
+ children: /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between", children: [
266
+ multiple && /* @__PURE__ */ jsx(
267
+ "input",
268
+ {
269
+ type: "checkbox",
270
+ checked: isOptionSelected(option.value),
271
+ onChange: () => {
272
+ },
273
+ className: "mr-2 cursor-pointer",
274
+ style: { accentColor: "var(--lm-primary-500)" },
275
+ onClick: (e) => e.stopPropagation()
276
+ }
277
+ ),
278
+ /* @__PURE__ */ jsx("span", { className: "truncate flex-1", children: option.label }),
279
+ !multiple && isOptionSelected(option.value) && /* @__PURE__ */ jsx("span", { className: "ml-2 shrink-0", style: { color: "var(--lm-primary-600)" }, children: /* @__PURE__ */ jsx(CheckIcon, {}) })
280
+ ] })
281
+ },
282
+ option.value
283
+ ))
284
+ }
285
+ ),
286
+ errorMessage && /* @__PURE__ */ jsxs(
287
+ "p",
288
+ {
289
+ className: "text-xs flex items-center gap-1 mt-2",
290
+ style: { color: "var(--lm-error-500)" },
291
+ children: [
292
+ /* @__PURE__ */ jsx("svg", { className: "w-3 h-3", fill: "currentColor", viewBox: "0 0 20 20", children: /* @__PURE__ */ jsx(
293
+ "path",
294
+ {
295
+ fillRule: "evenodd",
296
+ d: "M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z",
297
+ clipRule: "evenodd"
298
+ }
299
+ ) }),
300
+ errorMessage
301
+ ]
302
+ }
303
+ )
304
+ ] });
305
+ };
306
+ export {
307
+ LMSelect as L
308
+ };
309
+ //# sourceMappingURL=LMSelect-B-MWX2JI.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LMSelect-B-MWX2JI.js","sources":["../src/components/Form/LMSelect/LMSelect.tsx"],"sourcesContent":["import React, { useState, useRef, useEffect } from 'react'\nimport { SIZE_SELECTOR_CONFIG } from '../../../utils/componentSizes'\nimport type { ComponentSize } from '../../../utils/componentSizes'\n\nexport interface LMSelectOption {\n value: string | number\n label: string\n disabled?: boolean\n}\n\nexport interface LMSelectProps {\n /** Options */\n options: LMSelectOption[]\n /** Current value */\n value?: string | number | (string | number)[]\n /** Change callback */\n onChange?: (value: string | number | (string | number)[]) => void\n /** Dropdown visibility change callback */\n onDropdownVisibleChange?: (visible: boolean) => void\n /** Error state */\n error?: boolean\n /** Error message */\n errorMessage?: string\n /** Placeholder */\n placeholder?: string\n /** Disabled state */\n disabled?: boolean\n /** Class name */\n className?: string\n /** Form field name */\n name?: string\n /** Size */\n size?: ComponentSize\n /** Multiple selection */\n multiple?: boolean\n}\n\nconst SIZE_DROPDOWN_CONFIG: Record<\n ComponentSize,\n {\n maxHeight: string\n optionPadding: string\n optionTextSize: string\n }\n> = {\n xs: { maxHeight: 'max-h-32', optionPadding: 'px-3 py-1.5', optionTextSize: 'text-xs' },\n sm: { maxHeight: 'max-h-40', optionPadding: 'px-3 py-2', optionTextSize: 'text-xs' },\n md: { maxHeight: 'max-h-48', optionPadding: 'px-4 py-2.5', optionTextSize: 'text-sm' },\n lg: { maxHeight: 'max-h-56', optionPadding: 'px-4 py-3', optionTextSize: 'text-sm' },\n xl: { maxHeight: 'max-h-64', optionPadding: 'px-5 py-3', optionTextSize: 'text-base' },\n '2xl': { maxHeight: 'max-h-72', optionPadding: 'px-6 py-4', optionTextSize: 'text-lg' },\n}\n\nconst LMSelect: React.FC<LMSelectProps> = ({\n options,\n value,\n onChange,\n onDropdownVisibleChange,\n error = false,\n errorMessage,\n placeholder = 'Select...',\n disabled = false,\n className = '',\n name,\n size = 'md',\n multiple = false,\n}) => {\n const [isOpen, setIsOpen] = useState(false)\n const [selectedOption, setSelectedOption] = useState<LMSelectOption | null>(null)\n const [selectedOptions, setSelectedOptions] = useState<LMSelectOption[]>([])\n const dropdownRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n if (!multiple) {\n if (value !== undefined && value !== null && !Array.isArray(value)) {\n const option = options.find((opt) => opt.value === value)\n setSelectedOption(option || null)\n } else {\n setSelectedOption(null)\n }\n }\n }, [value, options, multiple])\n\n useEffect(() => {\n if (multiple && Array.isArray(value)) {\n const selectedOpts = options.filter((opt) => value.includes(opt.value))\n setSelectedOptions(selectedOpts)\n } else if (multiple) {\n setSelectedOptions([])\n }\n }, [value, options, multiple])\n\n useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (dropdownRef.current && !dropdownRef.current.contains(event.target as Node)) {\n setIsOpen(false)\n onDropdownVisibleChange?.(false)\n }\n }\n\n if (isOpen) {\n document.addEventListener('mousedown', handleClickOutside)\n return () => document.removeEventListener('mousedown', handleClickOutside)\n }\n }, [isOpen, onDropdownVisibleChange])\n\n const handleSelect = (option: LMSelectOption) => {\n if (option.disabled) return\n\n if (multiple) {\n const currentValues = Array.isArray(value) ? value : []\n const isSelected = currentValues.includes(option.value)\n const newValues = isSelected\n ? currentValues.filter((v) => v !== option.value)\n : [...currentValues, option.value]\n onChange?.(newValues)\n } else {\n setSelectedOption(option)\n onChange?.(option.value)\n setIsOpen(false)\n onDropdownVisibleChange?.(false)\n }\n }\n\n const toggleDropdown = () => {\n if (!disabled) {\n const newIsOpen = !isOpen\n setIsOpen(newIsOpen)\n onDropdownVisibleChange?.(newIsOpen)\n }\n }\n\n // Apple-like refined select styling\n const baseClassName = `\n w-full ${SIZE_SELECTOR_CONFIG[size].padding} ${SIZE_SELECTOR_CONFIG[size].height} ${SIZE_SELECTOR_CONFIG[size].fontSize}\n border rounded-xl\n cursor-pointer select-none\n flex items-center justify-between\n ${className}\n `\n .trim()\n .replace(/\\s+/g, ' ')\n\n const getSelectorStyles = () => {\n // Apple-like refined select styles\n const baseStyles = {\n backgroundColor: 'var(--lm-bg-elevated)',\n color: 'var(--lm-text-primary)',\n borderColor: error ? 'var(--lm-error-300)' : 'var(--lm-border-default)',\n boxShadow: 'var(--lm-shadow-sm)',\n transition: 'all var(--lm-transition-fast) var(--lm-ease-out)',\n }\n\n return {\n ...baseStyles,\n '--tw-ring-color': error ? 'var(--lm-error-400)' : 'var(--lm-primary-400)',\n '--tw-ring-opacity': '0.4',\n }\n }\n\n const getDisabledStyles = () =>\n disabled\n ? {\n backgroundColor: 'var(--lm-bg-paper)',\n color: 'var(--lm-text-disabled)',\n cursor: 'not-allowed',\n opacity: 0.6,\n }\n : {}\n\n const getIconStyles = () =>\n error ? { color: 'var(--lm-error-400)' } : { color: 'var(--lm-text-secondary)' }\n\n // Apple-like refined dropdown styles\n const getDropdownStyles = () => ({\n backgroundColor: 'var(--lm-bg-elevated)',\n borderColor: 'var(--lm-border-default)',\n boxShadow: 'var(--lm-shadow-lg)',\n backdropFilter: 'blur(20px) saturate(180%)',\n WebkitBackdropFilter: 'blur(20px) saturate(180%)',\n })\n\n const isOptionSelected = (optionValue: string | number): boolean => {\n if (multiple) {\n return Array.isArray(value) && value.includes(optionValue)\n }\n return selectedOption?.value === optionValue\n }\n\n const getOptionStyles = (option: LMSelectOption) => {\n const baseStyles = {\n color: option.disabled ? 'var(--lm-text-disabled)' : 'var(--lm-text-primary)',\n backgroundColor: option.disabled ? 'var(--lm-bg-paper)' : 'transparent',\n }\n\n if (isOptionSelected(option.value)) {\n return {\n ...baseStyles,\n backgroundColor: 'var(--lm-primary-50)',\n color: 'var(--lm-primary-700)',\n }\n }\n\n return baseStyles\n }\n\n const getHoverOptionStyles = (option: LMSelectOption) => {\n if (option.disabled) return {}\n\n if (isOptionSelected(option.value)) {\n return { backgroundColor: 'var(--lm-primary-100)' }\n }\n\n return { backgroundColor: 'var(--lm-bg-paper)' }\n }\n\n const getDisplayText = (): string => {\n if (multiple) {\n if (selectedOptions.length === 0) return placeholder\n if (selectedOptions.length === 1) return selectedOptions[0].label\n return `${selectedOptions.length} selected`\n }\n return selectedOption ? selectedOption.label : placeholder\n }\n\n const ChevronDown = () => (\n <svg\n className={`w-4 h-4 transition-transform duration-200 ${isOpen ? 'rotate-180' : ''}`}\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n style={getIconStyles()}\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M19 9l-7 7-7-7\" />\n </svg>\n )\n\n const CheckIcon = () => (\n <svg className=\"w-4 h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M5 13l4 4L19 7\" />\n </svg>\n )\n\n return (\n <div className=\"relative\" ref={dropdownRef}>\n <select\n name={name}\n value={\n multiple\n ? Array.isArray(value)\n ? value.map(String)\n : []\n : value !== undefined && value !== null && !Array.isArray(value)\n ? String(value)\n : ''\n }\n onChange={() => {}}\n className=\"sr-only\"\n disabled={disabled}\n tabIndex={-1}\n multiple={multiple}\n >\n {options.map((option) => (\n <option key={option.value} value={option.value} disabled={option.disabled}>\n {option.label}\n </option>\n ))}\n </select>\n\n <div\n className={baseClassName}\n onClick={toggleDropdown}\n role=\"button\"\n tabIndex={disabled ? -1 : 0}\n style={{\n ...getSelectorStyles(),\n ...getDisabledStyles(),\n } as React.CSSProperties}\n onMouseEnter={(e) => {\n if (!disabled && !error) {\n e.currentTarget.style.borderColor = 'var(--lm-border-strong)'\n }\n }}\n onMouseLeave={(e) => {\n if (!disabled && !error) {\n e.currentTarget.style.borderColor = 'var(--lm-border-default)'\n }\n }}\n onFocus={(e) => {\n if (!disabled) {\n e.currentTarget.style.borderColor = error\n ? 'var(--lm-error-400)'\n : 'var(--lm-primary-400)'\n }\n }}\n onBlur={(e) => {\n if (!disabled) {\n e.currentTarget.style.borderColor = error\n ? 'var(--lm-error-300)'\n : 'var(--lm-border-default)'\n }\n }}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n toggleDropdown()\n }\n }}\n >\n <span\n style={{\n color:\n (multiple && selectedOptions.length > 0) || selectedOption\n ? 'var(--lm-text-primary)'\n : 'var(--lm-text-secondary)',\n }}\n >\n {getDisplayText()}\n </span>\n <ChevronDown />\n </div>\n\n {isOpen && (\n <div\n className={`absolute left-0 right-0 z-50 border rounded-xl overflow-y-auto ${SIZE_DROPDOWN_CONFIG[size].maxHeight}`}\n style={{\n ...getDropdownStyles(),\n top: 'calc(100% + 4px)',\n }}\n >\n {options.map((option, index) => (\n <div\n key={option.value}\n className={`\n ${SIZE_DROPDOWN_CONFIG[size].optionPadding} ${SIZE_DROPDOWN_CONFIG[size].optionTextSize} font-medium\n cursor-pointer transition-all duration-150\n ${option.disabled ? 'cursor-not-allowed' : ''}\n ${index === 0 ? 'rounded-t-xl' : ''}\n ${index === options.length - 1 ? 'rounded-b-xl' : ''}\n ${index > 0 ? 'border-t' : ''}\n `}\n style={{\n ...getOptionStyles(option),\n borderTopColor: index > 0 ? 'var(--lm-border-light)' : 'transparent',\n }}\n onMouseEnter={(e) => {\n if (!option.disabled) {\n Object.assign(e.currentTarget.style, getHoverOptionStyles(option))\n }\n }}\n onMouseLeave={(e) => {\n if (!option.disabled) {\n Object.assign(e.currentTarget.style, getOptionStyles(option))\n }\n }}\n onClick={() => handleSelect(option)}\n role=\"option\"\n aria-selected={isOptionSelected(option.value)}\n >\n <div className=\"flex items-center justify-between\">\n {multiple && (\n <input\n type=\"checkbox\"\n checked={isOptionSelected(option.value)}\n onChange={() => {}}\n className=\"mr-2 cursor-pointer\"\n style={{ accentColor: 'var(--lm-primary-500)' }}\n onClick={(e) => e.stopPropagation()}\n />\n )}\n <span className=\"truncate flex-1\">{option.label}</span>\n {!multiple && isOptionSelected(option.value) && (\n <span className=\"ml-2 shrink-0\" style={{ color: 'var(--lm-primary-600)' }}>\n <CheckIcon />\n </span>\n )}\n </div>\n </div>\n ))}\n </div>\n )}\n\n {errorMessage && (\n <p\n className=\"text-xs flex items-center gap-1 mt-2\"\n style={{ color: 'var(--lm-error-500)' }}\n >\n <svg className=\"w-3 h-3\" fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path\n fillRule=\"evenodd\"\n d=\"M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z\"\n clipRule=\"evenodd\"\n />\n </svg>\n {errorMessage}\n </p>\n )}\n </div>\n )\n}\n\nexport default LMSelect\n"],"names":[],"mappings":"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"}