@dvcol/neo-svelte 1.1.2 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (466) hide show
  1. package/CHANGELOG.md +90 -0
  2. package/README.md +15 -7
  3. package/dist/badge/neo-badge.model.d.ts +1 -1
  4. package/dist/buttons/NeoArrowButton.svelte +4 -4
  5. package/dist/buttons/NeoButton.svelte +110 -24
  6. package/dist/buttons/NeoButtonGroup.svelte +18 -9
  7. package/dist/buttons/NeoButtonGroup.svelte.d.ts +1 -1
  8. package/dist/buttons/NeoButtonRow.svelte +137 -0
  9. package/dist/buttons/NeoButtonRow.svelte.d.ts +4 -0
  10. package/dist/buttons/NeoCancelButton.svelte +2 -2
  11. package/dist/buttons/NeoCheckboxButton.svelte +6 -4
  12. package/dist/buttons/NeoCheckboxButton.svelte.d.ts +1 -1
  13. package/dist/buttons/NeoCloseButton.svelte +37 -6
  14. package/dist/buttons/NeoCloseButton.svelte.d.ts +2 -2
  15. package/dist/buttons/NeoRadioButton.svelte +6 -4
  16. package/dist/buttons/NeoSwitchButton.svelte +5 -3
  17. package/dist/buttons/index.d.ts +2 -0
  18. package/dist/buttons/index.js +1 -0
  19. package/dist/buttons/neo-arrow-button.model.d.ts +3 -3
  20. package/dist/buttons/neo-button-group.model.d.ts +12 -3
  21. package/dist/buttons/neo-button-row.model.d.ts +33 -0
  22. package/dist/buttons/neo-button-row.model.js +1 -0
  23. package/dist/buttons/neo-button.model.d.ts +11 -4
  24. package/dist/buttons/neo-close-button.model.d.ts +13 -0
  25. package/dist/buttons/neo-close-button.model.js +5 -0
  26. package/dist/buttons/neo-icon-button.model.d.ts +2 -2
  27. package/dist/cards/NeoCard.svelte +22 -20
  28. package/dist/cards/neo-card.model.d.ts +3 -2
  29. package/dist/collapse/NeoAccordion.svelte +3 -1
  30. package/dist/collapse/NeoCollapse.svelte +2 -2
  31. package/dist/collapse/NeoCollapse.svelte.d.ts +3 -1
  32. package/dist/collapse/neo-accordion.model.d.ts +2 -1
  33. package/dist/containers/NeoTransitionContainer.svelte +10 -0
  34. package/dist/containers/neo-transition-container.model.d.ts +9 -0
  35. package/dist/cursor/NeoCursor.svelte.d.ts +1 -1
  36. package/dist/divider/NeoDivider.svelte +4 -2
  37. package/dist/divider/neo-divider.model.d.ts +2 -1
  38. package/dist/floating/common/NeoConfirm.svelte +5 -5
  39. package/dist/floating/common/NeoConfirm.svelte.d.ts +1 -1
  40. package/dist/floating/common/NeoFloatingStepper.svelte +1 -1
  41. package/dist/floating/common/NeoFloatingStepper.svelte.d.ts +1 -1
  42. package/dist/floating/common/NeoHandle.svelte +2 -1
  43. package/dist/floating/common/neo-confirm.model.d.ts +2 -1
  44. package/dist/floating/common/neo-floating-stepper.model.d.ts +1 -1
  45. package/dist/floating/common/neo-placement.model.d.ts +56 -4
  46. package/dist/floating/common/neo-placement.model.js +22 -0
  47. package/dist/floating/dialog/NeoDialog.svelte +23 -21
  48. package/dist/floating/dialog/NeoDialog.svelte.d.ts +1 -1
  49. package/dist/floating/dialog/NeoDialogConfirm.svelte.d.ts +1 -1
  50. package/dist/floating/dialog/NeoDialogStepper.svelte.d.ts +1 -1
  51. package/dist/floating/dialog/neo-dialog-confirm.model.d.ts +5 -5
  52. package/dist/floating/dialog/neo-dialog-stepper.model.d.ts +4 -4
  53. package/dist/floating/dialog/neo-dialog.model.d.ts +2 -1
  54. package/dist/floating/dialog/use-movable.svelte.js +2 -1
  55. package/dist/floating/drawer/NeoDrawer.svelte +9 -9
  56. package/dist/floating/drawer/NeoDrawer.svelte.d.ts +2 -2
  57. package/dist/floating/drawer/NeoDrawerConfirm.svelte +2 -4
  58. package/dist/floating/drawer/NeoDrawerConfirm.svelte.d.ts +2 -2
  59. package/dist/floating/drawer/NeoDrawerStepper.svelte +2 -4
  60. package/dist/floating/drawer/NeoDrawerStepper.svelte.d.ts +2 -2
  61. package/dist/floating/drawer/neo-drawer.model.d.ts +6 -0
  62. package/dist/floating/drawer/neo-drawer.model.js +1 -0
  63. package/dist/floating/index.d.ts +1 -0
  64. package/dist/floating/index.js +1 -0
  65. package/dist/floating/menu/NeoMenu.svelte +55 -17
  66. package/dist/floating/menu/NeoMenu.svelte.d.ts +1 -1
  67. package/dist/floating/menu/NeoMenuList.svelte +60 -67
  68. package/dist/floating/menu/NeoMenuListItem.svelte +157 -24
  69. package/dist/floating/menu/NeoMenuListItem.svelte.d.ts +1 -0
  70. package/dist/floating/menu/index.d.ts +1 -0
  71. package/dist/floating/menu/neo-menu-list-item.model.d.ts +48 -11
  72. package/dist/floating/menu/neo-menu-list.model.d.ts +24 -4
  73. package/dist/floating/menu/neo-menu.model.d.ts +3 -3
  74. package/dist/floating/notification/NeoNotificationItem.svelte +459 -0
  75. package/dist/floating/notification/NeoNotificationItem.svelte.d.ts +4 -0
  76. package/dist/floating/notification/NeoNotificationProvider.svelte +49 -0
  77. package/dist/floating/notification/NeoNotificationProvider.svelte.d.ts +4 -0
  78. package/dist/floating/notification/NeoNotificationStack.svelte +345 -0
  79. package/dist/floating/notification/NeoNotificationStack.svelte.d.ts +16 -0
  80. package/dist/floating/notification/NeoSimpleNotification.svelte +304 -0
  81. package/dist/floating/notification/NeoSimpleNotification.svelte.d.ts +4 -0
  82. package/dist/floating/notification/index.d.ts +8 -0
  83. package/dist/floating/notification/index.js +7 -0
  84. package/dist/floating/notification/neo-notification-item.model.d.ts +54 -0
  85. package/dist/floating/notification/neo-notification-item.model.js +1 -0
  86. package/dist/floating/notification/neo-notification-provider.model.d.ts +78 -0
  87. package/dist/floating/notification/neo-notification-provider.model.js +18 -0
  88. package/dist/floating/notification/neo-notification-stack.model.d.ts +48 -0
  89. package/dist/floating/notification/neo-notification-stack.model.js +1 -0
  90. package/dist/floating/notification/neo-notification.model.d.ts +271 -0
  91. package/dist/floating/notification/neo-notification.model.js +70 -0
  92. package/dist/floating/notification/neo-simple-notification.model.d.ts +14 -0
  93. package/dist/floating/notification/neo-simple-notification.model.js +1 -0
  94. package/dist/floating/portal/NeoPortal.svelte +11 -8
  95. package/dist/floating/portal/NeoPortalTarget.svelte +7 -0
  96. package/dist/floating/portal/NeoPortalTarget.svelte.d.ts +7 -0
  97. package/dist/floating/portal/neo-portal-context.svelte.d.ts +1 -1
  98. package/dist/floating/portal/neo-portal.model.d.ts +4 -5
  99. package/dist/floating/tooltips/NeoPopConfirm.svelte +2 -0
  100. package/dist/floating/tooltips/NeoPopConfirm.svelte.d.ts +1 -1
  101. package/dist/floating/tooltips/NeoPopSelect.svelte +5 -3
  102. package/dist/floating/tooltips/NeoPopSelect.svelte.d.ts +1 -1
  103. package/dist/floating/tooltips/NeoPopStepper.svelte +2 -0
  104. package/dist/floating/tooltips/NeoPopStepper.svelte.d.ts +1 -1
  105. package/dist/floating/tooltips/NeoTooltip.svelte +43 -23
  106. package/dist/floating/tooltips/NeoTooltip.svelte.d.ts +5 -1
  107. package/dist/floating/tooltips/neo-pop-confirm.model.d.ts +1 -1
  108. package/dist/floating/tooltips/neo-pop-select.model.d.ts +1 -3
  109. package/dist/floating/tooltips/neo-pop-stepper.model.d.ts +2 -2
  110. package/dist/floating/tooltips/neo-tooltip.model.d.ts +7 -2
  111. package/dist/form/NeoForm.svelte +1 -1
  112. package/dist/form/NeoForm.svelte.d.ts +3 -1
  113. package/dist/form/neo-form-context.svelte.d.ts +2 -0
  114. package/dist/icons/{IconAccount.svelte → NeoIconAccount.svelte} +2 -2
  115. package/dist/icons/NeoIconAccount.svelte.d.ts +4 -0
  116. package/dist/icons/{IconAdd.svelte → NeoIconAdd.svelte} +11 -6
  117. package/dist/icons/NeoIconAdd.svelte.d.ts +4 -0
  118. package/dist/icons/{IconAddress.svelte → NeoIconAddress.svelte} +2 -2
  119. package/dist/icons/NeoIconAddress.svelte.d.ts +4 -0
  120. package/dist/icons/{IconAlert.svelte → NeoIconAlert.svelte} +11 -6
  121. package/dist/icons/NeoIconAlert.svelte.d.ts +4 -0
  122. package/dist/icons/{IconAlignBottom.svelte → NeoIconAlignBottom.svelte} +11 -6
  123. package/dist/icons/NeoIconAlignBottom.svelte.d.ts +4 -0
  124. package/dist/icons/{IconAlignMiddle.svelte → NeoIconAlignMiddle.svelte} +11 -6
  125. package/dist/icons/NeoIconAlignMiddle.svelte.d.ts +4 -0
  126. package/dist/icons/{IconAlignTop.svelte → NeoIconAlignTop.svelte} +11 -6
  127. package/dist/icons/NeoIconAlignTop.svelte.d.ts +4 -0
  128. package/dist/icons/{IconArrow.svelte → NeoIconArrow.svelte} +9 -9
  129. package/dist/icons/NeoIconArrow.svelte.d.ts +4 -0
  130. package/dist/icons/NeoIconAudio.svelte +83 -0
  131. package/dist/icons/NeoIconAudio.svelte.d.ts +4 -0
  132. package/dist/icons/NeoIconBouncingDots.svelte +82 -0
  133. package/dist/icons/NeoIconBouncingDots.svelte.d.ts +4 -0
  134. package/dist/icons/{IconCalendar.svelte → NeoIconCalendar.svelte} +11 -6
  135. package/dist/icons/NeoIconCalendar.svelte.d.ts +4 -0
  136. package/dist/icons/{IconCancel.svelte → NeoIconCancel.svelte} +2 -2
  137. package/dist/icons/NeoIconCancel.svelte.d.ts +4 -0
  138. package/dist/icons/{IconCheckbox.svelte → NeoIconCheckbox.svelte} +2 -2
  139. package/dist/icons/NeoIconCheckbox.svelte.d.ts +4 -0
  140. package/dist/icons/NeoIconCircle.svelte +18 -0
  141. package/dist/icons/NeoIconCircle.svelte.d.ts +4 -0
  142. package/dist/icons/{IconCircleLoading.svelte → NeoIconCircleLoading.svelte} +2 -2
  143. package/dist/icons/{IconCircleLoading.svelte.d.ts → NeoIconCircleLoading.svelte.d.ts} +55 -39
  144. package/dist/icons/{IconClear.svelte → NeoIconClear.svelte} +11 -6
  145. package/dist/icons/NeoIconClear.svelte.d.ts +4 -0
  146. package/dist/icons/{IconClose.svelte → NeoIconClose.svelte} +2 -2
  147. package/dist/icons/NeoIconClose.svelte.d.ts +4 -0
  148. package/dist/icons/NeoIconCog.svelte +36 -0
  149. package/dist/icons/NeoIconCog.svelte.d.ts +4 -0
  150. package/dist/icons/{IconConfirm.svelte → NeoIconConfirm.svelte} +11 -6
  151. package/dist/icons/NeoIconConfirm.svelte.d.ts +4 -0
  152. package/dist/icons/NeoIconCube.svelte +31 -0
  153. package/dist/icons/NeoIconCube.svelte.d.ts +4 -0
  154. package/dist/icons/{IconDoubleChevron.svelte → NeoIconDoubleChevron.svelte} +11 -5
  155. package/dist/icons/NeoIconDoubleChevron.svelte.d.ts +4 -0
  156. package/dist/icons/{IconDoubleChevronLeft.svelte → NeoIconDoubleChevronLeft.svelte} +11 -6
  157. package/dist/icons/NeoIconDoubleChevronLeft.svelte.d.ts +4 -0
  158. package/dist/icons/{IconDoubleChevronRight.svelte → NeoIconDoubleChevronRight.svelte} +11 -6
  159. package/dist/icons/NeoIconDoubleChevronRight.svelte.d.ts +4 -0
  160. package/dist/icons/{IconDownload.svelte → NeoIconDownload.svelte} +11 -6
  161. package/dist/icons/NeoIconDownload.svelte.d.ts +4 -0
  162. package/dist/icons/NeoIconEmpty.svelte +26 -0
  163. package/dist/icons/NeoIconEmpty.svelte.d.ts +4 -0
  164. package/dist/icons/NeoIconError.svelte +30 -0
  165. package/dist/icons/NeoIconError.svelte.d.ts +4 -0
  166. package/dist/icons/{IconFileUpload.svelte → NeoIconFileUpload.svelte} +11 -6
  167. package/dist/icons/NeoIconFileUpload.svelte.d.ts +4 -0
  168. package/dist/icons/NeoIconFire.svelte +33 -0
  169. package/dist/icons/NeoIconFire.svelte.d.ts +4 -0
  170. package/dist/icons/{IconGithub.svelte → NeoIconGithub.svelte} +11 -6
  171. package/dist/icons/NeoIconGithub.svelte.d.ts +4 -0
  172. package/dist/icons/NeoIconImage.svelte +39 -0
  173. package/dist/icons/NeoIconImage.svelte.d.ts +4 -0
  174. package/dist/icons/NeoIconInfo.svelte +30 -0
  175. package/dist/icons/NeoIconInfo.svelte.d.ts +4 -0
  176. package/dist/icons/{IconList.svelte → NeoIconList.svelte} +11 -6
  177. package/dist/icons/NeoIconList.svelte.d.ts +4 -0
  178. package/dist/icons/{IconListSmall.svelte → NeoIconListSmall.svelte} +2 -2
  179. package/dist/icons/NeoIconListSmall.svelte.d.ts +4 -0
  180. package/dist/icons/{IconLoadingMatrix.svelte → NeoIconLoadingMatrix.svelte} +2 -2
  181. package/dist/icons/NeoIconLoadingMatrix.svelte.d.ts +4 -0
  182. package/dist/icons/{IconMail.svelte → NeoIconMail.svelte} +11 -6
  183. package/dist/icons/NeoIconMail.svelte.d.ts +4 -0
  184. package/dist/icons/{IconMinus.svelte → NeoIconMinus.svelte} +11 -6
  185. package/dist/icons/NeoIconMinus.svelte.d.ts +4 -0
  186. package/dist/icons/{IconPaint.svelte → NeoIconPaint.svelte} +11 -6
  187. package/dist/icons/NeoIconPaint.svelte.d.ts +4 -0
  188. package/dist/icons/{IconPencil.svelte → NeoIconPencil.svelte} +11 -6
  189. package/dist/icons/NeoIconPencil.svelte.d.ts +4 -0
  190. package/dist/icons/{IconPlayPause.svelte → NeoIconPlayPause.svelte} +2 -2
  191. package/dist/icons/NeoIconPlayPause.svelte.d.ts +4 -0
  192. package/dist/icons/{IconQuestionMark.svelte → NeoIconQuestionMark.svelte} +11 -6
  193. package/dist/icons/NeoIconQuestionMark.svelte.d.ts +4 -0
  194. package/dist/icons/{IconRadio.svelte → NeoIconRadio.svelte} +2 -2
  195. package/dist/icons/NeoIconRadio.svelte.d.ts +4 -0
  196. package/dist/icons/NeoIconRefresh.svelte +38 -0
  197. package/dist/icons/NeoIconRefresh.svelte.d.ts +4 -0
  198. package/dist/icons/NeoIconRestore.svelte +20 -0
  199. package/dist/icons/NeoIconRestore.svelte.d.ts +4 -0
  200. package/dist/icons/NeoIconSave.svelte +35 -0
  201. package/dist/icons/NeoIconSave.svelte.d.ts +4 -0
  202. package/dist/icons/NeoIconSaveOff.svelte +42 -0
  203. package/dist/icons/NeoIconSaveOff.svelte.d.ts +4 -0
  204. package/dist/icons/{IconSearch.svelte → NeoIconSearch.svelte} +11 -6
  205. package/dist/icons/NeoIconSearch.svelte.d.ts +4 -0
  206. package/dist/icons/NeoIconSuccess.svelte +26 -0
  207. package/dist/icons/NeoIconSuccess.svelte.d.ts +4 -0
  208. package/dist/icons/{IconSun.svelte → NeoIconSun.svelte} +11 -6
  209. package/dist/icons/NeoIconSun.svelte.d.ts +4 -0
  210. package/dist/icons/{IconSunMoon.svelte → NeoIconSunMoon.svelte} +11 -64
  211. package/dist/icons/NeoIconSunMoon.svelte.d.ts +4 -0
  212. package/dist/icons/{IconTextHighlight.svelte → NeoIconTextHighlight.svelte} +11 -6
  213. package/dist/icons/NeoIconTextHighlight.svelte.d.ts +4 -0
  214. package/dist/icons/NeoIconTheme.svelte +14 -0
  215. package/dist/icons/NeoIconTheme.svelte.d.ts +3 -0
  216. package/dist/icons/NeoIconTrend.svelte +39 -0
  217. package/dist/icons/NeoIconTrend.svelte.d.ts +4 -0
  218. package/dist/icons/NeoIconUnplug.svelte +63 -0
  219. package/dist/icons/NeoIconUnplug.svelte.d.ts +4 -0
  220. package/dist/icons/{IconVideo.svelte → NeoIconVideo.svelte} +11 -6
  221. package/dist/icons/NeoIconVideo.svelte.d.ts +4 -0
  222. package/dist/icons/NeoIconWarning.svelte +30 -0
  223. package/dist/icons/NeoIconWarning.svelte.d.ts +4 -0
  224. package/dist/icons/NeoIconWatch.svelte +41 -0
  225. package/dist/icons/NeoIconWatch.svelte.d.ts +4 -0
  226. package/dist/icons/NeoIconWatchOff.svelte +50 -0
  227. package/dist/icons/NeoIconWatchOff.svelte.d.ts +4 -0
  228. package/dist/icons/NeoIconWave.svelte +31 -0
  229. package/dist/icons/NeoIconWave.svelte.d.ts +4 -0
  230. package/dist/icons/index.d.ts +54 -0
  231. package/dist/icons/index.js +54 -0
  232. package/dist/icons/{icon.model.d.ts → neo-icon.model.d.ts} +41 -13
  233. package/dist/icons/{icon.model.js → neo-icon.model.js} +1 -1
  234. package/dist/index.d.ts +2 -0
  235. package/dist/index.js +2 -0
  236. package/dist/inputs/NeoCheckbox.svelte +6 -4
  237. package/dist/inputs/NeoCheckbox.svelte.d.ts +1 -1
  238. package/dist/inputs/NeoColorPicker.svelte +6 -3
  239. package/dist/inputs/NeoColorPicker.svelte.d.ts +1 -1
  240. package/dist/inputs/NeoColorPickerSelector.svelte +2 -2
  241. package/dist/inputs/NeoColorPickerSelector.svelte.d.ts +1 -1
  242. package/dist/inputs/NeoDateTime.svelte +6 -3
  243. package/dist/inputs/NeoDateTime.svelte.d.ts +1 -1
  244. package/dist/inputs/NeoFilePicker.svelte +11 -6
  245. package/dist/inputs/NeoFilePicker.svelte.d.ts +1 -1
  246. package/dist/inputs/NeoFilePickerCard.svelte +20 -14
  247. package/dist/inputs/NeoNativeSelect.svelte +6 -3
  248. package/dist/inputs/NeoNativeSelect.svelte.d.ts +1 -1
  249. package/dist/inputs/NeoNumberStep.svelte +13 -8
  250. package/dist/inputs/NeoNumberStep.svelte.d.ts +1 -1
  251. package/dist/inputs/NeoPassword.svelte +4 -4
  252. package/dist/inputs/NeoPassword.svelte.d.ts +1 -1
  253. package/dist/inputs/NeoPin.svelte +10 -10
  254. package/dist/inputs/NeoPin.svelte.d.ts +10 -1
  255. package/dist/inputs/NeoRadio.svelte +3 -3
  256. package/dist/inputs/NeoRadio.svelte.d.ts +1 -1
  257. package/dist/inputs/NeoRange.svelte +29 -27
  258. package/dist/inputs/NeoRange.svelte.d.ts +5 -2
  259. package/dist/inputs/NeoSelect.svelte +17 -8
  260. package/dist/inputs/NeoSelect.svelte.d.ts +1 -1
  261. package/dist/inputs/NeoSwitch.svelte +2 -2
  262. package/dist/inputs/NeoSwitch.svelte.d.ts +1 -1
  263. package/dist/inputs/common/NeoAffix.svelte +10 -10
  264. package/dist/inputs/common/NeoBaseInput.svelte +16 -2
  265. package/dist/inputs/common/NeoBaseInput.svelte.d.ts +1 -1
  266. package/dist/inputs/common/NeoInput.svelte +12 -4
  267. package/dist/inputs/common/NeoInput.svelte.d.ts +1 -1
  268. package/dist/inputs/common/NeoTextarea.svelte +18 -6
  269. package/dist/inputs/common/NeoTextarea.svelte.d.ts +2 -1
  270. package/dist/inputs/common/NeoValidation.svelte +6 -4
  271. package/dist/inputs/common/neo-input.model.d.ts +8 -1
  272. package/dist/inputs/common/neo-validation.model.d.ts +2 -1
  273. package/dist/inputs/neo-range.model.d.ts +2 -1
  274. package/dist/inputs/neo-select.model.d.ts +8 -4
  275. package/dist/list/NeoList.svelte +100 -62
  276. package/dist/list/NeoList.svelte.d.ts +5 -2
  277. package/dist/list/NeoListBaseItem.svelte +222 -92
  278. package/dist/list/NeoListBaseItem.svelte.d.ts +1 -1
  279. package/dist/list/NeoListBaseLoader.svelte +28 -4
  280. package/dist/list/NeoListBaseSection.svelte +18 -15
  281. package/dist/list/NeoListSearch.svelte +36 -20
  282. package/dist/list/NeoListSearch.svelte.d.ts +1 -1
  283. package/dist/list/NeoSimpleList.svelte +391 -0
  284. package/dist/list/NeoSimpleList.svelte.d.ts +8 -0
  285. package/dist/list/NeoVirtualList.svelte +388 -0
  286. package/dist/list/NeoVirtualList.svelte.d.ts +22 -0
  287. package/dist/list/index.d.ts +4 -0
  288. package/dist/list/index.js +2 -0
  289. package/dist/list/neo-list-base-item.model.d.ts +36 -7
  290. package/dist/list/neo-list-base-item.model.js +1 -0
  291. package/dist/list/neo-list-base-loader.model.d.ts +18 -1
  292. package/dist/list/neo-list-base-section.model.d.ts +8 -5
  293. package/dist/list/neo-list-search.model.d.ts +2 -2
  294. package/dist/list/neo-list.model.d.ts +120 -51
  295. package/dist/list/neo-list.model.js +18 -0
  296. package/dist/list/neo-simple-list.model.d.ts +124 -0
  297. package/dist/list/neo-simple-list.model.js +1 -0
  298. package/dist/list/neo-virtual-list.model.d.ts +69 -0
  299. package/dist/list/neo-virtual-list.model.js +6 -0
  300. package/dist/loading/NeoLoadingMatrix.svelte +2 -2
  301. package/dist/loading/neo-lazy.model.d.ts +2 -2
  302. package/dist/loading/neo-suspense.model.d.ts +1 -1
  303. package/dist/media/NeoImage.svelte +204 -0
  304. package/dist/media/NeoImage.svelte.d.ts +4 -0
  305. package/dist/media/NeoMedia.svelte +204 -0
  306. package/dist/media/NeoMedia.svelte.d.ts +4 -0
  307. package/dist/media/index.d.ts +2 -0
  308. package/dist/media/index.js +1 -0
  309. package/dist/media/neo-image.model.d.ts +67 -0
  310. package/dist/media/neo-image.model.js +1 -0
  311. package/dist/media/neo-media.model.d.ts +120 -0
  312. package/dist/media/neo-media.model.js +5 -0
  313. package/dist/nav/NeoTab.svelte +20 -15
  314. package/dist/nav/NeoTab.svelte.d.ts +17 -2
  315. package/dist/nav/NeoTabPanel.svelte +7 -5
  316. package/dist/nav/NeoTabPanel.svelte.d.ts +17 -2
  317. package/dist/nav/NeoTabs.svelte +21 -17
  318. package/dist/nav/NeoTabs.svelte.d.ts +19 -3
  319. package/dist/nav/NeoTabsCard.svelte +5 -3
  320. package/dist/nav/NeoTabsCard.svelte.d.ts +17 -2
  321. package/dist/nav/NeoTabsRow.svelte +225 -0
  322. package/dist/nav/NeoTabsRow.svelte.d.ts +19 -0
  323. package/dist/nav/index.d.ts +2 -0
  324. package/dist/nav/index.js +1 -0
  325. package/dist/nav/neo-tab-panel.model.d.ts +3 -3
  326. package/dist/nav/neo-tab.model.d.ts +15 -5
  327. package/dist/nav/neo-tabs-card.model.d.ts +3 -2
  328. package/dist/nav/neo-tabs-context.svelte.d.ts +35 -29
  329. package/dist/nav/neo-tabs-context.svelte.js +17 -3
  330. package/dist/nav/neo-tabs-row.model.d.ts +85 -0
  331. package/dist/nav/neo-tabs-row.model.js +1 -0
  332. package/dist/nav/neo-tabs.model.d.ts +12 -11
  333. package/dist/pill/NeoPill.svelte +73 -14
  334. package/dist/pill/neo-pill.model.d.ts +25 -1
  335. package/dist/progress/NeoProgress.svelte +203 -42
  336. package/dist/progress/NeoProgress.svelte.d.ts +8 -8
  337. package/dist/progress/NeoProgressBar.svelte +37 -6
  338. package/dist/progress/NeoProgressBar.svelte.d.ts +9 -1
  339. package/dist/progress/index.d.ts +1 -0
  340. package/dist/progress/index.js +1 -0
  341. package/dist/progress/neo-progress-bar.model.d.ts +11 -6
  342. package/dist/progress/neo-progress-service.svelte.d.ts +47 -0
  343. package/dist/progress/neo-progress-service.svelte.js +157 -0
  344. package/dist/progress/neo-progress.model.d.ts +98 -41
  345. package/dist/progress/neo-progress.model.js +6 -1
  346. package/dist/providers/NeoRememberSelector.svelte +43 -0
  347. package/dist/providers/NeoRememberSelector.svelte.d.ts +4 -0
  348. package/dist/providers/NeoResetSelector.svelte +40 -0
  349. package/dist/providers/NeoResetSelector.svelte.d.ts +4 -0
  350. package/dist/providers/NeoSourceSelector.svelte +63 -0
  351. package/dist/providers/NeoSourceSelector.svelte.d.ts +4 -0
  352. package/dist/providers/NeoThemeProvider.svelte +25 -10
  353. package/dist/providers/NeoThemeProvider.svelte.d.ts +1 -2
  354. package/dist/providers/NeoThemeSelector.svelte +26 -108
  355. package/dist/providers/NeoThemeSelector.svelte.d.ts +1 -1
  356. package/dist/providers/NeoThemeSelectors.svelte +57 -0
  357. package/dist/providers/NeoThemeSelectors.svelte.d.ts +4 -0
  358. package/dist/providers/NeoTransitionSelector.svelte +57 -0
  359. package/dist/providers/NeoTransitionSelector.svelte.d.ts +4 -0
  360. package/dist/providers/index.d.ts +10 -0
  361. package/dist/providers/index.js +5 -0
  362. package/dist/providers/neo-remember-selector.model.d.ts +9 -0
  363. package/dist/providers/neo-remember-selector.model.js +2 -0
  364. package/dist/providers/neo-reset-selector.model.d.ts +9 -0
  365. package/dist/providers/neo-reset-selector.model.js +1 -0
  366. package/dist/providers/neo-source-selector.model.d.ts +9 -0
  367. package/dist/providers/neo-source-selector.model.js +2 -0
  368. package/dist/providers/neo-theme-provider-context.svelte.d.ts +14 -3
  369. package/dist/providers/neo-theme-provider-context.svelte.js +94 -11
  370. package/dist/providers/neo-theme-provider.model.d.ts +31 -3
  371. package/dist/providers/neo-theme-provider.model.js +9 -0
  372. package/dist/providers/neo-theme-selector.model.d.ts +3 -48
  373. package/dist/providers/neo-theme-selector.model.js +1 -0
  374. package/dist/providers/neo-theme-selectors.model.d.ts +84 -0
  375. package/dist/providers/neo-theme-selectors.model.js +1 -0
  376. package/dist/providers/neo-transition-selector.model.d.ts +9 -0
  377. package/dist/providers/neo-transition-selector.model.js +2 -0
  378. package/dist/skeletons/NeoSkeletonContainer.svelte +3 -1
  379. package/dist/skeletons/NeoSkeletonMedia.svelte +26 -18
  380. package/dist/skeletons/NeoSkeletonText.svelte +5 -3
  381. package/dist/skeletons/neo-skeleton-container.model.d.ts +9 -0
  382. package/dist/skeletons/neo-skeleton-media.model.d.ts +20 -10
  383. package/dist/skeletons/neo-skeleton-media.model.js +7 -1
  384. package/dist/skeletons/neo-skeleton-text.model.d.ts +5 -0
  385. package/dist/stepper/NeoStepper.svelte +20 -20
  386. package/dist/stepper/NeoStepper.svelte.d.ts +9 -2
  387. package/dist/stepper/neo-stepper.model.d.ts +5 -5
  388. package/dist/styles/animation.scss +76 -0
  389. package/dist/styles/common/colors.scss +15 -9
  390. package/dist/styles/common/properties.css +18 -0
  391. package/dist/styles/common/spacing.scss +8 -4
  392. package/dist/styles/common/typography.scss +13 -3
  393. package/dist/styles/common/utils.scss +2 -2
  394. package/dist/styles/mixin.scss +125 -11
  395. package/dist/styles/theme.scss +20 -0
  396. package/dist/styles/transition.scss +101 -0
  397. package/dist/text/NeoEllipsis.svelte +1 -0
  398. package/dist/text/NeoHtml.svelte +26 -0
  399. package/dist/text/NeoHtml.svelte.d.ts +7 -0
  400. package/dist/text/NeoMark.svelte +18 -5
  401. package/dist/text/NeoTypewriter.svelte +5 -4
  402. package/dist/text/NeoTypewriter.svelte.d.ts +5 -1
  403. package/dist/text/index.d.ts +2 -0
  404. package/dist/text/index.js +1 -0
  405. package/dist/text/neo-html.model.d.ts +4 -0
  406. package/dist/text/neo-html.model.js +1 -0
  407. package/dist/text/neo-mark.model.d.ts +8 -0
  408. package/dist/text/typewriter.utils.d.ts +2 -2
  409. package/dist/text/typewriter.utils.js +8 -9
  410. package/dist/utils/action.utils.d.ts +1 -21
  411. package/dist/utils/border.utils.d.ts +13 -0
  412. package/dist/utils/border.utils.js +18 -0
  413. package/dist/utils/colors.utils.d.ts +1 -1
  414. package/dist/utils/error.utils.d.ts +22 -0
  415. package/dist/utils/error.utils.js +36 -0
  416. package/dist/utils/style.utils.d.ts +1 -1
  417. package/package.json +55 -39
  418. package/dist/icons/IconAccount.svelte.d.ts +0 -4
  419. package/dist/icons/IconAdd.svelte.d.ts +0 -26
  420. package/dist/icons/IconAddress.svelte.d.ts +0 -4
  421. package/dist/icons/IconAlert.svelte.d.ts +0 -26
  422. package/dist/icons/IconAlignBottom.svelte.d.ts +0 -26
  423. package/dist/icons/IconAlignMiddle.svelte.d.ts +0 -26
  424. package/dist/icons/IconAlignTop.svelte.d.ts +0 -26
  425. package/dist/icons/IconArrow.svelte.d.ts +0 -4
  426. package/dist/icons/IconBouncingDots.svelte +0 -63
  427. package/dist/icons/IconBouncingDots.svelte.d.ts +0 -4
  428. package/dist/icons/IconCalendar.svelte.d.ts +0 -26
  429. package/dist/icons/IconCancel.svelte.d.ts +0 -4
  430. package/dist/icons/IconCheckbox.svelte.d.ts +0 -4
  431. package/dist/icons/IconClear.svelte.d.ts +0 -26
  432. package/dist/icons/IconClose.svelte.d.ts +0 -4
  433. package/dist/icons/IconConfirm.svelte.d.ts +0 -26
  434. package/dist/icons/IconDoubleChevron.svelte.d.ts +0 -26
  435. package/dist/icons/IconDoubleChevronLeft.svelte.d.ts +0 -26
  436. package/dist/icons/IconDoubleChevronRight.svelte.d.ts +0 -26
  437. package/dist/icons/IconDownload.svelte.d.ts +0 -26
  438. package/dist/icons/IconEmpty.svelte +0 -18
  439. package/dist/icons/IconEmpty.svelte.d.ts +0 -26
  440. package/dist/icons/IconFileUpload.svelte.d.ts +0 -26
  441. package/dist/icons/IconGithub.svelte.d.ts +0 -26
  442. package/dist/icons/IconImage.svelte +0 -26
  443. package/dist/icons/IconImage.svelte.d.ts +0 -26
  444. package/dist/icons/IconList.svelte.d.ts +0 -26
  445. package/dist/icons/IconListSmall.svelte.d.ts +0 -4
  446. package/dist/icons/IconLoadingMatrix.svelte.d.ts +0 -4
  447. package/dist/icons/IconMail.svelte.d.ts +0 -26
  448. package/dist/icons/IconMinus.svelte.d.ts +0 -26
  449. package/dist/icons/IconPaint.svelte.d.ts +0 -26
  450. package/dist/icons/IconPencil.svelte.d.ts +0 -26
  451. package/dist/icons/IconPlayPause.svelte.d.ts +0 -4
  452. package/dist/icons/IconQuestionMark.svelte.d.ts +0 -26
  453. package/dist/icons/IconRadio.svelte.d.ts +0 -4
  454. package/dist/icons/IconSave.svelte +0 -25
  455. package/dist/icons/IconSave.svelte.d.ts +0 -26
  456. package/dist/icons/IconSaveOff.svelte +0 -32
  457. package/dist/icons/IconSaveOff.svelte.d.ts +0 -26
  458. package/dist/icons/IconSearch.svelte.d.ts +0 -26
  459. package/dist/icons/IconSun.svelte.d.ts +0 -26
  460. package/dist/icons/IconSunMoon.svelte.d.ts +0 -4
  461. package/dist/icons/IconTextHighlight.svelte.d.ts +0 -26
  462. package/dist/icons/IconVideo.svelte.d.ts +0 -26
  463. package/dist/icons/IconWatch.svelte +0 -29
  464. package/dist/icons/IconWatch.svelte.d.ts +0 -26
  465. package/dist/icons/IconWatchOff.svelte +0 -34
  466. package/dist/icons/IconWatchOff.svelte.d.ts +0 -26
