lumen-plus 0.0.1

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 (434) hide show
  1. package/dist/components/Affix/Affix.svelte +97 -0
  2. package/dist/components/Affix/Affix.svelte.d.ts +14 -0
  3. package/dist/components/Affix/index.d.ts +4 -0
  4. package/dist/components/Affix/index.js +3 -0
  5. package/dist/components/Affix/types.d.ts +11 -0
  6. package/dist/components/Affix/types.js +1 -0
  7. package/dist/components/Alert/Alert.svelte +77 -0
  8. package/dist/components/Alert/Alert.svelte.d.ts +16 -0
  9. package/dist/components/Alert/index.d.ts +4 -0
  10. package/dist/components/Alert/index.js +3 -0
  11. package/dist/components/Alert/types.d.ts +23 -0
  12. package/dist/components/Alert/types.js +1 -0
  13. package/dist/components/Autocomplete/Autocomplete.svelte +163 -0
  14. package/dist/components/Autocomplete/Autocomplete.svelte.d.ts +20 -0
  15. package/dist/components/Autocomplete/index.d.ts +3 -0
  16. package/dist/components/Autocomplete/index.js +3 -0
  17. package/dist/components/Avatar/Avatar.svelte +50 -0
  18. package/dist/components/Avatar/Avatar.svelte.d.ts +14 -0
  19. package/dist/components/Avatar/index.d.ts +4 -0
  20. package/dist/components/Avatar/index.js +3 -0
  21. package/dist/components/Avatar/types.d.ts +26 -0
  22. package/dist/components/Avatar/types.js +1 -0
  23. package/dist/components/Backtop/Backtop.svelte +60 -0
  24. package/dist/components/Backtop/Backtop.svelte.d.ts +13 -0
  25. package/dist/components/Backtop/index.d.ts +4 -0
  26. package/dist/components/Backtop/index.js +3 -0
  27. package/dist/components/Backtop/types.d.ts +18 -0
  28. package/dist/components/Backtop/types.js +1 -0
  29. package/dist/components/Badge/Badge.svelte +53 -0
  30. package/dist/components/Badge/Badge.svelte.d.ts +13 -0
  31. package/dist/components/Badge/index.d.ts +4 -0
  32. package/dist/components/Badge/index.js +3 -0
  33. package/dist/components/Badge/types.d.ts +20 -0
  34. package/dist/components/Badge/types.js +1 -0
  35. package/dist/components/Breadcrumb/Breadcrumb.svelte +35 -0
  36. package/dist/components/Breadcrumb/Breadcrumb.svelte.d.ts +6 -0
  37. package/dist/components/Breadcrumb/index.d.ts +4 -0
  38. package/dist/components/Breadcrumb/index.js +3 -0
  39. package/dist/components/Breadcrumb/types.d.ts +10 -0
  40. package/dist/components/Breadcrumb/types.js +1 -0
  41. package/dist/components/Button/Button.svelte +61 -0
  42. package/dist/components/Button/Button.svelte.d.ts +5 -0
  43. package/dist/components/Button/index.d.ts +4 -0
  44. package/dist/components/Button/index.js +3 -0
  45. package/dist/components/Button/types.d.ts +42 -0
  46. package/dist/components/Button/types.js +1 -0
  47. package/dist/components/Calendar/Calendar.svelte +115 -0
  48. package/dist/components/Calendar/Calendar.svelte.d.ts +7 -0
  49. package/dist/components/Calendar/index.d.ts +3 -0
  50. package/dist/components/Calendar/index.js +3 -0
  51. package/dist/components/Card/Card.svelte +59 -0
  52. package/dist/components/Card/Card.svelte.d.ts +4 -0
  53. package/dist/components/Card/index.d.ts +4 -0
  54. package/dist/components/Card/index.js +4 -0
  55. package/dist/components/Card/types.d.ts +26 -0
  56. package/dist/components/Card/types.js +1 -0
  57. package/dist/components/Carousel/Carousel.svelte +158 -0
  58. package/dist/components/Carousel/Carousel.svelte.d.ts +19 -0
  59. package/dist/components/Carousel/CarouselContext.d.ts +6 -0
  60. package/dist/components/Carousel/CarouselContext.js +1 -0
  61. package/dist/components/Carousel/CarouselItem.svelte +26 -0
  62. package/dist/components/Carousel/CarouselItem.svelte.d.ts +11 -0
  63. package/dist/components/Carousel/index.d.ts +5 -0
  64. package/dist/components/Carousel/index.js +4 -0
  65. package/dist/components/Carousel/types.d.ts +43 -0
  66. package/dist/components/Carousel/types.js +1 -0
  67. package/dist/components/Cascader/Cascader.svelte +191 -0
  68. package/dist/components/Cascader/Cascader.svelte.d.ts +4 -0
  69. package/dist/components/Cascader/index.d.ts +4 -0
  70. package/dist/components/Cascader/index.js +3 -0
  71. package/dist/components/Cascader/types.d.ts +19 -0
  72. package/dist/components/Cascader/types.js +1 -0
  73. package/dist/components/Checkbox/Checkbox.svelte +55 -0
  74. package/dist/components/Checkbox/Checkbox.svelte.d.ts +16 -0
  75. package/dist/components/Checkbox/index.d.ts +4 -0
  76. package/dist/components/Checkbox/index.js +3 -0
  77. package/dist/components/Checkbox/types.d.ts +24 -0
  78. package/dist/components/Checkbox/types.js +1 -0
  79. package/dist/components/Collapse/Collapse.svelte +48 -0
  80. package/dist/components/Collapse/Collapse.svelte.d.ts +11 -0
  81. package/dist/components/Collapse/CollapseContext.d.ts +6 -0
  82. package/dist/components/Collapse/CollapseContext.js +1 -0
  83. package/dist/components/Collapse/CollapseItem.svelte +133 -0
  84. package/dist/components/Collapse/CollapseItem.svelte.d.ts +11 -0
  85. package/dist/components/Collapse/index.d.ts +5 -0
  86. package/dist/components/Collapse/index.js +4 -0
  87. package/dist/components/Collapse/types.d.ts +27 -0
  88. package/dist/components/Collapse/types.js +1 -0
  89. package/dist/components/ColorPicker/ColorPicker.svelte +112 -0
  90. package/dist/components/ColorPicker/ColorPicker.svelte.d.ts +12 -0
  91. package/dist/components/ColorPicker/index.d.ts +4 -0
  92. package/dist/components/ColorPicker/index.js +3 -0
  93. package/dist/components/ColorPicker/types.d.ts +17 -0
  94. package/dist/components/ColorPicker/types.js +1 -0
  95. package/dist/components/Container/Aside.svelte +20 -0
  96. package/dist/components/Container/Aside.svelte.d.ts +9 -0
  97. package/dist/components/Container/Container.svelte +19 -0
  98. package/dist/components/Container/Container.svelte.d.ts +9 -0
  99. package/dist/components/Container/Footer.svelte +20 -0
  100. package/dist/components/Container/Footer.svelte.d.ts +9 -0
  101. package/dist/components/Container/Header.svelte +20 -0
  102. package/dist/components/Container/Header.svelte.d.ts +9 -0
  103. package/dist/components/Container/Main.svelte +18 -0
  104. package/dist/components/Container/Main.svelte.d.ts +8 -0
  105. package/dist/components/Container/index.d.ts +6 -0
  106. package/dist/components/Container/index.js +5 -0
  107. package/dist/components/Container/types.d.ts +46 -0
  108. package/dist/components/Container/types.js +1 -0
  109. package/dist/components/DatePicker/DatePicker.svelte +206 -0
  110. package/dist/components/DatePicker/DatePicker.svelte.d.ts +17 -0
  111. package/dist/components/DatePicker/index.d.ts +4 -0
  112. package/dist/components/DatePicker/index.js +3 -0
  113. package/dist/components/DatePicker/types.d.ts +29 -0
  114. package/dist/components/DatePicker/types.js +1 -0
  115. package/dist/components/DateTimePicker/DateTimePicker.svelte +387 -0
  116. package/dist/components/DateTimePicker/DateTimePicker.svelte.d.ts +4 -0
  117. package/dist/components/DateTimePicker/index.d.ts +4 -0
  118. package/dist/components/DateTimePicker/index.js +3 -0
  119. package/dist/components/DateTimePicker/types.d.ts +21 -0
  120. package/dist/components/DateTimePicker/types.js +1 -0
  121. package/dist/components/Descriptions/Descriptions.svelte +69 -0
  122. package/dist/components/Descriptions/Descriptions.svelte.d.ts +15 -0
  123. package/dist/components/Descriptions/DescriptionsContext.d.ts +8 -0
  124. package/dist/components/Descriptions/DescriptionsContext.js +1 -0
  125. package/dist/components/Descriptions/DescriptionsItem.svelte +59 -0
  126. package/dist/components/Descriptions/DescriptionsItem.svelte.d.ts +13 -0
  127. package/dist/components/Descriptions/index.d.ts +5 -0
  128. package/dist/components/Descriptions/index.js +4 -0
  129. package/dist/components/Descriptions/types.d.ts +41 -0
  130. package/dist/components/Descriptions/types.js +1 -0
  131. package/dist/components/Dialog/Dialog.svelte +122 -0
  132. package/dist/components/Dialog/Dialog.svelte.d.ts +20 -0
  133. package/dist/components/Dialog/index.d.ts +4 -0
  134. package/dist/components/Dialog/index.js +3 -0
  135. package/dist/components/Dialog/types.d.ts +32 -0
  136. package/dist/components/Dialog/types.js +1 -0
  137. package/dist/components/Divider/Divider.svelte +23 -0
  138. package/dist/components/Divider/Divider.svelte.d.ts +11 -0
  139. package/dist/components/Divider/index.d.ts +4 -0
  140. package/dist/components/Divider/index.js +3 -0
  141. package/dist/components/Divider/types.d.ts +20 -0
  142. package/dist/components/Divider/types.js +1 -0
  143. package/dist/components/Drawer/Drawer.svelte +141 -0
  144. package/dist/components/Drawer/Drawer.svelte.d.ts +26 -0
  145. package/dist/components/Drawer/index.d.ts +4 -0
  146. package/dist/components/Drawer/index.js +3 -0
  147. package/dist/components/Drawer/types.d.ts +40 -0
  148. package/dist/components/Drawer/types.js +1 -0
  149. package/dist/components/Dropdown/Dropdown.svelte +387 -0
  150. package/dist/components/Dropdown/Dropdown.svelte.d.ts +4 -0
  151. package/dist/components/Dropdown/DropdownContext.d.ts +7 -0
  152. package/dist/components/Dropdown/DropdownContext.js +8 -0
  153. package/dist/components/Dropdown/DropdownItem.svelte +50 -0
  154. package/dist/components/Dropdown/DropdownItem.svelte.d.ts +4 -0
  155. package/dist/components/Dropdown/DropdownMenu.svelte +16 -0
  156. package/dist/components/Dropdown/DropdownMenu.svelte.d.ts +4 -0
  157. package/dist/components/Dropdown/index.d.ts +5 -0
  158. package/dist/components/Dropdown/index.js +5 -0
  159. package/dist/components/Dropdown/types.d.ts +81 -0
  160. package/dist/components/Dropdown/types.js +1 -0
  161. package/dist/components/Empty/Empty.svelte +40 -0
  162. package/dist/components/Empty/Empty.svelte.d.ts +11 -0
  163. package/dist/components/Empty/index.d.ts +4 -0
  164. package/dist/components/Empty/index.js +3 -0
  165. package/dist/components/Empty/types.d.ts +14 -0
  166. package/dist/components/Empty/types.js +1 -0
  167. package/dist/components/Form/Form.svelte +88 -0
  168. package/dist/components/Form/Form.svelte.d.ts +15 -0
  169. package/dist/components/Form/FormContext.d.ts +19 -0
  170. package/dist/components/Form/FormContext.js +1 -0
  171. package/dist/components/Form/FormInternals.d.ts +40 -0
  172. package/dist/components/Form/FormInternals.js +152 -0
  173. package/dist/components/Form/FormItem.svelte +191 -0
  174. package/dist/components/Form/FormItem.svelte.d.ts +8 -0
  175. package/dist/components/Form/index.d.ts +3 -0
  176. package/dist/components/Form/index.js +2 -0
  177. package/dist/components/Form/types.d.ts +61 -0
  178. package/dist/components/Form/types.js +1 -0
  179. package/dist/components/Icon/Icon.svelte +43 -0
  180. package/dist/components/Icon/Icon.svelte.d.ts +12 -0
  181. package/dist/components/Icon/index.d.ts +5 -0
  182. package/dist/components/Icon/index.js +15 -0
  183. package/dist/components/Icon/types.d.ts +14 -0
  184. package/dist/components/Icon/types.js +1 -0
  185. package/dist/components/Image/Image.svelte +134 -0
  186. package/dist/components/Image/Image.svelte.d.ts +20 -0
  187. package/dist/components/Image/index.d.ts +4 -0
  188. package/dist/components/Image/index.js +3 -0
  189. package/dist/components/Image/types.d.ts +32 -0
  190. package/dist/components/Image/types.js +1 -0
  191. package/dist/components/Input/Input.svelte +177 -0
  192. package/dist/components/Input/Input.svelte.d.ts +4 -0
  193. package/dist/components/Input/index.d.ts +4 -0
  194. package/dist/components/Input/index.js +3 -0
  195. package/dist/components/Input/types.d.ts +72 -0
  196. package/dist/components/Input/types.js +1 -0
  197. package/dist/components/InputNumber/InputNumber.svelte +110 -0
  198. package/dist/components/InputNumber/InputNumber.svelte.d.ts +18 -0
  199. package/dist/components/InputNumber/index.d.ts +4 -0
  200. package/dist/components/InputNumber/index.js +3 -0
  201. package/dist/components/InputNumber/types.d.ts +29 -0
  202. package/dist/components/InputNumber/types.js +1 -0
  203. package/dist/components/InputTag/InputTag.svelte +160 -0
  204. package/dist/components/InputTag/InputTag.svelte.d.ts +4 -0
  205. package/dist/components/InputTag/index.d.ts +4 -0
  206. package/dist/components/InputTag/index.js +3 -0
  207. package/dist/components/InputTag/types.d.ts +21 -0
  208. package/dist/components/InputTag/types.js +1 -0
  209. package/dist/components/Link/Link.svelte +38 -0
  210. package/dist/components/Link/Link.svelte.d.ts +15 -0
  211. package/dist/components/Link/index.d.ts +4 -0
  212. package/dist/components/Link/index.js +3 -0
  213. package/dist/components/Link/types.d.ts +26 -0
  214. package/dist/components/Link/types.js +1 -0
  215. package/dist/components/Loading/Loading.svelte +56 -0
  216. package/dist/components/Loading/Loading.svelte.d.ts +15 -0
  217. package/dist/components/Loading/index.d.ts +4 -0
  218. package/dist/components/Loading/index.js +3 -0
  219. package/dist/components/Loading/types.d.ts +20 -0
  220. package/dist/components/Loading/types.js +1 -0
  221. package/dist/components/Menu/Menu.svelte +283 -0
  222. package/dist/components/Menu/Menu.svelte.d.ts +4 -0
  223. package/dist/components/Menu/index.d.ts +4 -0
  224. package/dist/components/Menu/index.js +3 -0
  225. package/dist/components/Menu/types.d.ts +18 -0
  226. package/dist/components/Menu/types.js +1 -0
  227. package/dist/components/Message/MessageBox.svelte +56 -0
  228. package/dist/components/Message/MessageBox.svelte.d.ts +10 -0
  229. package/dist/components/Message/index.d.ts +15 -0
  230. package/dist/components/Message/index.js +102 -0
  231. package/dist/components/Message/types.d.ts +28 -0
  232. package/dist/components/Message/types.js +1 -0
  233. package/dist/components/MessageBox/MessageBox.svelte +85 -0
  234. package/dist/components/MessageBox/MessageBox.svelte.d.ts +7 -0
  235. package/dist/components/MessageBox/index.d.ts +4 -0
  236. package/dist/components/MessageBox/index.js +3 -0
  237. package/dist/components/MessageBox/types.d.ts +21 -0
  238. package/dist/components/MessageBox/types.js +1 -0
  239. package/dist/components/Notification/Notification.svelte +90 -0
  240. package/dist/components/Notification/Notification.svelte.d.ts +7 -0
  241. package/dist/components/Notification/index.d.ts +4 -0
  242. package/dist/components/Notification/index.js +3 -0
  243. package/dist/components/Notification/types.d.ts +24 -0
  244. package/dist/components/Notification/types.js +1 -0
  245. package/dist/components/Pagination/Pagination.svelte +180 -0
  246. package/dist/components/Pagination/Pagination.svelte.d.ts +21 -0
  247. package/dist/components/Pagination/index.d.ts +4 -0
  248. package/dist/components/Pagination/index.js +3 -0
  249. package/dist/components/Pagination/types.d.ts +35 -0
  250. package/dist/components/Pagination/types.js +1 -0
  251. package/dist/components/PinInput/PinInput.svelte +175 -0
  252. package/dist/components/PinInput/PinInput.svelte.d.ts +4 -0
  253. package/dist/components/PinInput/index.d.ts +4 -0
  254. package/dist/components/PinInput/index.js +3 -0
  255. package/dist/components/PinInput/types.d.ts +31 -0
  256. package/dist/components/PinInput/types.js +1 -0
  257. package/dist/components/Popconfirm/Popconfirm.svelte +228 -0
  258. package/dist/components/Popconfirm/Popconfirm.svelte.d.ts +24 -0
  259. package/dist/components/Popconfirm/index.d.ts +4 -0
  260. package/dist/components/Popconfirm/index.js +3 -0
  261. package/dist/components/Popconfirm/types.d.ts +21 -0
  262. package/dist/components/Popconfirm/types.js +1 -0
  263. package/dist/components/Popover/Popover.svelte +176 -0
  264. package/dist/components/Popover/Popover.svelte.d.ts +7 -0
  265. package/dist/components/Popover/index.d.ts +4 -0
  266. package/dist/components/Popover/index.js +3 -0
  267. package/dist/components/Popover/types.d.ts +24 -0
  268. package/dist/components/Popover/types.js +1 -0
  269. package/dist/components/Progress/Progress.svelte +33 -0
  270. package/dist/components/Progress/Progress.svelte.d.ts +11 -0
  271. package/dist/components/Progress/index.d.ts +4 -0
  272. package/dist/components/Progress/index.js +3 -0
  273. package/dist/components/Progress/types.d.ts +17 -0
  274. package/dist/components/Progress/types.js +1 -0
  275. package/dist/components/Radio/Radio.svelte +48 -0
  276. package/dist/components/Radio/Radio.svelte.d.ts +15 -0
  277. package/dist/components/Radio/index.d.ts +4 -0
  278. package/dist/components/Radio/index.js +3 -0
  279. package/dist/components/Radio/types.d.ts +24 -0
  280. package/dist/components/Radio/types.js +1 -0
  281. package/dist/components/Rating/Rating.svelte +226 -0
  282. package/dist/components/Rating/Rating.svelte.d.ts +27 -0
  283. package/dist/components/Rating/index.d.ts +4 -0
  284. package/dist/components/Rating/index.js +3 -0
  285. package/dist/components/Rating/types.d.ts +43 -0
  286. package/dist/components/Rating/types.js +1 -0
  287. package/dist/components/Result/Result.svelte +58 -0
  288. package/dist/components/Result/Result.svelte.d.ts +14 -0
  289. package/dist/components/Result/index.d.ts +4 -0
  290. package/dist/components/Result/index.js +3 -0
  291. package/dist/components/Result/types.d.ts +20 -0
  292. package/dist/components/Result/types.js +1 -0
  293. package/dist/components/Segmented/Segmented.svelte +49 -0
  294. package/dist/components/Segmented/Segmented.svelte.d.ts +12 -0
  295. package/dist/components/Segmented/index.d.ts +4 -0
  296. package/dist/components/Segmented/index.js +3 -0
  297. package/dist/components/Segmented/types.d.ts +29 -0
  298. package/dist/components/Segmented/types.js +1 -0
  299. package/dist/components/Select/Select.svelte +215 -0
  300. package/dist/components/Select/Select.svelte.d.ts +4 -0
  301. package/dist/components/Select/index.d.ts +4 -0
  302. package/dist/components/Select/index.js +3 -0
  303. package/dist/components/Select/types.d.ts +41 -0
  304. package/dist/components/Select/types.js +1 -0
  305. package/dist/components/Skeleton/Skeleton.svelte +44 -0
  306. package/dist/components/Skeleton/Skeleton.svelte.d.ts +13 -0
  307. package/dist/components/Skeleton/SkeletonItem.svelte +14 -0
  308. package/dist/components/Skeleton/SkeletonItem.svelte.d.ts +8 -0
  309. package/dist/components/Skeleton/index.d.ts +5 -0
  310. package/dist/components/Skeleton/index.js +4 -0
  311. package/dist/components/Skeleton/types.d.ts +27 -0
  312. package/dist/components/Skeleton/types.js +1 -0
  313. package/dist/components/Slider/Slider.svelte +292 -0
  314. package/dist/components/Slider/Slider.svelte.d.ts +18 -0
  315. package/dist/components/Slider/index.d.ts +4 -0
  316. package/dist/components/Slider/index.js +3 -0
  317. package/dist/components/Slider/types.d.ts +28 -0
  318. package/dist/components/Slider/types.js +1 -0
  319. package/dist/components/Space/Space.svelte +59 -0
  320. package/dist/components/Space/Space.svelte.d.ts +18 -0
  321. package/dist/components/Space/index.d.ts +4 -0
  322. package/dist/components/Space/index.js +3 -0
  323. package/dist/components/Space/types.d.ts +32 -0
  324. package/dist/components/Space/types.js +1 -0
  325. package/dist/components/Statistic/Countdown.svelte +108 -0
  326. package/dist/components/Statistic/Countdown.svelte.d.ts +14 -0
  327. package/dist/components/Statistic/Statistic.svelte +63 -0
  328. package/dist/components/Statistic/Statistic.svelte.d.ts +15 -0
  329. package/dist/components/Statistic/index.d.ts +5 -0
  330. package/dist/components/Statistic/index.js +4 -0
  331. package/dist/components/Statistic/types.d.ts +41 -0
  332. package/dist/components/Statistic/types.js +1 -0
  333. package/dist/components/Steps/Step.svelte +58 -0
  334. package/dist/components/Steps/Step.svelte.d.ts +14 -0
  335. package/dist/components/Steps/Steps.svelte +60 -0
  336. package/dist/components/Steps/Steps.svelte.d.ts +15 -0
  337. package/dist/components/Steps/StepsContext.d.ts +12 -0
  338. package/dist/components/Steps/StepsContext.js +1 -0
  339. package/dist/components/Steps/index.d.ts +5 -0
  340. package/dist/components/Steps/index.js +4 -0
  341. package/dist/components/Steps/types.d.ts +41 -0
  342. package/dist/components/Steps/types.js +1 -0
  343. package/dist/components/Switch/Switch.svelte +122 -0
  344. package/dist/components/Switch/Switch.svelte.d.ts +22 -0
  345. package/dist/components/Switch/index.d.ts +4 -0
  346. package/dist/components/Switch/index.js +3 -0
  347. package/dist/components/Switch/styles/index.scss +1 -0
  348. package/dist/components/Switch/styles/switch.scss +194 -0
  349. package/dist/components/Switch/types.d.ts +37 -0
  350. package/dist/components/Switch/types.js +1 -0
  351. package/dist/components/Table/Table.svelte +575 -0
  352. package/dist/components/Table/Table.svelte.d.ts +11 -0
  353. package/dist/components/Table/index.d.ts +4 -0
  354. package/dist/components/Table/index.js +3 -0
  355. package/dist/components/Table/types.d.ts +180 -0
  356. package/dist/components/Table/types.js +1 -0
  357. package/dist/components/Tabs/TabPane.svelte +37 -0
  358. package/dist/components/Tabs/TabPane.svelte.d.ts +13 -0
  359. package/dist/components/Tabs/Tabs.svelte +251 -0
  360. package/dist/components/Tabs/Tabs.svelte.d.ts +13 -0
  361. package/dist/components/Tabs/TabsContext.d.ts +11 -0
  362. package/dist/components/Tabs/TabsContext.js +1 -0
  363. package/dist/components/Tabs/index.d.ts +3 -0
  364. package/dist/components/Tabs/index.js +2 -0
  365. package/dist/components/Tabs/types.d.ts +39 -0
  366. package/dist/components/Tabs/types.js +1 -0
  367. package/dist/components/Tag/Tag.svelte +39 -0
  368. package/dist/components/Tag/Tag.svelte.d.ts +13 -0
  369. package/dist/components/Tag/index.d.ts +4 -0
  370. package/dist/components/Tag/index.js +3 -0
  371. package/dist/components/Tag/types.d.ts +22 -0
  372. package/dist/components/Tag/types.js +1 -0
  373. package/dist/components/Textarea/Textarea.svelte +76 -0
  374. package/dist/components/Textarea/Textarea.svelte.d.ts +16 -0
  375. package/dist/components/Textarea/index.d.ts +4 -0
  376. package/dist/components/Textarea/index.js +3 -0
  377. package/dist/components/Textarea/types.d.ts +25 -0
  378. package/dist/components/Textarea/types.js +1 -0
  379. package/dist/components/TimePicker/TimePicker.svelte +297 -0
  380. package/dist/components/TimePicker/TimePicker.svelte.d.ts +14 -0
  381. package/dist/components/TimePicker/index.d.ts +3 -0
  382. package/dist/components/TimePicker/index.js +3 -0
  383. package/dist/components/Timeline/Timeline.svelte +18 -0
  384. package/dist/components/Timeline/Timeline.svelte.d.ts +8 -0
  385. package/dist/components/Timeline/TimelineItem.svelte +67 -0
  386. package/dist/components/Timeline/TimelineItem.svelte.d.ts +18 -0
  387. package/dist/components/Timeline/index.d.ts +5 -0
  388. package/dist/components/Timeline/index.js +4 -0
  389. package/dist/components/Timeline/types.d.ts +39 -0
  390. package/dist/components/Timeline/types.js +1 -0
  391. package/dist/components/Tooltip/OverflowTooltip.svelte +81 -0
  392. package/dist/components/Tooltip/OverflowTooltip.svelte.d.ts +4 -0
  393. package/dist/components/Tooltip/Tooltip.svelte +51 -0
  394. package/dist/components/Tooltip/Tooltip.svelte.d.ts +16 -0
  395. package/dist/components/Tooltip/index.d.ts +6 -0
  396. package/dist/components/Tooltip/index.js +5 -0
  397. package/dist/components/Tooltip/types.d.ts +51 -0
  398. package/dist/components/Tooltip/types.js +1 -0
  399. package/dist/components/Transfer/Transfer.svelte +145 -0
  400. package/dist/components/Transfer/Transfer.svelte.d.ts +14 -0
  401. package/dist/components/Transfer/index.d.ts +4 -0
  402. package/dist/components/Transfer/index.js +3 -0
  403. package/dist/components/Transfer/types.d.ts +16 -0
  404. package/dist/components/Transfer/types.js +1 -0
  405. package/dist/components/Tree/Tree.svelte +148 -0
  406. package/dist/components/Tree/Tree.svelte.d.ts +17 -0
  407. package/dist/components/Tree/TreeNode.svelte +133 -0
  408. package/dist/components/Tree/TreeNode.svelte.d.ts +19 -0
  409. package/dist/components/Tree/index.d.ts +4 -0
  410. package/dist/components/Tree/index.js +3 -0
  411. package/dist/components/Tree/types.d.ts +65 -0
  412. package/dist/components/Tree/types.js +1 -0
  413. package/dist/components/TreeSelect/TreeSelect.svelte +656 -0
  414. package/dist/components/TreeSelect/TreeSelect.svelte.d.ts +4 -0
  415. package/dist/components/TreeSelect/index.d.ts +4 -0
  416. package/dist/components/TreeSelect/index.js +3 -0
  417. package/dist/components/TreeSelect/types.d.ts +98 -0
  418. package/dist/components/TreeSelect/types.js +1 -0
  419. package/dist/components/Upload/Upload.svelte +323 -0
  420. package/dist/components/Upload/Upload.svelte.d.ts +28 -0
  421. package/dist/components/Upload/index.d.ts +4 -0
  422. package/dist/components/Upload/index.js +3 -0
  423. package/dist/components/Upload/types.d.ts +67 -0
  424. package/dist/components/Upload/types.js +1 -0
  425. package/dist/components/Watermark/Watermark.svelte +174 -0
  426. package/dist/components/Watermark/Watermark.svelte.d.ts +20 -0
  427. package/dist/components/Watermark/index.d.ts +4 -0
  428. package/dist/components/Watermark/index.js +3 -0
  429. package/dist/components/Watermark/types.d.ts +32 -0
  430. package/dist/components/Watermark/types.js +1 -0
  431. package/dist/index.d.ts +64 -0
  432. package/dist/index.js +64 -0
  433. package/dist/theme/index.css +9737 -0
  434. package/package.json +51 -0
