@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,15 +1,15 @@
1
1
  import type { MouseEventHandler } from 'svelte/elements';
2
2
  import type { NeoConfirmProps } from '../common/neo-confirm.model.js';
3
3
  import type { NeoDialogProps } from './neo-dialog.model.js';
4
- export type NeoDialogConfirmProps = {
4
+ export type NeoDialogConfirmProps<Tag extends keyof HTMLElementTagNameMap = keyof HTMLElementTagNameMap> = {
5
5
  /**
6
6
  * Element(s) to render inside the trigger.
7
7
  */
8
- children?: NeoDialogProps['children'] | string;
8
+ children?: NeoDialogProps<Tag>['children'] | string;
9
9
  /**
10
10
  * Element(s) to render inside the header once open.
11
11
  */
12
- header?: NeoDialogProps['children'] | string;
12
+ header?: NeoDialogProps<Tag>['children'] | string;
13
13
  /**
14
14
  * Event Handlers that fires on close.
15
15
  */
@@ -30,5 +30,5 @@ export type NeoDialogConfirmProps = {
30
30
  /**
31
31
  * Optional props to pass to the dialog.
32
32
  */
33
- dialogProps?: Omit<NeoDialogProps, 'ref' | 'open' | 'children' | 'header' | 'modal' | 'returnValue'>;
34
- } & Pick<NeoDialogProps, 'ref' | 'open' | 'modal' | 'moved' | 'returnValue' | 'closedby' | 'unmountOnClose' | 'placement' | 'movable' | 'outside' | 'elevation' | 'blur' | 'slide' | 'color' | 'filled' | 'tinted' | 'backdrop' | 'borderless' | 'flex' | 'align' | 'justify' | 'width' | 'height' | 'padding' | 'in' | 'out' | 'transition' | 'use' | 'backdropProps'> & Omit<NeoConfirmProps, 'children' | 'header'>;
33
+ dialogProps?: Omit<NeoDialogProps<Tag>, 'ref' | 'open' | 'children' | 'header' | 'modal' | 'returnValue'>;
34
+ } & Pick<NeoDialogProps<Tag>, 'ref' | 'open' | 'modal' | 'moved' | 'returnValue' | 'closedby' | 'unmountOnClose' | 'placement' | 'movable' | 'outside' | 'elevation' | 'blur' | 'slide' | 'color' | 'filled' | 'tinted' | 'backdrop' | 'borderless' | 'flex' | 'align' | 'justify' | 'width' | 'height' | 'padding' | 'in' | 'out' | 'transition' | 'use' | 'backdropProps'> & Omit<NeoConfirmProps, 'children' | 'header'>;
@@ -3,7 +3,7 @@ import type { NeoFloatingStepperProps } from '../common/neo-floating-stepper.mod
3
3
  import type { NeoDialogContext, NeoDialogProps } from './neo-dialog.model.js';
4
4
  import type { NeoTooltipProps } from '../tooltips/neo-tooltip.model.js';
5
5
  import type { NeoStepperContext } from '../../stepper/neo-stepper.model.js';
6
- export type NeoDialogStepperProps = {
6
+ export type NeoDialogStepperProps<Tag extends keyof HTMLElementTagNameMap = keyof HTMLElementTagNameMap> = {
7
7
  /**
8
8
  * Element(s) to render inside the stepper.
9
9
  */
@@ -19,7 +19,7 @@ export type NeoDialogStepperProps = {
19
19
  /**
20
20
  * The dialog element reference.
21
21
  */
22
- dialogRef?: NeoDialogProps['ref'];
22
+ dialogRef?: NeoDialogProps<Tag>['ref'];
23
23
  /**
24
24
  * Event Handlers that fires on close.
25
25
  */
@@ -40,5 +40,5 @@ export type NeoDialogStepperProps = {
40
40
  /**
41
41
  * Optional props to pass to the dialog.
42
42
  */
43
- dialogProps?: Omit<NeoDialogProps, 'ref' | 'open' | 'children' | 'header' | 'modal' | 'returnValue'>;
44
- } & Pick<NeoDialogProps, 'ref' | 'open' | 'modal' | 'moved' | 'returnValue' | 'closedby' | 'unmountOnClose' | 'placement' | 'movable' | 'outside' | 'elevation' | 'blur' | 'slide' | 'color' | 'filled' | 'tinted' | 'backdrop' | 'borderless' | 'flex' | 'align' | 'justify' | 'width' | 'height' | 'padding' | 'in' | 'out' | 'transition' | 'use' | 'backdropProps'> & Omit<NeoFloatingStepperProps, 'placement'>;
43
+ dialogProps?: Omit<NeoDialogProps<Tag>, 'ref' | 'open' | 'children' | 'header' | 'modal' | 'returnValue'>;
44
+ } & Pick<NeoDialogProps<Tag>, 'ref' | 'open' | 'modal' | 'moved' | 'returnValue' | 'closedby' | 'unmountOnClose' | 'placement' | 'movable' | 'outside' | 'elevation' | 'blur' | 'slide' | 'color' | 'filled' | 'tinted' | 'backdrop' | 'borderless' | 'flex' | 'align' | 'justify' | 'width' | 'height' | 'padding' | 'in' | 'out' | 'transition' | 'use' | 'backdropProps'> & Omit<NeoFloatingStepperProps, 'placement'>;
@@ -5,6 +5,7 @@ import type { NeoDialogPlacement } from '../common/neo-placement.model.js';
5
5
  import type { NeoMovable, NeoMovableOutside, NeoMovableResetOptions, NeoMoved } from './use-movable.svelte.js';
6
6
  import type { NeoPortalProps } from '../portal/neo-portal.model.js';
7
7
  import type { HTMLActionProps } from '../../utils/action.utils.js';
8
+ import type { BorderRadiusInput } from '../../utils/border.utils.js';
8
9
  import type { Color } from '../../utils/colors.utils.js';
9
10
  import type { HTMLFlexProps, HTMLNeoBaseElement } from '../../utils/html-element.utils.js';
10
11
  import type { BlurElevation, BlurElevationString, PositiveShadowElevation, PositiveShadowElevationString } from '../../utils/shadow.utils.js';
@@ -156,7 +157,7 @@ export type NeoDialogProps<Tag extends keyof HTMLElementTagNameMap = keyof HTMLE
156
157
  /**
157
158
  * If true, the dialog will have a rounded border.
158
159
  */
159
- rounded?: boolean;
160
+ rounded?: BorderRadiusInput;
160
161
  /**
161
162
  * Tints the dialog with the current color.
162
163
  */
@@ -24,6 +24,7 @@ export const defaultMovable = {
24
24
  snap: defaultSnap,
25
25
  handle: defaultHandle,
26
26
  };
27
+ const translateRegex = /translate[^;]+/g;
27
28
  export function useMovable(options) {
28
29
  const offset = $derived(options.offset);
29
30
  const element = $derived(options.element);
@@ -61,7 +62,7 @@ export function useMovable(options) {
61
62
  transition = element.style.transition;
62
63
  const computed = getComputedStyle(element).transition;
63
64
  if (computed.includes('translate'))
64
- element.style.transition = computed.replace(/translate[^;]+/g, `translate ${duration}ms ${easing}`);
65
+ element.style.transition = computed.replace(translateRegex, `translate ${duration}ms ${easing}`);
65
66
  else
66
67
  element.style.transition = `${computed}, translate ${duration}ms ${easing}`;
67
68
  return { easing, duration };
@@ -1,6 +1,6 @@
1
1
  <script lang="ts">
2
- import type { NeoDialogProps } from '../dialog/neo-dialog.model.js';
3
2
  import type { NeoMovable, NeoMovableLimits, NeoMovableSnap } from '../dialog/use-movable.svelte.js';
3
+ import type { NeoDrawerProps } from './neo-drawer.model.js';
4
4
 
5
5
  import { getUUID } from '@dvcol/common-utils/common/string';
6
6
 
@@ -11,7 +11,6 @@
11
11
  id = `neo-drawer-${getUUID()}`,
12
12
  ref = $bindable(),
13
13
  open = $bindable(false),
14
- modal = $bindable(true),
15
14
  moved = $bindable({ x: 0, y: 0 }),
16
15
  returnValue = $bindable(),
17
16
 
@@ -21,13 +20,13 @@
21
20
  movable: _movable,
22
21
 
23
22
  // Sizing
24
- full = modal,
23
+ full = true,
25
24
 
26
25
  // Style
27
26
  elevation = 1,
28
27
 
29
28
  ...rest
30
- }: NeoDialogProps = $props();
29
+ }: NeoDrawerProps = $props();
31
30
 
32
31
  const getLimits = (limits: NeoMovableLimits = {}): NeoMovableLimits => {
33
32
  if (!placement) return limits;
@@ -73,25 +72,26 @@
73
72
  </script>
74
73
 
75
74
  <div class:neo-drawer={true}>
76
- <NeoDialog bind:ref bind:open bind:modal bind:moved bind:returnValue bind:placement bind:outside {id} {movable} {full} {elevation} {...rest} />
75
+ <NeoDialog modal bind:ref bind:open bind:moved bind:returnValue bind:placement bind:outside {id} {movable} {full} {elevation} {...rest} />
77
76
  </div>
78
77
 
79
78
  <style>.neo-drawer {
80
79
  display: contents;
80
+ --neo-dialog-margin: none;
81
81
  }
82
- .neo-drawer :global(> .neo-dialog[data-placement^="top"]) {
82
+ .neo-drawer :global(> .neo-dialog[data-placement^='top']) {
83
83
  border-top-left-radius: 0;
84
84
  border-top-right-radius: 0;
85
85
  }
86
- .neo-drawer :global(> .neo-dialog[data-placement^="bottom"]) {
86
+ .neo-drawer :global(> .neo-dialog[data-placement^='bottom']) {
87
87
  border-bottom-right-radius: 0;
88
88
  border-bottom-left-radius: 0;
89
89
  }
90
- .neo-drawer :global(> .neo-dialog[data-placement^="left"]) {
90
+ .neo-drawer :global(> .neo-dialog[data-placement^='left']) {
91
91
  border-top-left-radius: 0;
92
92
  border-bottom-left-radius: 0;
93
93
  }
94
- .neo-drawer :global(> .neo-dialog[data-placement^="right"]) {
94
+ .neo-drawer :global(> .neo-dialog[data-placement^='right']) {
95
95
  border-top-right-radius: 0;
96
96
  border-bottom-right-radius: 0;
97
97
  }
@@ -1,4 +1,4 @@
1
- import type { NeoDialogProps } from '../dialog/neo-dialog.model.js';
2
- declare const NeoDrawer: import("svelte").Component<NeoDialogProps, {}, "ref" | "placement" | "open" | "outside" | "modal" | "moved" | "returnValue">;
1
+ import type { NeoDrawerProps } from './neo-drawer.model.js';
2
+ declare const NeoDrawer: import("svelte").Component<NeoDrawerProps, {}, "ref" | "placement" | "open" | "returnValue" | "outside" | "moved">;
3
3
  type NeoDrawer = ReturnType<typeof NeoDrawer>;
4
4
  export default NeoDrawer;
@@ -1,8 +1,8 @@
1
1
  <script lang="ts">
2
2
  import type { MouseEventHandler } from 'svelte/elements';
3
3
 
4
- import type { NeoDialogConfirmProps } from '../dialog/neo-dialog-confirm.model.js';
5
4
  import type { NeoDialogContext } from '../dialog/neo-dialog.model.js';
5
+ import type { NeoDrawerConfirmProps } from './neo-drawer.model.js';
6
6
 
7
7
  import { NeoDialogPlacements } from '../common/neo-placement.model.js';
8
8
  import NeoConfirm from '../common/NeoConfirm.svelte';
@@ -17,7 +17,6 @@
17
17
  // Dialog Props
18
18
  ref = $bindable(),
19
19
  open = $bindable(false),
20
- modal = $bindable(true),
21
20
  moved = $bindable({ x: 0, y: 0 }),
22
21
  returnValue = $bindable(),
23
22
  closedby,
@@ -74,7 +73,7 @@
74
73
  dialogProps,
75
74
  backdropProps,
76
75
  ...rest
77
- }: NeoDialogConfirmProps = $props();
76
+ }: NeoDrawerConfirmProps = $props();
78
77
 
79
78
  const close = () => {
80
79
  if (!ref) return Logger.error('NeoDialogConfirm: ref is not defined');
@@ -111,7 +110,6 @@
111
110
  <NeoDrawer
112
111
  bind:ref
113
112
  bind:open
114
- bind:modal
115
113
  bind:moved
116
114
  bind:outside
117
115
  bind:placement
@@ -1,4 +1,4 @@
1
- import type { NeoDialogConfirmProps } from '../dialog/neo-dialog-confirm.model.js';
2
- declare const NeoDrawerConfirm: import("svelte").Component<NeoDialogConfirmProps, {}, "ref" | "disabled" | "loading" | "placement" | "open" | "outside" | "modal" | "moved" | "returnValue">;
1
+ import type { NeoDrawerConfirmProps } from './neo-drawer.model.js';
2
+ declare const NeoDrawerConfirm: import("svelte").Component<NeoDrawerConfirmProps, {}, "loading" | "ref" | "disabled" | "placement" | "open" | "returnValue" | "outside" | "moved">;
3
3
  type NeoDrawerConfirm = ReturnType<typeof NeoDrawerConfirm>;
4
4
  export default NeoDrawerConfirm;
@@ -2,8 +2,8 @@
2
2
  import type { MouseEventHandler } from 'svelte/elements';
3
3
 
4
4
  import type { NeoFloatingStepperProps } from '../common/neo-floating-stepper.model.js';
5
- import type { NeoDialogStepperProps } from '../dialog/neo-dialog-stepper.model.js';
6
5
  import type { NeoDialogContext } from '../dialog/neo-dialog.model.js';
6
+ import type { NeoDrawerStepperProps } from './neo-drawer.model.js';
7
7
  import type { NeoStepperBeforeEvent, NeoStepperContext } from '../../stepper/neo-stepper.model.js';
8
8
 
9
9
  import { NeoDialogPlacements } from '../common/neo-placement.model.js';
@@ -18,7 +18,6 @@
18
18
  // Dialog Props
19
19
  dialogRef = $bindable(),
20
20
  open = $bindable(false),
21
- modal = $bindable(true),
22
21
  moved = $bindable({ x: 0, y: 0 }),
23
22
  returnValue = $bindable(),
24
23
  closedby,
@@ -81,7 +80,7 @@
81
80
  dialogProps,
82
81
  backdropProps,
83
82
  ...rest
84
- }: NeoDialogStepperProps = $props();
83
+ }: NeoDrawerStepperProps = $props();
85
84
 
86
85
  const marks = $derived<boolean>(_marks ?? steps?.some(s => s?.markProps) ?? !!rest?.markProps);
87
86
 
@@ -149,7 +148,6 @@
149
148
  <NeoDrawer
150
149
  bind:ref={dialogRef}
151
150
  bind:open
152
- bind:modal
153
151
  bind:moved
154
152
  bind:outside
155
153
  bind:placement
@@ -1,4 +1,4 @@
1
- import type { NeoDialogStepperProps } from '../dialog/neo-dialog-stepper.model.js';
2
- declare const NeoDrawerStepper: import("svelte").Component<NeoDialogStepperProps, {}, "ref" | "active" | "loading" | "placement" | "open" | "outside" | "modal" | "moved" | "returnValue" | "dialogRef">;
1
+ import type { NeoDrawerStepperProps } from './neo-drawer.model.js';
2
+ declare const NeoDrawerStepper: import("svelte").Component<NeoDrawerStepperProps, {}, "loading" | "ref" | "active" | "placement" | "open" | "returnValue" | "outside" | "moved" | "dialogRef">;
3
3
  type NeoDrawerStepper = ReturnType<typeof NeoDrawerStepper>;
4
4
  export default NeoDrawerStepper;
@@ -0,0 +1,6 @@
1
+ import type { NeoDialogProps } from '../dialog/neo-dialog.model.js';
2
+ import type { NeoDialogConfirmProps } from '../dialog/neo-dialog-confirm.model.js';
3
+ import type { NeoDialogStepperProps } from '../dialog/neo-dialog-stepper.model.js';
4
+ export type NeoDrawerProps<Tag extends keyof HTMLElementTagNameMap = keyof HTMLElementTagNameMap> = Omit<NeoDialogProps<Tag>, 'modal'>;
5
+ export type NeoDrawerConfirmProps<Tag extends keyof HTMLElementTagNameMap = keyof HTMLElementTagNameMap> = Omit<NeoDialogConfirmProps<Tag>, 'modal'>;
6
+ export type NeoDrawerStepperProps<Tag extends keyof HTMLElementTagNameMap = keyof HTMLElementTagNameMap> = Omit<NeoDialogStepperProps<Tag>, 'modal'>;
@@ -0,0 +1 @@
1
+ export {};
@@ -1,5 +1,6 @@
1
1
  export * from './dialog/index.js';
2
2
  export * from './drawer/index.js';
3
3
  export * from './menu/index.js';
4
+ export * from './notification/index.js';
4
5
  export * from './portal/index.js';
5
6
  export * from './tooltips/index.js';
@@ -1,5 +1,6 @@
1
1
  export * from './dialog/index.js';
2
2
  export * from './drawer/index.js';
3
3
  export * from './menu/index.js';
4
+ export * from './notification/index.js';
4
5
  export * from './portal/index.js';
5
6
  export * from './tooltips/index.js';
@@ -1,7 +1,10 @@
1
1
  <script lang="ts">
2
+ import type { NeoTooltipContext } from '../../index.js';
3
+
2
4
  import type { NeoMenuProps } from './neo-menu.model.js';
3
5
 
4
6
  import { getFocusableElement } from '@dvcol/common-utils/common/element';
7
+ import { tick } from 'svelte';
5
8
 
6
9
  import { setMenuContext } from './neo-menu-context.svelte.js';
7
10
  import NeoMenuList from './NeoMenuList.svelte';
@@ -16,6 +19,7 @@
16
19
  // Tooltip Props
17
20
  ref = $bindable(),
18
21
  open = $bindable(false),
22
+ position = $bindable(),
19
23
  triggerRef = $bindable(),
20
24
 
21
25
  target,
@@ -23,13 +27,16 @@
23
27
  padding = '0',
24
28
  openOnHover = true,
25
29
  openOnFocus = false,
26
- openOnClick = false,
30
+ openOnClick = true,
31
+ unmountOnClose = false,
27
32
  role = 'menu',
28
33
 
29
34
  // Styles
30
35
  shadow = true,
31
36
  scrollbar,
32
37
  rounded,
38
+ reverse,
39
+ flip,
33
40
 
34
41
  // Events
35
42
  onMenu,
@@ -60,38 +67,67 @@
60
67
  open = tooltipOpen || context.children;
61
68
  });
62
69
 
63
- const host = $derived.by(() => {
64
- if (triggerRef) return triggerRef;
65
- if (!target) return;
66
- if (typeof target === 'function') return target();
67
- return target;
68
- });
70
+ const toggleListener = async (e: KeyboardEvent) => {
71
+ // if tab && open, focus next element
72
+ if (e.key === 'Tab' && open) {
73
+ if (e.shiftKey !== position?.includes('top')) return;
74
+ e.preventDefault();
75
+ e.stopPropagation();
76
+ return getFocusableElement(ref)?.focus();
77
+ }
78
+
79
+ if (!['ArrowUp', 'ArrowDown', 'ArrowRight', 'ArrowLeft'].includes(e.key)) return;
80
+ e.preventDefault();
81
+ e.stopPropagation();
82
+
83
+ const was = open;
84
+ if (position?.includes('bottom')) triggerRef?.toggle?.(e.key === 'ArrowDown');
85
+ if (position?.includes('top')) triggerRef?.toggle?.(e.key === 'ArrowUp');
86
+ if (position?.includes('right')) triggerRef?.toggle?.(e.key === 'ArrowRight');
87
+ if (position?.includes('left')) triggerRef?.toggle?.(e.key === 'ArrowLeft');
88
+ await tick();
89
+ if (was && open && ref) getFocusableElement(ref)?.focus();
90
+ };
69
91
 
70
- const onkeydown = (e: KeyboardEvent) => {
71
- if (!['ArrowUp', 'ArrowDown'].includes(e.key)) return;
92
+ const closeListener = async (e: KeyboardEvent) => {
93
+ if (!triggerRef) return;
94
+ if (position?.includes('bottom') && e.key !== 'ArrowUp') return;
95
+ if (position?.includes('top') && e.key !== 'ArrowDown') return;
96
+ if (position?.includes('right') && e.key !== 'ArrowLeft') return;
97
+ if (position?.includes('left') && e.key !== 'ArrowRight') return;
98
+ const selector = baseProps?.selector || '.neo-menu-item';
99
+ if (!(e.target instanceof HTMLElement)) return;
100
+ if (e.target?.closest(selector)?.previousElementSibling) return;
101
+ if (!e.target?.closest(selector)?.parentElement?.classList.contains('neo-menu-list')) return;
72
102
  e.preventDefault();
73
103
  e.stopPropagation();
74
- open = e.key === 'ArrowDown';
75
- if (open && ref) getFocusableElement(ref)?.focus();
104
+ triggerRef?.toggle?.(false);
105
+ getFocusableElement(triggerRef)?.focus();
76
106
  };
77
107
 
78
108
  $effect(() => {
79
- host?.addEventListener('keydown', onkeydown);
80
- return () => host?.removeEventListener('keydown', onkeydown);
109
+ triggerRef?.addEventListener('keydown', toggleListener);
110
+ ref?.addEventListener('keydown', closeListener);
111
+ return () => {
112
+ triggerRef?.removeEventListener('keydown', toggleListener);
113
+ ref?.removeEventListener('keydown', closeListener);
114
+ };
81
115
  });
82
116
  </script>
83
117
 
84
- {#snippet tooltip()}
118
+ {#snippet tooltip({ placement }: NeoTooltipContext)}
85
119
  <NeoMenuList
86
120
  {items}
87
121
  {shadow}
88
122
  {scrollbar}
89
- {rounded}
123
+ {reverse}
124
+ flip={flip ?? placement.includes('top')}
90
125
  {baseProps}
91
126
  {itemProps}
92
127
  {dividerProps}
93
128
  {keepOpenOnSelect}
94
- tooltipProps={{ role, portal, padding, openOnHover, openOnFocus, openOnClick, ...rest }}
129
+ rounded={rounded === true ? 'xl' : rounded}
130
+ tooltipProps={{ role, portal, padding, openOnHover, openOnFocus, openOnClick, unmountOnClose, ...rest }}
95
131
  {...menuProps}
96
132
  {onMenu}
97
133
  {onSelect}
@@ -101,6 +137,7 @@
101
137
  <NeoTooltip
102
138
  bind:ref
103
139
  bind:triggerRef
140
+ bind:position
104
141
  bind:open={() => open,
105
142
  (_open) => {
106
143
  tooltipOpen = _open;
@@ -112,7 +149,8 @@
112
149
  {openOnHover}
113
150
  {openOnFocus}
114
151
  {openOnClick}
115
- {rounded}
152
+ {unmountOnClose}
153
+ rounded={rounded === true ? 'xl' : rounded}
116
154
  {...rest}
117
155
  {tooltip}
118
156
  />
@@ -1,4 +1,4 @@
1
1
  import type { NeoMenuProps } from './neo-menu.model.js';
2
- declare const NeoMenu: import("svelte").Component<NeoMenuProps, {}, "ref" | "open" | "triggerRef">;
2
+ declare const NeoMenu: import("svelte").Component<NeoMenuProps, {}, "ref" | "open" | "position" | "triggerRef">;
3
3
  type NeoMenu = ReturnType<typeof NeoMenu>;
4
4
  export default NeoMenu;
@@ -2,11 +2,10 @@
2
2
  import type { NeoMenuItem } from './neo-menu-list-item.model.js';
3
3
  import type { NeoMenuListProps } from './neo-menu-list.model.js';
4
4
 
5
- import { getUUID } from '@dvcol/common-utils/common/string';
5
+ import { isSafari } from '@dvcol/common-utils/common/browser';
6
+ import { tick } from 'svelte';
6
7
 
7
- import NeoDivider from '../../divider/NeoDivider.svelte';
8
8
  import NeoMenuListItem from './NeoMenuListItem.svelte';
9
- import { showDivider } from '../../list/neo-list.model.js';
10
9
 
11
10
  let {
12
11
  ref = $bindable(),
@@ -23,6 +22,9 @@
23
22
  shadow,
24
23
  scrollbar,
25
24
  rounded,
25
+ reverse,
26
+ divider,
27
+ flip,
26
28
 
27
29
  // Events
28
30
  onMenu,
@@ -36,54 +38,46 @@
36
38
  ...rest
37
39
  }: NeoMenuListProps = $props();
38
40
 
39
- // TODO: Section
40
- </script>
41
+ const scrollReverse = async () => {
42
+ await tick();
43
+ if (!ref) return;
44
+ ref.scrollTo({ top: ref.scrollHeight, behavior: 'instant' });
45
+ };
41
46
 
42
- {#snippet line(item: NeoMenuItem, index = 0, length = 0)}
43
- <NeoMenuListItem
44
- {keepOpenOnSelect}
45
- {rounded}
46
- {...itemProps}
47
- {parent}
48
- {item}
49
- {index}
50
- {length}
51
- {level}
52
- {tooltipProps}
53
- {baseProps}
54
- menuProps={{ tag, shadow, scrollbar, rounded, dividerProps, tooltipProps, baseProps, ...rest, ...item.menuProps }}
55
- onMenu={(i, e) => {
56
- item.menuProps?.onMenu?.(i, e);
57
- onMenu?.(i, e);
58
- }}
59
- onSelect={(i, e) => {
60
- item.menuProps?.onSelect?.(i, e);
61
- onSelect?.(i, e);
62
- }}
63
- />
64
- {/snippet}
47
+ $effect(() => {
48
+ if (!flip || !ref) return;
49
+ scrollReverse();
50
+ });
51
+ </script>
65
52
 
66
- {#snippet list(array: NeoMenuItem[])}
53
+ {#snippet list(array: NeoMenuItem[], sectionIndex = undefined)}
67
54
  {#each array as item, index (item.id ?? index)}
68
- {@const labelId = item.label ? `neo-menu-section-label-${getUUID()}` : undefined}
69
- {#if index && showDivider(item.divider, 'top')}
70
- <NeoDivider aria-hidden="true" {...dividerProps} {...item.dividerProps} class={['neo-menu-item-divider', item.dividerProps?.class]} />
71
- {/if}
72
- {#if item.section}
73
- <span id={labelId} class="neo-menu-list-section-label" class:neo-sticky={item.sticky}>
74
- {item.label}
75
- </span>
76
- <svelte:element this={tag} role="menu">
77
- {#if item.items}
78
- {@render list(item.items)}
79
- {/if}
80
- </svelte:element>
81
- {:else}
82
- {@render line(item, index, array.length)}
83
- {/if}
84
- {#if index < array.length - 1 && showDivider(item.divider, 'bottom') && !showDivider(array[index + 1]?.divider, 'bottom')}
85
- <NeoDivider aria-hidden="true" {...dividerProps} {...item.dividerProps} class={['neo-menu-item-divider', item.dividerProps?.class]} />
86
- {/if}
55
+ <NeoMenuListItem
56
+ {keepOpenOnSelect}
57
+ {rounded}
58
+ {reverse}
59
+ menuTag={tag}
60
+ {...itemProps}
61
+ {item}
62
+ {parent}
63
+ {array}
64
+ {index}
65
+ {sectionIndex}
66
+ {level}
67
+ {divider}
68
+ flip={flip && !isSafari()}
69
+ {tooltipProps}
70
+ {baseProps}
71
+ menuProps={{ tag, shadow, scrollbar, rounded, reverse, flip, divider, dividerProps, tooltipProps, baseProps, ...rest, ...item.menuProps }}
72
+ onMenu={(i, e) => {
73
+ item.menuProps?.onMenu?.(i, e);
74
+ onMenu?.(i, e);
75
+ }}
76
+ onSelect={(i, e) => {
77
+ item.menuProps?.onSelect?.(i, e);
78
+ onSelect?.(i, e);
79
+ }}
80
+ />
87
81
  {/each}
88
82
  {/snippet}
89
83
 
@@ -95,6 +89,7 @@
95
89
  class:neo-scroll={scrollbar}
96
90
  class:neo-shadow={shadow}
97
91
  class:neo-rounded={rounded}
92
+ class:neo-flip={flip}
98
93
  {...rest}
99
94
  >
100
95
  {@render list(items)}
@@ -103,41 +98,33 @@
103
98
  <style>.neo-menu-list {
104
99
  display: flex;
105
100
  flex-direction: column;
106
- padding: var(--neo-menu-padding, var(--neo-gap-tiny, 0.25rem)) 0;
101
+ padding: var(--neo-menu-padding, var(--neo-gap-4xs, 0.25rem)) 0;
107
102
  overflow: auto;
108
103
  }
109
- .neo-menu-list :global(.neo-menu-item-divider) {
110
- margin: var(--neo-menu-padding, var(--neo-gap-tiny, 0.25rem)) 0;
104
+ .neo-menu-list :global(.neo-menu-item-divider[data-elevation='0']) {
105
+ margin: var(--neo-menu-margin, var(--neo-gap-3xs, 0.3125rem)) 0;
111
106
  }
112
- .neo-menu-list-section-label {
113
- display: inline-flex;
114
- padding: 0.25rem 0.6125rem;
115
- transition: color 0.3s ease;
116
- margin-block-end: 0.125rem;
117
- }
118
- .neo-menu-list-section-label.neo-sticky {
119
- position: sticky;
120
- top: -0.5rem;
121
- z-index: var(--neo-z-index-in-front, 1);
122
- background: var(--neo-list-section-bg-color, linear-gradient(to top, transparent 5%, oklch(from var(--neo-background-color) l c h/50%) 20%, var(--neo-background-color)));
107
+ .neo-menu-list :global(.neo-menu-item-divider:not([data-elevation='0'])) {
108
+ --neo-divider-margin: var(--neo-menu-margin, var(--neo-gap-3xs, 0.3125rem));
123
109
  }
124
110
  .neo-menu-list.neo-scroll, .neo-menu-list.neo-rounded {
125
- padding-block: var(--neo-menu-scroll-padding, 0.625rem);
111
+ padding-block: var(--neo-menu-scroll-padding, 0.5rem);
112
+ gap: var(--neo-menu-scroll-gap, 0.125rem);
126
113
  }
127
114
  .neo-menu-list.neo-scroll:not(.neo-scroll) :global(> .neo-menu-item), .neo-menu-list.neo-rounded:not(.neo-scroll) :global(> .neo-menu-item) {
128
115
  padding: 0 var(--neo-menu-padding, var(--neo-gap-xxs, 0.5rem));
129
116
  }
130
- .neo-menu-list.neo-scroll .neo-menu-list-section-label, .neo-menu-list.neo-rounded .neo-menu-list-section-label {
117
+ .neo-menu-list.neo-scroll :global(.neo-menu-item-section-label), .neo-menu-list.neo-rounded :global(.neo-menu-item-section-label) {
131
118
  top: -0.75rem;
132
119
  }
120
+ .neo-menu-list.neo-scroll.neo-shadow {
121
+ 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);
122
+ }
133
123
  .neo-menu-list.neo-scroll {
134
124
  scrollbar-gutter: stable both-edges;
135
125
  overflow: var(--neo-scrollbar-overflow, auto);
136
126
  transition: --neo-thumb-color 0.45s ease 0.1s;
137
127
  }
138
- .neo-menu-list.neo-scroll.neo-shadow {
139
- 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);
140
- }
141
128
  .neo-menu-list.neo-scroll:focus-within, .neo-menu-list.neo-scroll:focus, .neo-menu-list.neo-scroll:hover {
142
129
  --neo-thumb-color: var(--neo-scrollbar-color);
143
130
  transition: --neo-thumb-color 0.45s ease 0s;
@@ -193,4 +180,10 @@
193
180
  .neo-menu-list.neo-scroll {
194
181
  padding-inline: calc(var(--neo-scrollbar-width, 0.375rem) * 2);
195
182
  }
183
+ }
184
+ @supports not ((hanging-punctuation: first) and (font: -apple-system-body) and (-webkit-appearance: none)) {
185
+ .neo-menu-list.neo-flip {
186
+ flex-direction: column-reverse;
187
+ justify-content: end;
188
+ }
196
189
  }</style>