@@ -1,14 +1,18 @@
1
1
  <script lang="ts">
2
2
  import type {
3
3
  NeoListContext,
4
+ NeoListItemOrSection,
4
5
  NeoListMethods,
5
6
  NeoListProps,
6
7
  NeoListRenderContext,
7
8
  NeoListSection,
8
9
  NeoListSelectedItem,
9
10
  NeoListSelectEvent,
11
+ NeoListSelectMethods,
10
12
  } from './neo-list.model.js';
13
+ import type { SvelteEvent } from '../utils/html-element.utils.js';
11
14
 
15
+ import { isSafari } from '@dvcol/common-utils/common/browser';
12
16
  import { debounce } from '@dvcol/common-utils/common/debounce';
13
17
  import { shallowClone } from '@dvcol/common-utils/common/object';
14
18
  import { emptyAnimation, emptyTransition, flipToggle, scaleFreeze } from '@dvcol/svelte-utils/transition';
@@ -17,7 +21,7 @@
17
21
  import { fade, scale } from 'svelte/transition';
18
22
 
19
23
  import NeoDivider from '../divider/NeoDivider.svelte';
20
- import IconList from '../icons/IconList.svelte';
24
+ import NeoIconList from '../icons/NeoIconList.svelte';
21
25
  import { findByIdInList, isSection, showDivider } from './neo-list.model.js';
