@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
@@ -0,0 +1,459 @@
1
+ <script lang="ts">
2
+ import type { NeoNotificationItemProps } from './neo-notification-item.model.js';
3
+
4
+ import { debounce } from '@dvcol/common-utils/common/debounce';
5
+ import { flyFrom } from '@dvcol/svelte-utils';
6
+ import { focusin } from '@dvcol/svelte-utils/focusin';
7
+ import { hovering } from '@dvcol/svelte-utils/hovering';
8
+ import { onDestroy, onMount } from 'svelte';
9
+
10
+ import { NeoNotificationPlacements } from '../common/neo-placement.model.js';
11
+ import { NeoNotificationEvent, NeoNotificationStatus, NeoNotificationType } from './neo-notification.model.js';
12
+ import NeoSimpleNotification from './NeoSimpleNotification.svelte';
13
+ import { computeBorderRadius } from '../../utils/border.utils.js';
14
+ import { getColorVariable } from '../../utils/colors.utils.js';
15
+ import { coerce, computeGlassFilter, computeShadowElevation, PositiveMinMaxElevation } from '../../utils/shadow.utils.js';
16
+
17
+ let {
18
+ // Snippets
19
+ children,
20
+ before,
21
+ after,
22
+
23
+ // State
24
+ ref = $bindable(),
25
+ hovered = $bindable(false),
26
+ focused = $bindable(false),
27
+
28
+ tag = 'li',
29
+
30
+ index,
31
+ item,
32
+ posinset,
33
+ setsize,
34
+ visible = 0,
35
+
36
+ // Style
37
+ elevation: _elevation = 1,
38
+ blur: _blur,
39
+ color: _color,
40
+ filled,
41
+ tinted,
42
+ rounded: _rounded,
43
+ borderless,
44
+
45
+ // Behavior
46
+ expand,
47
+ reverse,
48
+ draggable,
49
+ swipeable,
50
+ placement = NeoNotificationPlacements.BottomEnd,
51
+ threshold = { x: 3, y: 2 },
52
+ stagger = 16,
53
+ swiped,
54
+ restartOnTouch,
55
+
56
+ progress,
57
+ loading,
58
+ close = true,
59
+
60
+ // Events
61
+
62
+ onChange: onStateChange,
63
+ onDrag,
64
+ onCancel,
65
+
66
+ // Other Props
67
+
68
+ containerProps: _containerProps,
69
+ progressProps,
70
+ actionProps,
71
+ closeProps,
72
+ ...rest
73
+ }: NeoNotificationItemProps = $props();
74
+
75
+ const { tag: containerTag, ...containerProps } = $derived(_containerProps ?? {});
76
+ const { id, tag: itemTag, ...itemProps } = $derived(item?.containerProps ?? {});
77
+
78
+ const elevation = $derived(coerce(item.elevation ?? _elevation!, PositiveMinMaxElevation));
79
+ const blur = $derived(coerce(item.blur ?? _blur ?? _elevation!, PositiveMinMaxElevation));
80
+
81
+ const filter = $derived(computeGlassFilter(blur, true));
82
+ const shadow = $derived(computeShadowElevation(elevation, { glass: true }, PositiveMinMaxElevation));
83
+
84
+ const color = $derived.by(() => {
85
+ if (item.color) return getColorVariable(item.color);
86
+ if (_color) return getColorVariable(_color);
87
+ if (item.type === NeoNotificationType.Info) return getColorVariable('primary');
88
+ return getColorVariable(item.type);
89
+ });
90
+
91
+ const rounded = $derived.by(() => {
92
+ const isRounded = item.rounded ?? _rounded;
93
+ if (isRounded === true) return 'xl';
94
+ return isRounded;
95
+ });
96
+
97
+ const first = $derived(index === visible - 1);
98
+ const last = $derived(index === 0);
99
+
100
+ function getNotifications() {
101
+ const parent = ref?.parentElement;
102
+ const array = parent?.querySelectorAll<HTMLElement>('.neo-notification-stack-item:not([inert])');
103
+ return { parent, array };
104
+ }
105
+
106
+ function getTotalHeight(el?: HTMLElement): number {
107
+ if (!el) return 0;
108
+ const styles = getComputedStyle(el);
109
+ return el.offsetHeight + (Number.parseFloat(styles.marginTop) || 0) + (Number.parseFloat(styles.marginBottom) || 0);
110
+ }
111
+
112
+ const translate = $derived.by(() => {
113
+ if ((posinset === setsize) && reverse) return;
114
+ if (!expand) return `0 ${(reverse ? 0 : -getTotalHeight(ref)) + stagger * (visible - 1 - index) * (reverse ? 1 : -1)}px`;
115
+
116
+ const { parent, array } = getNotifications();
117
+ if (!array?.length) return;
118
+ const heights = Array.from(array).map(getTotalHeight);
119
+ if (!heights?.length) return;
120
+ const bottom = reverse ? index + 1 : index;
121
+ const offset = heights.slice(bottom, heights.length).reduce((acc, h) => acc + h, 0);
122
+ const position = heights.length - 1 - index;
123
+ const gap = parent ? Number.parseFloat(getComputedStyle(parent).gap) || 0 : 0;
124
+ return `0 ${reverse ? '' : '-'}${offset + gap * position}px`;
125
+ });
126
+
127
+ const scale = $derived.by(() => {
128
+ if (expand) return;
129
+ return 1 - (visible - 1 - index) * 0.05;
130
+ });
131
+
132
+ let initial: Record<'x' | 'y', number> | false = $state(false);
133
+ let offset: Record<'x' | 'y', number> = $state({ x: 0, y: 0 });
134
+
135
+ const transform = $derived.by(() => {
136
+ if (!draggable || !initial) return;
137
+ return `translate(${offset.x}px, ${offset.y}px)`;
138
+ });
139
+
140
+ function onDragMove(event: PointerEvent) {
141
+ if (!draggable || !initial) return;
142
+ offset = { x: event.movementX + offset.x, y: event.movementY + offset.y };
143
+ onDrag?.({ item, index, event, offset, initial });
144
+ };
145
+
146
+ function cancelDrag({
147
+ top = placement?.startsWith('top'),
148
+ bottom = placement?.startsWith('bottom'),
149
+ start = placement?.endsWith('start'),
150
+ end = placement?.endsWith('end'),
151
+ fraction = threshold,
152
+ } = {}) {
153
+ if (!ref) return false;
154
+ const { x, y } = typeof fraction === 'number' ? { x: fraction, y: fraction } : fraction;
155
+ if (top && (offset.y < -ref.clientHeight / y)) return true;
156
+ if (bottom && (offset.y > ref.clientHeight / y)) return true;
157
+ if (end && (offset.x > ref.clientWidth / x)) return true;
158
+ return start && (offset.x < -ref.clientWidth / x);
159
+ }
160
+
161
+ function resetState() {
162
+ initial = false;
163
+ setTimeout(() => {
164
+ offset = { x: 0, y: 0 };
165
+ });
166
+ }
167
+
168
+ let cancelled = $state(false);
169
+ function cancelItem(event: PointerEvent | WheelEvent | MouseEvent, status = NeoNotificationStatus.Dismissed) {
170
+ if (cancelled || !cancelDrag()) return cancelled;
171
+ cancelled = true;
172
+ item.cancel(status);
173
+ onCancel?.({ item, index, event });
174
+ return cancelled;
175
+ }
176
+
177
+ function onDragEnd(event: PointerEvent) {
178
+ cancelItem(event);
179
+ window.removeEventListener('pointermove', onDragMove);
180
+ window.removeEventListener('pointerup', onDragEnd);
181
+ window.removeEventListener('pointercancel', onDragEnd);
182
+ window.removeEventListener('pointerleave', onDragEnd);
183
+ resetState();
184
+ onDrag?.({ item, index, event, offset, initial });
185
+ }
186
+
187
+ function onDragStart(event: PointerEvent) {
188
+ if (!draggable) return;
189
+ if (event.button !== 0) return; // Only left click
190
+ initial = { x: event.clientX, y: event.clientY };
191
+ event.preventDefault();
192
+ window.addEventListener('pointermove', onDragMove);
193
+ window.addEventListener('pointerup', onDragEnd);
194
+ window.addEventListener('pointercancel', onDragEnd);
195
+ window.addEventListener('pointerleave', onDragEnd);
196
+ onDrag?.({ item, index, event, offset, initial });
197
+ }
198
+
199
+ const debounceReset = debounce(resetState, 100);
200
+
201
+ function onWheel(event: WheelEvent) {
202
+ if (!swipeable) return;
203
+ event.preventDefault();
204
+ if (swiped) return;
205
+ const axis = Math.abs(event.deltaX) > Math.abs(event.deltaY) ? 'x' : 'y';
206
+ const off = axis === 'x' ? 'y' : 'x';
207
+ if (['top', 'bottom'].includes(placement) && axis === 'x') return;
208
+ if (placement?.endsWith('start') && axis === 'x' && (event.deltaX < 0)) return;
209
+ if (placement?.endsWith('end') && axis === 'x' && (event.deltaX > 0)) return;
210
+ if (placement?.startsWith('top') && axis === 'y' && (event.deltaY < 0)) return;
211
+ if (placement?.startsWith('bottom') && axis === 'y' && (event.deltaY > 0)) return;
212
+ debounceReset.cancel();
213
+ const delta = axis === 'x' ? event.deltaX : event.deltaY;
214
+ if (!initial) initial = ({ [axis]: delta, [off]: 0 } as Record<'x' | 'y', number>);
215
+ offset[axis] -= delta;
216
+ onDrag?.({ item, index, event, offset, initial });
217
+ if (cancelItem(event)) {
218
+ removeWheel();
219
+ return resetState();
220
+ }
221
+ debounceReset();
222
+ }
223
+
224
+ function removeWheel() {
225
+ window?.removeEventListener('wheel', onWheel);
226
+ ref?.removeEventListener('pointerleave', onLeave);
227
+ }
228
+
229
+ const debounceLeave = debounce(removeWheel, 300);
230
+
231
+ function onLeave() {
232
+ if (!cancelled) return debounceLeave();
233
+ removeWheel();
234
+ }
235
+
236
+ function onEnter() {
237
+ if (!swipeable || !ref) return;
238
+ debounceLeave.cancel();
239
+ window.addEventListener('wheel', onWheel, { passive: false });
240
+ ref.addEventListener('pointerleave', onLeave);
241
+ }
242
+
243
+ const inParams = $derived({
244
+ y: last && !first ? 0 : `${reverse ? '-' : ''}150%`,
245
+ duration: 600,
246
+ scale: 1,
247
+ delay: last && !first ? 300 : 10,
248
+ opacity: last && !first ? 0 : 1,
249
+ });
250
+
251
+ const outParams = $derived.by(() => {
252
+ let x: string | number = 0;
253
+ let y: string | number = last && !first && !expand ? 0 : `${reverse ? '-' : ''}50%`;
254
+
255
+ // If moving left/right
256
+ if (Math.abs(offset.y) < Math.abs(offset.x)) {
257
+ if (placement?.endsWith('start')) {
258
+ x = '-50%';
259
+ y = 0;
260
+ } else if (placement?.endsWith('end')) {
261
+ x = '50%';
262
+ y = 0;
263
+ }
264
+ }
265
+
266
+ return {
267
+ x,
268
+ y,
269
+ duration: 600,
270
+ scale: 0.95,
271
+ opacity: 0,
272
+ };
273
+ });
274
+
275
+ const onChange = debounce((_, event: PointerEvent | FocusEvent) => {
276
+ if (Math.abs(offset.x) > 16 || Math.abs(offset.y) > 16) return;
277
+ onStateChange?.({ item, index, hovered, focused, event });
278
+ }, 100);
279
+
280
+ $effect(() => {
281
+ if (!ref) return;
282
+ ref.addEventListener('pointerdown', onDragStart);
283
+ ref.addEventListener('pointerenter', onEnter);
284
+ return () => {
285
+ if (!ref) return;
286
+ ref.removeEventListener('pointerdown', onDragStart);
287
+ ref.removeEventListener('pointerenter', onEnter);
288
+ };
289
+ });
290
+
291
+ onMount(() => {
292
+ item.visible = Date.now();
293
+ item.onChange?.(NeoNotificationEvent.Visible, item);
294
+ });
295
+
296
+ onDestroy(() => {
297
+ item.hidden = Date.now();
298
+ item.onChange?.(NeoNotificationEvent.Hidden, item);
299
+ });
300
+ </script>
301
+
302
+ <svelte:element
303
+ {...rest}
304
+ {...containerProps}
305
+ {...itemProps}
306
+ bind:this={ref}
307
+ this={itemTag ?? containerTag ?? tag}
308
+ data-id={id}
309
+ data-index={index}
310
+ data-first={first}
311
+ data-last={last}
312
+ data-visible={visible}
313
+ aria-setsize={setsize}
314
+ aria-posinset={posinset}
315
+ class:neo-notification-stack-item={true}
316
+ class:neo-draggable={draggable}
317
+ class:neo-dragging={transform}
318
+ class:neo-rounded={rounded}
319
+ class:neo-tinted={item.tinted ?? tinted}
320
+ class:neo-filled={item.filled ?? filled}
321
+ class:neo-flat={!elevation}
322
+ class:neo-borderless={item.borderless ?? borderless}
323
+ style:--neo-notification-border-radius={computeBorderRadius(item.rounded ?? rounded)}
324
+ style:--neo-notification-color={color}
325
+ style:--neo-notification-box-shadow={shadow}
326
+ style:--neo-notification-filter={filter}
327
+ style:--neo-notification-elevation={index}
328
+ style:scale
329
+ style:translate
330
+ style:transform
331
+ use:focusin={{
332
+ get focusin() {
333
+ return focused;
334
+ },
335
+ set focusin(_value) {
336
+ focused = _value;
337
+ },
338
+ onChange,
339
+ }}
340
+ use:hovering={{
341
+ get hovered() {
342
+ return hovered;
343
+ },
344
+ set hovered(_value) {
345
+ hovered = _value;
346
+ },
347
+ onChange,
348
+ }}
349
+ in:flyFrom={inParams}
350
+ out:flyFrom={outParams}
351
+ >
352
+ {#if item.render}
353
+ {@render item.render?.(item)}
354
+ {:else if children}
355
+ {@render children?.(item)}
356
+ {:else}
357
+ <NeoSimpleNotification
358
+ {before}
359
+ {after}
360
+
361
+ {item}
362
+ {index}
363
+
364
+ {restartOnTouch}
365
+ {progress}
366
+ {loading}
367
+ {close}
368
+
369
+ {rounded}
370
+
371
+ {progressProps}
372
+ {actionProps}
373
+ {closeProps}
374
+
375
+ {onCancel}
376
+ />
377
+ {/if}
378
+ </svelte:element>
379
+
380
+ <style>.neo-notification-stack-item {
381
+ color: var(--neo-notification-color, inherit);
382
+ background-color: var(--neo-notification-bg-color, var(--neo-glass-background-color));
383
+ border: var(--neo-border-width, 1px) solid var(--neo-notification-border-color, var(--neo-glass-background-color));
384
+ border-color: var(--neo-notification-border-color, var(--neo-glass-top-border-color) var(--neo-glass-right-border-color) var(--neo-glass-bottom-border-color) var(--neo-glass-left-border-color));
385
+ border-radius: var(--neo-notification-border-radius, var(--neo-border-radius));
386
+ outline: none;
387
+ box-shadow: var(--neo-notification-box-shadow, var(--neo-glass-box-shadow-raised-1));
388
+ backdrop-filter: var(--neo-notification-content-filter, var(--neo-blur-3));
389
+ z-index: var(--neo-notification-z-index, calc(var(--neo-z-index-layer-top, 1000) + var(--neo-notification-elevation, 1)));
390
+ }
391
+ .neo-notification-stack-item.neo-tinted {
392
+ background-color: var(--neo-notification-bg-color, var(--neo-glass-background-color-tinted));
393
+ }
394
+ .neo-notification-stack-item.neo-filled {
395
+ background-color: var(--neo-notification-bg-color, var(--neo-background-color));
396
+ border-color: var(--neo-notification-border-color, var(--neo-filled-top-border-color) var(--neo-filled-right-border-color) var(--neo-filled-bottom-border-color) var(--neo-filled-left-border-color));
397
+ }
398
+ .neo-notification-stack-item.neo-flat {
399
+ border-color: var(--neo-notification-border-color, var(--neo-glass-border-color-flat));
400
+ }
401
+ .neo-notification-stack-item.neo-borderless {
402
+ border-color: transparent;
403
+ }
404
+ .neo-notification-stack-item.neo-rounded {
405
+ border-radius: var(--neo-notification-border-radius, var(--neo-notification-border-radius-rounded, var(--neo-border-radius-xxl)));
406
+ }
407
+ .neo-notification-stack-item {
408
+ position: absolute;
409
+ display: flex;
410
+ flex: 1 1 auto;
411
+ flex-direction: column;
412
+ box-sizing: border-box;
413
+ margin: var(--neo-notification-margin, var(--neo-gap-4xs));
414
+ transition: transform 0.6s ease, translate 0.6s ease, width 0.3s ease, height 0.3s ease, scale 0.3s ease, box-shadow 0.3s ease-out, backdrop-filter 0.3s ease, border-radius 0.3s ease, border-color 0.3s ease;
415
+ pointer-events: auto;
416
+ will-change: transform, opacity, scale, translate, backdrop-filter;
417
+ }
418
+ .neo-notification-stack-item[inert] {
419
+ z-index: var(--neo-z-index-layer-top, 2000000000);
420
+ }
421
+ .neo-notification-stack-item.neo-draggable {
422
+ cursor: grab;
423
+ touch-action: none;
424
+ }
425
+ .neo-notification-stack-item.neo-dragging {
426
+ transition: none;
427
+ }
428
+
429
+ .neo-notification {
430
+ display: flex;
431
+ align-items: center;
432
+ justify-content: space-between;
433
+ width: 100%;
434
+ height: 100%;
435
+ }
436
+ .neo-notification :global(.neo-notification-close-button) {
437
+ opacity: 0.5;
438
+ transition: opacity 0.3s ease;
439
+ }
440
+ .neo-notification:hover :global(.neo-notification-close-button), .neo-notification:active :global(.neo-notification-close-button), .neo-notification:focus :global(.neo-notification-close-button), .neo-notification:focus-within :global(.neo-notification-close-button), .neo-notification:focus-visible :global(.neo-notification-close-button) {
441
+ opacity: 1;
442
+ }
443
+ .neo-notification-content {
444
+ display: flex;
445
+ flex: 1 1 auto;
446
+ flex-direction: column;
447
+ width: max-content;
448
+ min-width: min(10rem, 80vw);
449
+ max-width: calc(100vw - 2rem);
450
+ padding: var(--neo-notification-padding, 0.5rem 1rem);
451
+ }
452
+ .neo-notification-actions {
453
+ display: flex;
454
+ align-items: flex-start;
455
+ justify-content: space-around;
456
+ height: stretch;
457
+ height: -webkit-fill-available; /* Chrome/Safari */
458
+ height: -moz-available; /* Firefox */
459
+ }</style>
@@ -0,0 +1,4 @@
1
+ import type { NeoNotificationItemProps } from './neo-notification-item.model.js';
2
+ declare const NeoNotificationItem: import("svelte").Component<NeoNotificationItemProps<"li">, {}, "ref" | "hovered" | "focused">;
3
+ type NeoNotificationItem = ReturnType<typeof NeoNotificationItem>;
4
+ export default NeoNotificationItem;
@@ -0,0 +1,49 @@
1
+ <script lang="ts">
2
+
3
+ import type { NeoNotificationProviderContext, NeoNotificationStackService, NotificationProviderProps } from './neo-notification-provider.model.js';
4
+
5
+ import { getUUID } from '@dvcol/common-utils/common/string';
6
+ import { SvelteMap } from 'svelte/reactivity';
7
+
8
+ import {
9
+
10
+ setNeoNotificationProviderContext,
11
+ } from './neo-notification-provider.model.js';
12
+ import NeoNotificationStack from './NeoNotificationStack.svelte';
13
+ import { NeoErrorNotificationDuplicateId } from '../../utils/error.utils.js';
14
+
15
+ let {
16
+ // Snippets
17
+ children,
18
+
19
+ // States
20
+ services = $bindable(new SvelteMap<NeoNotificationStackService['id'], NeoNotificationStackService>()),
21
+
22
+ // Other props
23
+ stack = { id: `default-${getUUID()}` },
24
+ }: NotificationProviderProps = $props();
25
+
26
+ setNeoNotificationProviderContext(
27
+ {
28
+ register: (service: NeoNotificationStackService) => {
29
+ if (services.has(service.id)) throw new NeoErrorNotificationDuplicateId(service.id!);
30
+ services.set(service.id, service);
31
+ console.info('Registered notification stack service:', service.id);
32
+ },
33
+ unregister: (id: NeoNotificationStackService['id']) => {
34
+ if (!services.has(id)) return;
35
+ services.delete(id);
36
+ },
37
+ get: (id?: NeoNotificationStackService['id']) => {
38
+ if (!id) return services.values().next().value;
39
+ return services.get(id);
40
+ },
41
+ } satisfies NeoNotificationProviderContext,
42
+ );
43
+ </script>
44
+
45
+ {@render children?.(services)}
46
+
47
+ {#if stack}
48
+ <NeoNotificationStack {...stack} />
49
+ {/if}
@@ -0,0 +1,4 @@
1
+ import type { NotificationProviderProps } from './neo-notification-provider.model.js';
2
+ declare const NeoNotificationProvider: import("svelte").Component<NotificationProviderProps, {}, "services">;
3
+ type NeoNotificationProvider = ReturnType<typeof NeoNotificationProvider>;
4
+ export default NeoNotificationProvider;