@@ -0,0 +1,90 @@
1
+ <script lang="ts">
2
+ import Icon from '../Icon'
3
+ import { CheckCircle, AlertTriangle, XCircle, Info, X } from 'lucide'
4
+ import type { IconNode } from 'lucide'
5
+ import type { NotificationItem, NotificationOptions, NotificationType, NotificationPlacement } from './types'
6
+
7
+ interface Props {
8
+ defaultPlacement?: NotificationPlacement
9
+ }
10
+
11
+ let { defaultPlacement = 'top-right' }: Props = $props()
12
+
13
+ let notifications = $state<NotificationItem[]>([])
14
+
15
+ /** 图标映射(静态,避免重复创建) */
16
+ const ICON_MAP: Record<NotificationType, IconNode> = {
17
+ success: CheckCircle,
18
+ warning: AlertTriangle,
19
+ error: XCircle,
20
+ info: Info,
21
+ }
22
+
23
+ /** 根据类型获取图标 */
24
+ const getIcon = (type?: NotificationType): IconNode => ICON_MAP[type || 'info']
25
+
26
+ /** 移除通知 */
27
+ const removeNotification = (id: number): void => {
28
+ notifications = notifications.filter((n) => n.id !== id)
29
+ }
30
+
31
+ /** 添加通知 */
32
+ const addNotification = (options: NotificationOptions): void => {
33
+ const id = Date.now()
34
+ const item: NotificationItem = {
35
+ id,
36
+ type: 'info',
37
+ duration: 4500,
38
+ placement: defaultPlacement,
39
+ ...options,
40
+ }
41
+ notifications = [...notifications, item]
42
+
43
+ if (item.duration && item.duration > 0) {
44
+ setTimeout(() => removeNotification(id), item.duration)
45
+ }
46
+ }
47
+
48
+ /** 按位置分组的通知 */
49
+ const groupedNotifications = $derived.by(() => {
50
+ if (notifications.length === 0) return null
51
+ const groups: Record<string, NotificationItem[]> = {}
52
+ for (const n of notifications) {
53
+ const placement = n.placement || defaultPlacement
54
+ ;(groups[placement] ??= []).push(n)
55
+ }
56
+ return groups
57
+ })
58
+
59
+ // 监听事件
60
+ $effect(() => {
61
+ const handler = (event: CustomEvent<NotificationOptions>): void => {
62
+ addNotification(event.detail)
63
+ }
64
+ window.addEventListener('lumen-notification', handler as EventListener)
65
+ return () => window.removeEventListener('lumen-notification', handler as EventListener)
66
+ })
67
+ </script>
68
+
69
+ {#if groupedNotifications}
70
+ {#each Object.entries(groupedNotifications) as [placement, items] (placement)}
71
+ <div class="lm-notification-container lm-notification-container--{placement}">
72
+ {#each items as notification (notification.id)}
73
+ <div class="lm-notification lm-notification--{notification.type}">
74
+ <div class="lm-notification__content">
75
+ <div class="lm-notification__header">
76
+ <Icon icon={getIcon(notification.type)} size={18} class="lm-notification__icon" />
77
+ {#if notification.title}
78
+ <div class="lm-notification__title">{notification.title}</div>
79
+ {/if}
80
+ </div>
81
+ <div class="lm-notification__message" class:is-with-title={!!notification.title}>{notification.message}</div>
82
+ </div>
83
+ <button type="button" class="lm-notification__close" onclick={() => removeNotification(notification.id)} aria-label="Close">
84
+ <Icon icon={X} size={14} />
85
+ </button>
86
+ </div>
87
+ {/each}
88
+ </div>
89
+ {/each}
90
+ {/if}
@@ -0,0 +1,7 @@
1
+ import type { NotificationPlacement } from './types';
2
+ interface Props {
3
+ defaultPlacement?: NotificationPlacement;
4
+ }
5
+ declare const Notification: import("svelte").Component<Props, {}, "">;
6
+ type Notification = ReturnType<typeof Notification>;
7
+ export default Notification;
@@ -0,0 +1,4 @@
1
+ import Notification from './Notification.svelte';
2
+ export { Notification };
3
+ export type { NotificationOptions, NotificationItem, NotificationType, NotificationPlacement, CloseNotificationFn } from './types';
4
+ export default Notification;
@@ -0,0 +1,3 @@
1
+ import Notification from './Notification.svelte';
2
+ export { Notification };
3
+ export default Notification;
@@ -0,0 +1,24 @@
1
+ /** 通知类型 */
2
+ export type NotificationType = 'success' | 'warning' | 'error' | 'info';
3
+ /** 通知位置 */
4
+ export type NotificationPlacement = 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';
5
+ /** 通知配置选项 */
6
+ export interface NotificationOptions {
7
+ /** 标题 */
8
+ title?: string;
9
+ /** 消息内容 */
10
+ message: string;
11
+ /** 类型 */
12
+ type?: NotificationType;
13
+ /** 显示时间(毫秒) */
14
+ duration?: number;
15
+ /** 显示位置 */
16
+ placement?: NotificationPlacement;
17
+ }
18
+ /** 通知项(内部使用) */
19
+ export interface NotificationItem extends NotificationOptions {
20
+ /** 唯一标识 */
21
+ id: number;
22
+ }
23
+ /** 关闭通知的回调函数类型 */
24
+ export type CloseNotificationFn = (id: number) => void;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,180 @@
1
+ <script lang="ts">
2
+ import type { PaginationLayout } from './types'
3
+ import Icon from '../Icon'
4
+ import Button from '../Button'
5
+ import Select from '../Select'
6
+ import Input from '../Input'
7
+ import { ChevronLeft, ChevronRight } from 'lucide'
8
+
9
+ interface PaginationProps {
10
+ currentPage?: number
11
+ pageSize?: number
12
+ total?: number
13
+ pagerCount?: number
14
+ pageSizes?: number[]
15
+ layout?: PaginationLayout[]
16
+ disabled?: boolean
17
+ hideOnSinglePage?: boolean
18
+ small?: boolean
19
+ background?: boolean
20
+ onchange?: (page: number) => void
21
+ onsizechange?: (size: number) => void
22
+ prevText?: string
23
+ nextText?: string
24
+ class?: string
25
+ }
26
+
27
+ let {
28
+ currentPage = $bindable(1),
29
+ pageSize = $bindable(10),
30
+ total = 0,
31
+ pagerCount = 7,
32
+ pageSizes = [10, 20, 30, 50],
33
+ layout = ['prev', 'pager', 'next'],
34
+ disabled = false,
35
+ hideOnSinglePage = false,
36
+ small = false,
37
+ background = false,
38
+ onchange,
39
+ onsizechange,
40
+ prevText = '',
41
+ nextText = '',
42
+ class: cls = '',
43
+ ...attrs
44
+ }: PaginationProps = $props()
45
+
46
+ let jumperValue = $state('')
47
+
48
+ const totalPages = $derived(Math.max(1, Math.ceil(total / pageSize)))
49
+ const shouldHide = $derived(hideOnSinglePage && totalPages <= 1)
50
+
51
+ // 转换 pageSizes 为 Select 需要的 options 格式
52
+ const sizeOptions = $derived(pageSizes.map(size => ({ value: size, label: `${size} 条/页` })))
53
+
54
+ const pagers = $derived.by(() => {
55
+ const pages: (number | 'prev-more' | 'next-more')[] = []
56
+ const half = Math.floor(pagerCount / 2)
57
+
58
+ if (totalPages <= pagerCount) {
59
+ for (let i = 1; i <= totalPages; i++) pages.push(i)
60
+ } else {
61
+ pages.push(1)
62
+ const start = Math.max(2, currentPage - half + 1)
63
+ const end = Math.min(totalPages - 1, currentPage + half - 1)
64
+
65
+ if (start > 2) pages.push('prev-more')
66
+ for (let i = start; i <= end; i++) pages.push(i)
67
+ if (end < totalPages - 1) pages.push('next-more')
68
+ pages.push(totalPages)
69
+ }
70
+ return pages
71
+ })
72
+
73
+ const goTo = (page: number): void => {
74
+ if (disabled || page < 1 || page > totalPages || page === currentPage) return
75
+ currentPage = page
76
+ onchange?.(page)
77
+ }
78
+
79
+ const handleSizeChange = (newSize: number): void => {
80
+ pageSize = newSize
81
+ currentPage = 1
82
+ onsizechange?.(newSize)
83
+ onchange?.(1)
84
+ }
85
+
86
+ const handleJump = (): void => {
87
+ const page = parseInt(jumperValue, 10)
88
+ if (!isNaN(page)) goTo(Math.min(Math.max(1, page), totalPages))
89
+ jumperValue = ''
90
+ }
91
+
92
+ const handleMoreClick = (type: 'prev-more' | 'next-more'): void => {
93
+ const jump = pagerCount - 2
94
+ goTo(type === 'prev-more' ? Math.max(1, currentPage - jump) : Math.min(totalPages, currentPage + jump))
95
+ }
96
+
97
+ const classes = $derived(`lm-pagination${small ? ' lm-pagination--small' : ''}${background ? ' is-background' : ''}${disabled ? ' is-disabled' : ''}${cls ? ` ${cls}` : ''}`)
98
+ </script>
99
+
100
+ {#if !shouldHide}
101
+ <div class={classes} role="navigation" aria-label="Pagination" {...attrs}>
102
+ {#each layout as item (item)}
103
+ {#if item === 'total'}
104
+ <span class="lm-pagination__total">共 {total} 条</span>
105
+ {:else if item === 'sizes'}
106
+ <Select
107
+ class="lm-pagination__sizes"
108
+ modelValue={pageSize}
109
+ options={sizeOptions}
110
+ size={small ? 'small' : 'default'}
111
+ {disabled}
112
+ onchange={(val) => handleSizeChange(val as number)}
113
+ />
114
+ {:else if item === 'prev'}
115
+ <Button
116
+ class="lm-pagination__btn lm-pagination__btn--prev"
117
+ size={small ? 'small' : 'medium'}
118
+ disabled={disabled || currentPage <= 1}
119
+ onclick={() => goTo(currentPage - 1)}
120
+ aria-label="Previous page"
121
+ >
122
+ {#if prevText}
123
+ {prevText}
124
+ {:else}
125
+ <Icon icon={ChevronLeft} size={16} />
126
+ {/if}
127
+ </Button>
128
+ {:else if item === 'pager'}
129
+ <ul class="lm-pagination__pager">
130
+ {#each pagers as p (p)}
131
+ {#if p === 'prev-more' || p === 'next-more'}
132
+ <li class="lm-pagination__more">
133
+ <Button class="lm-pagination__more-btn" size={small ? 'small' : 'medium'} onclick={() => handleMoreClick(p)}>
134
+ <span class="lm-pagination__ellipsis">...</span>
135
+ </Button>
136
+ </li>
137
+ {:else}
138
+ <li>
139
+ <Button
140
+ class="lm-pagination__number{p === currentPage ? ' is-active' : ''}"
141
+ size={small ? 'small' : 'medium'}
142
+ onclick={() => goTo(p)}
143
+ aria-current={p === currentPage ? 'page' : undefined}
144
+ >
145
+ {p}
146
+ </Button>
147
+ </li>
148
+ {/if}
149
+ {/each}
150
+ </ul>
151
+ {:else if item === 'next'}
152
+ <Button
153
+ class="lm-pagination__btn lm-pagination__btn--next"
154
+ size={small ? 'small' : 'medium'}
155
+ disabled={disabled || currentPage >= totalPages}
156
+ onclick={() => goTo(currentPage + 1)}
157
+ aria-label="Next page"
158
+ >
159
+ {#if nextText}
160
+ {nextText}
161
+ {:else}
162
+ <Icon icon={ChevronRight} size={16} />
163
+ {/if}
164
+ </Button>
165
+ {:else if item === 'jumper'}
166
+ <span class="lm-pagination__jump">
167
+ 前往
168
+ <Input
169
+ class="lm-pagination__editor"
170
+ bind:value={jumperValue}
171
+ size={small ? 'small' : 'medium'}
172
+ {disabled}
173
+ onkeydown={(e) => e.key === 'Enter' && handleJump()}
174
+ />
175
+
176
+ </span>
177
+ {/if}
178
+ {/each}
179
+ </div>
180
+ {/if}
@@ -0,0 +1,21 @@
1
+ import type { PaginationLayout } from './types';
2
+ interface PaginationProps {
3
+ currentPage?: number;
4
+ pageSize?: number;
5
+ total?: number;
6
+ pagerCount?: number;
7
+ pageSizes?: number[];
8
+ layout?: PaginationLayout[];
9
+ disabled?: boolean;
10
+ hideOnSinglePage?: boolean;
11
+ small?: boolean;
12
+ background?: boolean;
13
+ onchange?: (page: number) => void;
14
+ onsizechange?: (size: number) => void;
15
+ prevText?: string;
16
+ nextText?: string;
17
+ class?: string;
18
+ }
19
+ declare const Pagination: import("svelte").Component<PaginationProps, {}, "currentPage" | "pageSize">;
20
+ type Pagination = ReturnType<typeof Pagination>;
21
+ export default Pagination;
@@ -0,0 +1,4 @@
1
+ import Pagination from './Pagination.svelte';
2
+ export { Pagination };
3
+ export type { PaginationProps, PaginationLayout } from './types';
4
+ export default Pagination;
@@ -0,0 +1,3 @@
1
+ import Pagination from './Pagination.svelte';
2
+ export { Pagination };
3
+ export default Pagination;
@@ -0,0 +1,35 @@
1
+ /** Pagination 布局项 */
2
+ export type PaginationLayout = 'prev' | 'pager' | 'next' | 'jumper' | 'sizes' | 'total';
3
+ /** Pagination 属性 */
4
+ export interface PaginationProps {
5
+ /** 当前页码 */
6
+ currentPage?: number;
7
+ /** 每页条数 */
8
+ pageSize?: number;
9
+ /** 总条数 */
10
+ total?: number;
11
+ /** 页码按钮数量 */
12
+ pagerCount?: number;
13
+ /** 每页条数选项 */
14
+ pageSizes?: number[];
15
+ /** 布局 */
16
+ layout?: PaginationLayout[];
17
+ /** 是否禁用 */
18
+ disabled?: boolean;
19
+ /** 是否隐藏只有一页时的分页 */
20
+ hideOnSinglePage?: boolean;
21
+ /** 是否使用小型分页 */
22
+ small?: boolean;
23
+ /** 是否使用背景色 */
24
+ background?: boolean;
25
+ /** 页码变更事件 */
26
+ onchange?: (page: number) => void;
27
+ /** 每页条数变更事件 */
28
+ onsizechange?: (size: number) => void;
29
+ /** 上一页文本 */
30
+ prevText?: string;
31
+ /** 下一页文本 */
32
+ nextText?: string;
33
+ /** 自定义类名 */
34
+ class?: string;
35
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,175 @@
1
+ <script lang="ts">
2
+ import type { PinInputProps } from './types'
3
+
4
+ let {
5
+ value = $bindable(''),
6
+ length = 6,
7
+ type = 'text',
8
+ size = 'medium',
9
+ disabled = false,
10
+ mask = false,
11
+ placeholder = '',
12
+ autoFocus = false,
13
+ oninput,
14
+ oncomplete,
15
+ class: className = '',
16
+ ...restProps
17
+ }: PinInputProps = $props()
18
+
19
+ let inputRefs = $state<(HTMLInputElement | null)[]>([])
20
+ let focusedIndex = $state<number | null>(null)
21
+ let internalValues = $state<string[]>([])
22
+ let lastSyncedValue = ''
23
+
24
+ /** 输入框索引数组(静态缓存) */
25
+ const inputIndices = $derived(Array.from({ length }, (_, i) => i))
26
+
27
+ // 初始化
28
+ $effect(() => {
29
+ if (internalValues.length !== length) {
30
+ internalValues = Array(length).fill('')
31
+ }
32
+ if (inputRefs.length !== length) {
33
+ inputRefs = Array(length).fill(null)
34
+ }
35
+ })
36
+
37
+ // 同步外部值
38
+ $effect(() => {
39
+ const joined = internalValues.join('')
40
+ if (value !== lastSyncedValue && value !== joined) {
41
+ const chars = value.split('')
42
+ const newValues = Array(length).fill('')
43
+ for (let i = 0; i < Math.min(chars.length, length); i++) {
44
+ newValues[i] = chars[i]
45
+ }
46
+ internalValues = newValues
47
+ lastSyncedValue = value
48
+ }
49
+ })
50
+
51
+ const isComplete = $derived(internalValues.filter(Boolean).length === length)
52
+ const isPassword = $derived(mask || type === 'password')
53
+
54
+ const rootClasses = $derived(
55
+ `lm-pin-input lm-pin-input--${size}${disabled ? ' is-disabled' : ''}${isPassword ? ' is-password' : ''}${isComplete ? ' is-complete' : ''}${className ? ` ${className}` : ''}`
56
+ )
57
+
58
+ /** 更新值 */
59
+ const updateValue = (newValues: string[]): void => {
60
+ internalValues = newValues
61
+ const newValue = newValues.join('')
62
+ value = newValue
63
+ lastSyncedValue = newValue
64
+ }
65
+
66
+ /** 输入处理 */
67
+ const handleInput = (index: number, event: Event): void => {
68
+ const input = event.currentTarget as HTMLInputElement
69
+ let inputValue = input.value
70
+
71
+ if (type === 'number') {
72
+ inputValue = inputValue.replace(/\D/g, '')
73
+ }
74
+
75
+ if (inputValue.length > 1) {
76
+ inputValue = inputValue.slice(-1)
77
+ }
78
+
79
+ const newValues = [...internalValues]
80
+ newValues[index] = inputValue
81
+ updateValue(newValues)
82
+
83
+ if (inputValue && index < length - 1) {
84
+ setTimeout(() => inputRefs[index + 1]?.focus(), 0)
85
+ }
86
+
87
+ oninput?.(value)
88
+ if (value.length === length) {
89
+ oncomplete?.(value)
90
+ }
91
+ }
92
+
93
+ /** 键盘处理 */
94
+ const handleKeyDown = (index: number, event: KeyboardEvent): void => {
95
+ const { key } = event
96
+
97
+ if (key === 'Backspace') {
98
+ if (!internalValues[index] && index > 0) {
99
+ event.preventDefault()
100
+ const newValues = [...internalValues]
101
+ newValues[index - 1] = ''
102
+ updateValue(newValues)
103
+ inputRefs[index - 1]?.focus()
104
+ }
105
+ } else if (key === 'ArrowLeft' && index > 0) {
106
+ event.preventDefault()
107
+ inputRefs[index - 1]?.focus()
108
+ } else if (key === 'ArrowRight' && index < length - 1) {
109
+ event.preventDefault()
110
+ inputRefs[index + 1]?.focus()
111
+ } else if (key === 'Delete') {
112
+ event.preventDefault()
113
+ const newValues = [...internalValues]
114
+ newValues[index] = ''
115
+ updateValue(newValues)
116
+ }
117
+ }
118
+
119
+ /** 粘贴处理 */
120
+ const handlePaste = (event: ClipboardEvent): void => {
121
+ event.preventDefault()
122
+ let pastedText = event.clipboardData?.getData('text') || ''
123
+
124
+ if (type === 'number') {
125
+ pastedText = pastedText.replace(/\D/g, '')
126
+ }
127
+
128
+ const chars = pastedText.slice(0, length).split('')
129
+ const newValues = Array(length).fill('')
130
+ chars.forEach((char, i) => {
131
+ newValues[i] = char
132
+ })
133
+ updateValue(newValues)
134
+
135
+ inputRefs[Math.min(chars.length, length - 1)]?.focus()
136
+
137
+ oninput?.(value)
138
+ if (chars.length === length) {
139
+ oncomplete?.(value)
140
+ }
141
+ }
142
+
143
+ // 自动聚焦
144
+ $effect(() => {
145
+ if (autoFocus && inputRefs[0]) {
146
+ inputRefs[0].focus()
147
+ }
148
+ })
149
+ </script>
150
+
151
+ <div {...restProps} class={rootClasses} role="group" aria-label="PIN input">
152
+ {#each inputIndices as index (index)}
153
+ {@const currentValue = internalValues[index] || ''}
154
+ {@const isFocused = focusedIndex === index}
155
+
156
+ <input
157
+ bind:this={inputRefs[index]}
158
+ type={isPassword ? 'password' : type === 'number' ? 'text' : type}
159
+ inputmode={type === 'number' ? 'numeric' : 'text'}
160
+ class="lm-pin-input__input"
161
+ class:is-focused={isFocused}
162
+ value={currentValue}
163
+ {placeholder}
164
+ {disabled}
165
+ maxlength="1"
166
+ autocomplete="off"
167
+ aria-label="PIN digit {index + 1} of {length}"
168
+ oninput={(e: Event) => handleInput(index, e)}
169
+ onkeydown={(e: KeyboardEvent) => handleKeyDown(index, e)}
170
+ onpaste={handlePaste}
171
+ onfocus={() => (focusedIndex = index)}
172
+ onblur={() => (focusedIndex = null)}
173
+ />
174
+ {/each}
175
+ </div>
@@ -0,0 +1,4 @@
1
+ import type { PinInputProps } from './types';
2
+ declare const PinInput: import("svelte").Component<PinInputProps, {}, "value">;
3
+ type PinInput = ReturnType<typeof PinInput>;
4
+ export default PinInput;
@@ -0,0 +1,4 @@
1
+ import PinInput from './PinInput.svelte';
2
+ export { PinInput };
3
+ export type { PinInputProps, PinInputType, PinInputSize } from './types';
4
+ export default PinInput;
@@ -0,0 +1,3 @@
1
+ import PinInput from './PinInput.svelte';
2
+ export { PinInput };
3
+ export default PinInput;
@@ -0,0 +1,31 @@
1
+ /** PinInput 类型 */
2
+ export type PinInputType = 'text' | 'number' | 'password';
3
+ /** PinInput 尺寸 */
4
+ export type PinInputSize = 'small' | 'medium' | 'large';
5
+ /** PinInput 属性 */
6
+ export interface PinInputProps {
7
+ /** 绑定值 */
8
+ value?: string;
9
+ /** 输入框数量 */
10
+ length?: number;
11
+ /** 输入类型 */
12
+ type?: PinInputType;
13
+ /** 尺寸 */
14
+ size?: PinInputSize;
15
+ /** 是否禁用 */
16
+ disabled?: boolean;
17
+ /** 是否遮罩(密码模式) */
18
+ mask?: boolean;
19
+ /** 占位符 */
20
+ placeholder?: string;
21
+ /** 是否自动聚焦 */
22
+ autoFocus?: boolean;
23
+ /** 输入事件 */
24
+ oninput?: (value: string) => void;
25
+ /** 完成事件 */
26
+ oncomplete?: (value: string) => void;
27
+ /** 自定义类名 */
28
+ class?: string;
29
+ /** 其他属性 */
30
+ [key: string]: unknown;
31
+ }
@@ -0,0 +1 @@
1
+ export {};