22
26
  import NeoListBaseItem from './NeoListBaseItem.svelte';
23
27
  import NeoListBaseLoader from './NeoListBaseLoader.svelte';
@@ -47,9 +51,10 @@
47
51
  filter = $bindable(item => !item?.hidden),
48
52
  sort = $bindable(() => 0),
49
53
  loading = false,
50
- skeleton = false,
51
54
  scrollToLoader,
55
+ scrollTolerance = 1,
52
56
 
57
+ divider,
53
58
  select = false,
54
59
  multiple = false,
55
60
  nullable = true,
@@ -57,11 +62,13 @@
57
62
  disabled,
58
63
  readonly,
59
64
  reverse,
65
+ flip,
60
66
  dim,
61
67
 
62
68
  // Styles
63
69
  shadow = true,
64
70
  scrollbar = true,
71
+ rounded,
65
72
 
66
73
  // Size
67
74
  flex,
@@ -75,6 +82,8 @@
75
82
 
76
83
  // Events
77
84
  onSelect,
85
+ onScrollTop,
86
+ onScrollBottom,
78
87
 
79
88
  // Other props
80
89
  containerProps,
@@ -86,6 +95,9 @@
86
95
  ...rest
87
96
  }: NeoListProps = $props();
88
97
 
98
+ // TODO - pull to refresh (in mixin or component)
99
+ // TODO - floating button (back to top)
100
+
89
101
  const { tag: containerTag = 'div', ...containerRest } = $derived(containerProps ?? {});
90
102
 
91
103
  const empty = $derived(!items?.length);
@@ -96,21 +108,37 @@
96
108
 
97
109
  const isNullable = $derived(multiple ? nullable || (isMultiple(selected) && (selected?.length ?? 0) > 1) : nullable);
98
110
 
99
- const scrollTop: NeoListMethods['scrollTop'] = debounce((options?: ScrollToOptions) => {
111
+ const onScrollEvent = (e?: SvelteEvent) => {
112
+ if (!ref) return;
113
+ // if at the top console.info('top');
114
+ if (ref.scrollTop === 0) {
115
+ if (flip) return onScrollBottom?.(e);
116
+ else return onScrollTop?.(e);
117
+ }
118
+ // if at the bottom console.info('bottom');
119
+ if (Math.abs(Math.abs(ref.scrollTop) + ref.clientHeight - ref.scrollHeight) <= scrollTolerance) {
120
+ if (flip) return onScrollTop?.(e);
121
+ else return onScrollBottom?.(e);
122
+ }
123
+ };
124
+
125
+ export const scrollToTop: NeoListMethods['scrollToTop'] = debounce((options?: ScrollToOptions) => {
100
126
  if (!ref) return false;
101
- ref.scrollTo({ top: 0, behavior: 'smooth', ...options });
127
+ ref.scrollTo({ top: flip ? -ref.scrollHeight : 0, behavior: 'smooth', ...options });
128
+ onScrollEvent();
102
129
  return ref;
103
130
  }, shortDuration / 2);
104
131
 
105
- const scrollBottom: NeoListMethods['scrollBottom'] = debounce((options?: ScrollToOptions) => {
132
+ export const scrollToBottom: NeoListMethods['scrollToBottom'] = debounce((options?: ScrollToOptions) => {
106
133
  if (!ref?.scrollHeight) return false;
107
- ref.scrollTo({ top: ref.scrollHeight, behavior: 'smooth', ...options });
134
+ ref.scrollTo({ top: flip ? 0 : ref.scrollHeight, behavior: 'smooth', ...options });
135
+ onScrollEvent();
108
136
  return ref;
109
137
  }, shortDuration / 2);
110
138
 
111
139
  $effect(() => {
112
140
  if (!loading || !scrollToLoader) return;
113
- scrollBottom();
141
+ scrollToBottom();
114
142
  });
115
143
 
116
144
  const scrollReverse = async () => {
@@ -120,7 +148,7 @@
120
148
  };
121
149
 
122
150
  $effect(() => {
123
- if (!reverse || !ref) return;
151
+ if (!flip || !ref) return;
124
152
  scrollReverse();
125
153
  });
126
154
 
@@ -132,7 +160,7 @@
132
160
  return shallowClone(selection, Array.isArray(selection) ? 3 : 2);
133
161
  };
134
162
 
135
- const selectItem: NeoListMethods['selectItem'] = (...selection: NeoListSelectedItem[]): NeoListSelectEvent | undefined => {
163
+ const selectItem: NeoListSelectMethods['selectItem'] = (...selection: NeoListSelectedItem[]): NeoListSelectEvent | undefined => {
136
164
  if (disabled || readonly || !selection?.length) return;
137
165
  if (!select) throw new NeoErrorListSelectDisabled();
138
166
 
@@ -146,7 +174,7 @@
146
174
  return { type: 'select', previous, current: cloneSelection(), added: selection };
147
175
  };
148
176
 
149
- const clearItem: NeoListMethods['clearItem'] = (...selection: NeoListSelectedItem[]): NeoListSelectEvent | undefined => {
177
+ const clearItem: NeoListSelectMethods['clearItem'] = (...selection: NeoListSelectedItem[]): NeoListSelectEvent | undefined => {
150
178
  if (disabled || readonly) return;
151
179
  if (!select) throw new NeoErrorListSelectDisabled();
152
180
 
@@ -175,7 +203,7 @@
175
203
  /**
176
204
  * Re-selects the previous selection if it still exists in the list
177
205
  */
178
- const reSelect: NeoListMethods['reSelect'] = () => {
206
+ const reSelect: NeoListSelectMethods['reSelect'] = () => {
179
207
  if (!select || missing || !selected) return;
180
208
  if (Array.isArray(selected) && !selected.length) return;
181
209
  const previous = cloneSelection();
@@ -203,16 +231,18 @@
203
231
  // States
204
232
  items,
205
233
 
206
- select,
207
- multiple,
208
- nullable,
209
- selected,
210
-
234
+ divider,
211
235
  loading,
212
- skeleton,
213
236
  disabled,
214
237
  readonly,
215
238
  reverse,
239
+ flip,
240
+
241
+ // Selection
242
+ select,
243
+ multiple,
244
+ nullable,
245
+ selected,
216
246
 
217
247
  // Filter
218
248
  get highlight() {
@@ -235,8 +265,8 @@
235
265
  },
236
266
 
237
267
  // Methods
238
- scrollTop,
239
- scrollBottom,
268
+ scrollToTop,
269
+ scrollToBottom,
240
270
  selectItem,
241
271
  clearItem,
242
272
  reSelect,
@@ -245,11 +275,22 @@
245
275
  $effect(() => {
246
276
  if (!ref) return;
247
277
  Object.assign(ref, {
248
- scrollTop,
249
- scrollBottom,
278
+ scrollToTop,
279
+ scrollToBottom,
250
280
  });
251
281
  });
252
282
 
283
+ const onscroll: NeoListProps['onscroll'] = debounce((e) => {
284
+ rest?.onscroll?.(e);
285
+ onScrollEvent(e);
286
+ }, 25);
287
+
288
+ const renderDivider = (index: number, array: { item: NeoListItemOrSection }[], position: 'top' | 'bottom') => {
289
+ if (position === 'top') return index && (showDivider(array[index]?.item.divider, 'top') ?? showDivider(divider, 'top'));
290
+ if (index >= array.length - 1) return false;
291
+ return showDivider(array[index].item.divider, 'bottom') && !showDivider(array[index + 1]?.item.divider, 'top');
292
+ };
293
+
253
294
  const width = $derived(toSize(_width));
254
295
  const height = $derived(toSize(_height));
255
296
 
@@ -284,7 +325,7 @@
284
325
  {@render itemEmpty(context)}
285
326
  {:else}
286
327
  <div class="neo-list-empty-content">
287
- <IconList size="3rem" stroke="1" />
328
+ <NeoIconList size="3rem" stroke="1" />
288
329
  <div>No items</div>
289
330
  </div>
290
331
  {/if}
@@ -295,22 +336,22 @@
295
336
  ?.map((item, index) => ({ item, index }))
296
337
  .filter(({ item }) => filter(item))
297
338
  .sort((a, b) => sort(a.item, b.item))}
298
- {#if !visible?.length}
339
+ {#if !visible?.length && !loading}
299
340
  {@render emptyItem(section?.empty)}
300
341
  {:else}
301
342
  <!-- Items -->
302
- {#each visible as { item, index } (item.id ?? index)}
343
+ {#each visible as { item, index }, i (item.id ?? index)}
303
344
  {@const checked = !isSection(item) && isChecked({ index, item, sectionIndex, section })}
304
345
  <svelte:element
305
346
  this={item.tag ?? 'li'}
306
347
  role={select ? 'option' : 'listitem'}
348
+ data-id={item?.id}
307
349
  data-index={index}
308
350
  data-section={sectionIndex}
309
351
  aria-selected={checked}
310
352
  aria-posinset={index + 1}
311
- aria-setsize={array.length}
353
+ aria-setsize={visible.length}
312
354
  class:neo-list-item={true}
313
- class:neo-skeleton={skeleton}
314
355
  class:neo-checked={checked}
315
356
  class:neo-list-item-select={select}
316
357
  style:--neo-list-item-color={getColorVariable(item.color)}
@@ -319,7 +360,7 @@
319
360
  out:inFn={inProps}
320
361
  in:outFn={outProps}
321
362
  >
322
- {#if index && showDivider(item.divider, 'top')}
363
+ {#if renderDivider(i, visible, flip && !isSafari() ? 'bottom' : 'top')}
323
364
  <NeoDivider aria-hidden="true" {...dividerProps} {...item.dividerProps} class={['neo-list-item-divider', item.dividerProps?.class]} />
324
365
  {/if}
325
366
  {#if isSection(item)}
@@ -327,7 +368,7 @@
327
368
  {#if customSection && !item.render}
328
369
  {@render customSection(list, sectionContext)}
329
370
  {:else}
330
- <NeoListBaseSection section={item} {index} {context} {skeleton} {select} {list} {...sectionProps} />
371
+ <NeoListBaseSection section={item} {index} {context} {select} {list} {reverse} {flip} {...sectionProps} />
331
372
  {/if}
332
373
  {:else if customItem && !item.render}
333
374
  {@render customItem({ item, index, checked, context })}
@@ -336,18 +377,20 @@
336
377
  {item}
337
378
  {index}
338
379
  {context}
339
- {skeleton}
340
380
  {checked}
341
381
  {select}
342
382
  {highlight}
343
383
  {buttonProps}
384
+ {reverse}
385
+ {rounded}
386
+ flip={flip && !isSafari()}
344
387
  disabled={item.disabled || disabled || section?.disabled}
345
388
  readonly={item.readonly || readonly || section?.readonly || (!isNullable && checked)}
346
389
  {...itemProps}
347
390
  onclick={select ? () => toggleItem({ index, item, sectionIndex, section }, checked) : undefined}
348
391
  />
349
392
  {/if}
350
- {#if index < visible.length - 1 && showDivider(item.divider, 'bottom') && !showDivider(visible[index + 1].item.divider, 'bottom')}
393
+ {#if renderDivider(i, visible, flip && !isSafari() ? 'top' : 'bottom')}
351
394
  <NeoDivider aria-hidden="true" {...dividerProps} {...item.dividerProps} class={['neo-list-item-divider', item.dividerProps?.class]} />
352
395
  {/if}
353
396
  </svelte:element>
@@ -359,7 +402,7 @@
359
402
  this={containerTag}
360
403
  class:neo-list={true}
361
404
  class:neo-empty={empty}
362
- class:neo-reverse={reverse}
405
+ class:neo-flip={flip}
363
406
  style:flex
364
407
  style:width={width?.absolute}
365
408
  style:min-width={width?.min}
@@ -370,7 +413,7 @@
370
413
  {...containerRest}
371
414
  >
372
415
  {@render before?.(context)}
373
- {#if !empty || loading || skeleton}
416
+ {#if !empty || loading}
374
417
  <svelte:element
375
418
  this={tag}
376
419
  role={select ? 'listbox' : 'list'}
@@ -378,14 +421,14 @@
378
421
  class:neo-list-items={true}
379
422
  class:neo-scroll={scrollbar}
380
423
  class:neo-shadow={shadow}
381
- class:neo-rounded={buttonProps?.rounded}
382
424
  class:neo-dim={dim}
383
425
  in:scaleFreeze={quickScaleProps}
426
+ {onscroll}
384
427
  {...rest}
385
428
  >
386
429
  {@render children?.(context)}
387
430
  {@render list({ items, context })}
388
- {@render loader(loading || (empty && skeleton))}
431
+ {@render loader(loading || empty)}
389
432
  </svelte:element>
390
433
  {:else}
391
434
  <svelte:element
@@ -395,6 +438,7 @@
395
438
  bind:this={ref}
396
439
  class:neo-list-empty={true}
397
440
  in:fade={quickDurationProps}
441
+ {onscroll}
398
442
  {...rest}
399
443
  >
400
444
  {@render emptyItem()}
@@ -406,6 +450,7 @@
406
450
  <style>.neo-list {
407
451
  display: flex;
408
452
  flex-direction: column;
453
+ width: 100%;
409
454
  height: 100%;
410
455
  }
411
456
  .neo-list-loader, .neo-list-item {
@@ -426,28 +471,24 @@
426
471
  max-height: 100%;
427
472
  margin: 0;
428
473
  padding: 0;
429
- border-radius: var(--neo-border-radius);
474
+ border-radius: var(--neo-list-border-radius, var(--neo-border-radius));
430
475
  }
431
476
  .neo-list-items {
477
+ overflow: auto;
432
478
  padding-inline: var(--neo-list-padding, 0.375rem);
433
479
  padding-block: var(--neo-list-padding, 0.375rem);
434
- overflow: auto;
435
480
  }
436
- .neo-list-items.neo-scroll, .neo-list-items.neo-rounded {
437
- padding-block: var(--neo-menu-scroll-padding, 0.625rem);
481
+ .neo-list-items.neo-scroll {
482
+ padding-block: var(--neo-list-scroll-padding, 0.625rem);
438
483
  }
439
- .neo-list-items.neo-scroll:not(.neo-scroll) :global(> .neo-list-item), .neo-list-items.neo-rounded:not(.neo-scroll) :global(> .neo-list-item) {
440
- padding: 0 var(--neo-menu-padding, var(--neo-gap-tiny, 0.25rem));
484
+ .neo-list-items.neo-scroll.neo-shadow {
485
+ mask-image: linear-gradient(to var(--neo-scroll-direction, top), black, black, transparent 0, black var(--neo-scroll-shadow-size, 1rem), black calc(100% - var(--neo-scroll-shadow-size, 1rem)), transparent);
441
486
  }
442
487
  .neo-list-items.neo-scroll {
443
- padding-block: var(--neo-list-scroll-padding, 0.625rem);
444
488
  scrollbar-gutter: stable both-edges;
445
489
  overflow: var(--neo-scrollbar-overflow, auto);
446
490
  transition: --neo-thumb-color 0.45s ease 0.1s;
447
491
  }
448
- .neo-list-items.neo-scroll.neo-shadow {
449
- mask-image: linear-gradient(to var(--neo-scroll-direction, top), black, black, transparent 0, black var(--neo-scroll-shadow-size, 1rem), black calc(100% - var(--neo-scroll-shadow-size, 1rem)), transparent);
450
- }
451
492
  .neo-list-items.neo-scroll:focus-within, .neo-list-items.neo-scroll:focus, .neo-list-items.neo-scroll:hover {
452
493
  --neo-thumb-color: var(--neo-scrollbar-color);
453
494
  transition: --neo-thumb-color 0.45s ease 0s;
@@ -471,10 +512,10 @@
471
512
  background-color: var(--neo-thumb-color, transparent);
472
513
  }
473
514
  .neo-list-items.neo-scroll::-webkit-scrollbar-button:vertical {
474
- height: var(--neo-list-scrollbar-padding, 0.5rem);
515
+ height: var(--neo-list-scrollbar-padding, 0.625rem);
475
516
  }
476
517
  .neo-list-items.neo-scroll::-webkit-scrollbar-button:horizontal {
477
- width: var(--neo-list-scrollbar-padding, 0.5rem);
518
+ width: var(--neo-list-scrollbar-padding, 0.625rem);
478
519
  }
479
520
  .neo-list-items.neo-scroll::-webkit-scrollbar-thumb {
480
521
  background-color: var(--neo-thumb-color, transparent);
@@ -510,33 +551,30 @@
510
551
  transition-duration: 0.6s;
511
552
  }
512
553
  .neo-list-loader.neo-select {
513
- gap: var(--neo-gap-tiny, 0.25rem);
554
+ gap: var(--neo-gap-xs, 0.625rem);
514
555
  }
515
556
  .neo-list-item :global(> .neo-list-item-button) {
516
557
  width: 100%;
517
558
  }
518
- .neo-list-item.neo-skeleton {
519
- pointer-events: none;
520
- }
521
- .neo-list-item-select :global(> .neo-list-item-button.neo-rounded) {
522
- border-radius: var(--neo-btn-border-radius-rounded, var(--neo-border-radius-md));
523
- }
524
559
  .neo-list-item-select :global(> .neo-list-base-loader:first-child) {
525
560
  margin-top: 0.25rem;
526
561
  }
527
562
  .neo-list-item :global(> .neo-list-item-divider) {
528
- margin-block: 0.5rem;
529
563
  color: var(--neo-list-divider-color, var(--neo-text-color));
564
+ margin-block: 0.5rem;
530
565
  }
531
566
  .neo-list-item:hover :global(> .neo-list-section-title),
532
- .neo-list-item:hover :global(> .neo-list-item-button .neo-list-item-content),
533
- .neo-list-item:hover :global(> .neo-list-item-button .neo-list-item-description), .neo-list-item:focus :global(> .neo-list-section-title),
534
- .neo-list-item:focus :global(> .neo-list-item-button .neo-list-item-content),
535
- .neo-list-item:focus :global(> .neo-list-item-button .neo-list-item-description), .neo-list-item:focus-within :global(> .neo-list-section-title),
536
- .neo-list-item:focus-within :global(> .neo-list-item-button .neo-list-item-content),
537
- .neo-list-item:focus-within :global(> .neo-list-item-button .neo-list-item-description) {
567
+ .neo-list-item:hover :global(> .neo-list-item-button .neo-list-item-content), .neo-list-item:focus :global(> .neo-list-section-title),
568
+ .neo-list-item:focus :global(> .neo-list-item-button .neo-list-item-content), .neo-list-item:focus-within :global(> .neo-list-section-title),
569
+ .neo-list-item:focus-within :global(> .neo-list-item-button .neo-list-item-content) {
538
570
  color: var(--neo-text-color-highlight);
539
571
  }
572
+ .neo-list-item:hover :global(> .neo-list-item-button .neo-list-item-description),
573
+ .neo-list-item:hover :global(> .neo-list-item-button .neo-list-item-tags), .neo-list-item:focus :global(> .neo-list-item-button .neo-list-item-description),
574
+ .neo-list-item:focus :global(> .neo-list-item-button .neo-list-item-tags), .neo-list-item:focus-within :global(> .neo-list-item-button .neo-list-item-description),
575
+ .neo-list-item:focus-within :global(> .neo-list-item-button .neo-list-item-tags) {
576
+ color: var(--neo-text-color-secondary-highlight);
577
+ }
540
578
  .neo-list-empty-content {
541
579
  display: flex;
542
580
  flex: 1 1 auto;
@@ -547,12 +585,12 @@
547
585
  min-width: var(--neo-list-min-width, 8rem);
548
586
  min-height: var(--neo-list-min-height);
549
587
  }
550
- .neo-list.neo-reverse {
588
+ .neo-list.neo-flip {
551
589
  flex-direction: column-reverse;
552
590
  justify-content: end;
553
591
  }
554
592
  @supports not ((hanging-punctuation: first) and (font: -apple-system-body) and (-webkit-appearance: none)) {
555
- .neo-list.neo-reverse .neo-list-items {
593
+ .neo-list.neo-flip .neo-list-items {
556
594
  flex-direction: column-reverse;
557
595
  justify-content: end;
558
596
  }
@@ -1,4 +1,7 @@
1
- import type { NeoListProps } from './neo-list.model.js';
2
- declare const NeoList: import("svelte").Component<NeoListProps, {}, "ref" | "filter" | "sort" | "highlight" | "selected">;
1
+ import type { NeoListMethods, NeoListProps } from './neo-list.model.js';
2
+ declare const NeoList: import("svelte").Component<NeoListProps, {
3
+ scrollToTop: NeoListMethods["scrollToTop"];
4
+ scrollToBottom: NeoListMethods["scrollToBottom"];
5
+ }, "ref" | "filter" | "sort" | "selected" | "highlight">;
3
6
  type NeoList = ReturnType<typeof NeoList>;
4
7
  export default NeoList;