svelte-ag 0.0.2-dev.73 → 0.0.2-dev.81

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 (445) hide show
  1. package/README.md +12 -0
  2. package/dist/app.css +0 -4
  3. package/dist/lib/api/form.svelte.d.ts +11 -0
  4. package/dist/lib/api/form.svelte.d.ts.map +1 -0
  5. package/dist/lib/api/form.svelte.js +43 -0
  6. package/dist/lib/api/index.d.ts +3 -0
  7. package/dist/lib/api/index.d.ts.map +1 -0
  8. package/dist/lib/api/index.js +2 -0
  9. package/dist/lib/api/query.svelte.d.ts +21 -0
  10. package/dist/lib/api/query.svelte.d.ts.map +1 -0
  11. package/dist/lib/api/query.svelte.js +47 -0
  12. package/dist/lib/bits/internal/arrays.d.ts +1 -0
  13. package/dist/lib/bits/internal/arrays.d.ts.map +1 -0
  14. package/dist/lib/bits/internal/arrays.test.d.ts +1 -0
  15. package/dist/lib/bits/internal/arrays.test.d.ts.map +1 -0
  16. package/dist/lib/bits/internal/attrs.d.ts +1 -0
  17. package/dist/lib/bits/internal/attrs.d.ts.map +1 -0
  18. package/dist/lib/bits/internal/box-auto-reset.svelte.d.ts +1 -0
  19. package/dist/lib/bits/internal/box-auto-reset.svelte.d.ts.map +1 -0
  20. package/dist/lib/bits/internal/box.svelte.d.ts +1 -0
  21. package/dist/lib/bits/internal/box.svelte.d.ts.map +1 -0
  22. package/dist/lib/bits/internal/clamp.d.ts +1 -0
  23. package/dist/lib/bits/internal/clamp.d.ts.map +1 -0
  24. package/dist/lib/bits/internal/clamp.test.d.ts +1 -0
  25. package/dist/lib/bits/internal/clamp.test.d.ts.map +1 -0
  26. package/dist/lib/bits/internal/create-event-hook.svelte.d.ts +1 -0
  27. package/dist/lib/bits/internal/create-event-hook.svelte.d.ts.map +1 -0
  28. package/dist/lib/bits/internal/create-shared-hook.svelte.d.ts +1 -0
  29. package/dist/lib/bits/internal/create-shared-hook.svelte.d.ts.map +1 -0
  30. package/dist/lib/bits/internal/date-time/announcer.d.ts +2 -1
  31. package/dist/lib/bits/internal/date-time/announcer.d.ts.map +1 -0
  32. package/dist/lib/bits/internal/date-time/calendar-helpers.svelte.d.ts +1 -0
  33. package/dist/lib/bits/internal/date-time/calendar-helpers.svelte.d.ts.map +1 -0
  34. package/dist/lib/bits/internal/date-time/field/helpers.d.ts +1 -0
  35. package/dist/lib/bits/internal/date-time/field/helpers.d.ts.map +1 -0
  36. package/dist/lib/bits/internal/date-time/field/parts.d.ts +1 -0
  37. package/dist/lib/bits/internal/date-time/field/parts.d.ts.map +1 -0
  38. package/dist/lib/bits/internal/date-time/field/segments.d.ts +1 -0
  39. package/dist/lib/bits/internal/date-time/field/segments.d.ts.map +1 -0
  40. package/dist/lib/bits/internal/date-time/field/types.d.ts +1 -0
  41. package/dist/lib/bits/internal/date-time/field/types.d.ts.map +1 -0
  42. package/dist/lib/bits/internal/date-time/formatter.d.ts +1 -0
  43. package/dist/lib/bits/internal/date-time/formatter.d.ts.map +1 -0
  44. package/dist/lib/bits/internal/date-time/placeholders.d.ts +1 -0
  45. package/dist/lib/bits/internal/date-time/placeholders.d.ts.map +1 -0
  46. package/dist/lib/bits/internal/date-time/utils.d.ts +1 -0
  47. package/dist/lib/bits/internal/date-time/utils.d.ts.map +1 -0
  48. package/dist/lib/bits/internal/debounce.d.ts +1 -0
  49. package/dist/lib/bits/internal/debounce.d.ts.map +1 -0
  50. package/dist/lib/bits/internal/debounce.test.d.ts +1 -0
  51. package/dist/lib/bits/internal/debounce.test.d.ts.map +1 -0
  52. package/dist/lib/bits/internal/dom.d.ts +1 -0
  53. package/dist/lib/bits/internal/dom.d.ts.map +1 -0
  54. package/dist/lib/bits/internal/elements.d.ts +1 -0
  55. package/dist/lib/bits/internal/elements.d.ts.map +1 -0
  56. package/dist/lib/bits/internal/events.d.ts +1 -0
  57. package/dist/lib/bits/internal/events.d.ts.map +1 -0
  58. package/dist/lib/bits/internal/floating-svelte/floating-utils.svelte.d.ts +1 -0
  59. package/dist/lib/bits/internal/floating-svelte/floating-utils.svelte.d.ts.map +1 -0
  60. package/dist/lib/bits/internal/floating-svelte/types.d.ts +1 -0
  61. package/dist/lib/bits/internal/floating-svelte/types.d.ts.map +1 -0
  62. package/dist/lib/bits/internal/floating-svelte/use-floating.svelte.d.ts +1 -0
  63. package/dist/lib/bits/internal/floating-svelte/use-floating.svelte.d.ts.map +1 -0
  64. package/dist/lib/bits/internal/focus.d.ts +1 -0
  65. package/dist/lib/bits/internal/focus.d.ts.map +1 -0
  66. package/dist/lib/bits/internal/get-directional-keys.d.ts +1 -0
  67. package/dist/lib/bits/internal/get-directional-keys.d.ts.map +1 -0
  68. package/dist/lib/bits/internal/get-directional-keys.test.d.ts +1 -0
  69. package/dist/lib/bits/internal/get-directional-keys.test.d.ts.map +1 -0
  70. package/dist/lib/bits/internal/is.d.ts +1 -0
  71. package/dist/lib/bits/internal/is.d.ts.map +1 -0
  72. package/dist/lib/bits/internal/is.test.d.ts +1 -0
  73. package/dist/lib/bits/internal/is.test.d.ts.map +1 -0
  74. package/dist/lib/bits/internal/kbd-constants.d.ts +1 -0
  75. package/dist/lib/bits/internal/kbd-constants.d.ts.map +1 -0
  76. package/dist/lib/bits/internal/kbd.d.ts +1 -0
  77. package/dist/lib/bits/internal/kbd.d.ts.map +1 -0
  78. package/dist/lib/bits/internal/locale.d.ts +1 -0
  79. package/dist/lib/bits/internal/locale.d.ts.map +1 -0
  80. package/dist/lib/bits/internal/math.d.ts +1 -0
  81. package/dist/lib/bits/internal/math.d.ts.map +1 -0
  82. package/dist/lib/bits/internal/math.test.d.ts +1 -0
  83. package/dist/lib/bits/internal/math.test.d.ts.map +1 -0
  84. package/dist/lib/bits/internal/noop.d.ts +1 -0
  85. package/dist/lib/bits/internal/noop.d.ts.map +1 -0
  86. package/dist/lib/bits/internal/should-trap-focus.d.ts +1 -0
  87. package/dist/lib/bits/internal/should-trap-focus.d.ts.map +1 -0
  88. package/dist/lib/bits/internal/sleep.d.ts +1 -0
  89. package/dist/lib/bits/internal/sleep.d.ts.map +1 -0
  90. package/dist/lib/bits/internal/tabbable.d.ts +1 -0
  91. package/dist/lib/bits/internal/tabbable.d.ts.map +1 -0
  92. package/dist/lib/bits/internal/types.d.ts +1 -0
  93. package/dist/lib/bits/internal/types.d.ts.map +1 -0
  94. package/dist/lib/bits/internal/use-after-animations.svelte.d.ts +1 -0
  95. package/dist/lib/bits/internal/use-after-animations.svelte.d.ts.map +1 -0
  96. package/dist/lib/bits/internal/use-arrow-navigation.d.ts +1 -0
  97. package/dist/lib/bits/internal/use-arrow-navigation.d.ts.map +1 -0
  98. package/dist/lib/bits/internal/use-body-scroll-lock.svelte.d.ts +1 -0
  99. package/dist/lib/bits/internal/use-body-scroll-lock.svelte.d.ts.map +1 -0
  100. package/dist/lib/bits/internal/use-data-typeahead.svelte.d.ts +1 -0
  101. package/dist/lib/bits/internal/use-data-typeahead.svelte.d.ts.map +1 -0
  102. package/dist/lib/bits/internal/use-dom-typeahead.svelte.d.ts +1 -0
  103. package/dist/lib/bits/internal/use-dom-typeahead.svelte.d.ts.map +1 -0
  104. package/dist/lib/bits/internal/use-form-control.svelte.d.ts +1 -0
  105. package/dist/lib/bits/internal/use-form-control.svelte.d.ts.map +1 -0
  106. package/dist/lib/bits/internal/use-grace-area.svelte.d.ts +1 -0
  107. package/dist/lib/bits/internal/use-grace-area.svelte.d.ts.map +1 -0
  108. package/dist/lib/bits/internal/use-id.d.ts +1 -0
  109. package/dist/lib/bits/internal/use-id.d.ts.map +1 -0
  110. package/dist/lib/bits/internal/use-resize-observer.svelte.d.ts +1 -0
  111. package/dist/lib/bits/internal/use-resize-observer.svelte.d.ts.map +1 -0
  112. package/dist/lib/bits/internal/use-roving-focus.svelte.d.ts +1 -0
  113. package/dist/lib/bits/internal/use-roving-focus.svelte.d.ts.map +1 -0
  114. package/dist/lib/bits/internal/use-size.svelte.d.ts +1 -0
  115. package/dist/lib/bits/internal/use-size.svelte.d.ts.map +1 -0
  116. package/dist/lib/bits/internal/use-state-machine.svelte.d.ts +1 -0
  117. package/dist/lib/bits/internal/use-state-machine.svelte.d.ts.map +1 -0
  118. package/dist/lib/bits/internal/use-timeout-fn.svelte.d.ts +1 -0
  119. package/dist/lib/bits/internal/use-timeout-fn.svelte.d.ts.map +1 -0
  120. package/dist/lib/components/animated/animated.svelte +5 -3
  121. package/dist/lib/components/animated/animated.svelte.d.ts +5 -1
  122. package/dist/lib/components/animated/animated.svelte.d.ts.map +1 -0
  123. package/dist/lib/components/animated/index.d.ts +1 -0
  124. package/dist/lib/components/animated/index.d.ts.map +1 -0
  125. package/dist/lib/components/carousel/carousel-content.svelte +44 -0
  126. package/dist/lib/components/carousel/carousel-content.svelte.d.ts +4 -0
  127. package/dist/lib/components/carousel/carousel-content.svelte.d.ts.map +1 -0
  128. package/dist/lib/components/carousel/carousel-dots.svelte +28 -0
  129. package/dist/lib/components/carousel/carousel-dots.svelte.d.ts +4 -0
  130. package/dist/lib/components/carousel/carousel-dots.svelte.d.ts.map +1 -0
  131. package/dist/lib/components/carousel/carousel-item.svelte +27 -0
  132. package/dist/lib/components/carousel/carousel-item.svelte.d.ts +4 -0
  133. package/dist/lib/components/carousel/carousel-item.svelte.d.ts.map +1 -0
  134. package/dist/lib/components/carousel/carousel-next.svelte +38 -0
  135. package/dist/lib/components/carousel/carousel-next.svelte.d.ts +4 -0
  136. package/dist/lib/components/carousel/carousel-next.svelte.d.ts.map +1 -0
  137. package/dist/lib/components/carousel/carousel-previous.svelte +38 -0
  138. package/dist/lib/components/carousel/carousel-previous.svelte.d.ts +4 -0
  139. package/dist/lib/components/carousel/carousel-previous.svelte.d.ts.map +1 -0
  140. package/dist/lib/components/carousel/carousel.svelte +103 -0
  141. package/dist/lib/components/carousel/carousel.svelte.d.ts +4 -0
  142. package/dist/lib/components/carousel/carousel.svelte.d.ts.map +1 -0
  143. package/dist/lib/components/carousel/context.d.ts +36 -0
  144. package/dist/lib/components/carousel/context.d.ts.map +1 -0
  145. package/dist/lib/components/carousel/context.js +12 -0
  146. package/dist/lib/components/carousel/index.d.ts +8 -0
  147. package/dist/lib/components/carousel/index.d.ts.map +1 -0
  148. package/dist/lib/components/carousel/index.js +9 -0
  149. package/dist/lib/components/dnd/Droppable.svelte.d.ts +2 -8
  150. package/dist/lib/components/dnd/Droppable.svelte.d.ts.map +1 -0
  151. package/dist/lib/components/dnd/context.svelte.d.ts +3 -3
  152. package/dist/lib/components/dnd/context.svelte.d.ts.map +1 -0
  153. package/dist/lib/components/dnd/context.svelte.js +6 -7
  154. package/dist/lib/components/dnd/dnd-context.svelte.d.ts +2 -1
  155. package/dist/lib/components/dnd/dnd-context.svelte.d.ts.map +1 -0
  156. package/dist/lib/components/dnd/dnd-drag-overlay.svelte.d.ts +2 -1
  157. package/dist/lib/components/dnd/dnd-drag-overlay.svelte.d.ts.map +1 -0
  158. package/dist/lib/components/dnd/dnd-drag-placeholder.svelte.d.ts +2 -1
  159. package/dist/lib/components/dnd/dnd-drag-placeholder.svelte.d.ts.map +1 -0
  160. package/dist/lib/components/dnd/dnd-draghandle.svelte +7 -1
  161. package/dist/lib/components/dnd/dnd-draghandle.svelte.d.ts +2 -1
  162. package/dist/lib/components/dnd/dnd-draghandle.svelte.d.ts.map +1 -0
  163. package/dist/lib/components/dnd/dnd-overlay.svelte.d.ts +4 -11
  164. package/dist/lib/components/dnd/dnd-overlay.svelte.d.ts.map +1 -0
  165. package/dist/lib/components/dnd/dnd-sortable-context.svelte.d.ts +2 -1
  166. package/dist/lib/components/dnd/dnd-sortable-context.svelte.d.ts.map +1 -0
  167. package/dist/lib/components/dnd/dnd-sortable-item.svelte +9 -5
  168. package/dist/lib/components/dnd/dnd-sortable-item.svelte.d.ts +4 -3
  169. package/dist/lib/components/dnd/dnd-sortable-item.svelte.d.ts.map +1 -0
  170. package/dist/lib/components/dnd/example.svelte.d.ts +2 -1
  171. package/dist/lib/components/dnd/example.svelte.d.ts.map +1 -0
  172. package/dist/lib/components/dnd/exports.d.ts +1 -0
  173. package/dist/lib/components/dnd/exports.d.ts.map +1 -0
  174. package/dist/lib/components/dnd/index.d.ts +1 -0
  175. package/dist/lib/components/dnd/index.d.ts.map +1 -0
  176. package/dist/lib/components/dnd/sortable.svelte.d.ts +1 -0
  177. package/dist/lib/components/dnd/sortable.svelte.d.ts.map +1 -0
  178. package/dist/lib/components/dnd/sortable.svelte.js +3 -1
  179. package/dist/lib/components/dnd/utils.svelte.d.ts +14 -0
  180. package/dist/lib/components/dnd/utils.svelte.d.ts.map +1 -0
  181. package/dist/lib/components/dnd/utils.svelte.js +7 -3
  182. package/dist/lib/components/form/form-button.svelte +20 -0
  183. package/dist/lib/components/form/form-button.svelte.d.ts +4 -0
  184. package/dist/lib/components/form/form-button.svelte.d.ts.map +1 -0
  185. package/dist/lib/components/form/form-description.svelte +17 -0
  186. package/dist/lib/components/form/form-description.svelte.d.ts +4 -0
  187. package/dist/lib/components/form/form-description.svelte.d.ts.map +1 -0
  188. package/dist/lib/components/form/form-element-field.svelte +24 -0
  189. package/dist/lib/components/form/form-element-field.svelte.d.ts +19 -0
  190. package/dist/lib/components/form/form-element-field.svelte.d.ts.map +1 -0
  191. package/dist/lib/components/form/form-field-errors.svelte +30 -0
  192. package/dist/lib/components/form/form-field-errors.svelte.d.ts +4 -0
  193. package/dist/lib/components/form/form-field-errors.svelte.d.ts.map +1 -0
  194. package/dist/lib/components/form/form-field.svelte +29 -0
  195. package/dist/lib/components/form/form-field.svelte.d.ts +19 -0
  196. package/dist/lib/components/form/form-field.svelte.d.ts.map +1 -0
  197. package/dist/lib/components/form/form-fieldset.svelte +15 -0
  198. package/dist/lib/components/form/form-fieldset.svelte.d.ts +20 -0
  199. package/dist/lib/components/form/form-fieldset.svelte.d.ts.map +1 -0
  200. package/dist/lib/components/form/form-label.svelte +24 -0
  201. package/dist/lib/components/form/form-label.svelte.d.ts +4 -0
  202. package/dist/lib/components/form/form-label.svelte.d.ts.map +1 -0
  203. package/dist/lib/components/form/form-legend.svelte +16 -0
  204. package/dist/lib/components/form/form-legend.svelte.d.ts +4 -0
  205. package/dist/lib/components/form/form-legend.svelte.d.ts.map +1 -0
  206. package/dist/lib/components/form/form.svelte +36 -0
  207. package/dist/lib/components/form/form.svelte.d.ts +8 -0
  208. package/dist/lib/components/form/form.svelte.d.ts.map +1 -0
  209. package/dist/lib/components/form/index.d.ts +13 -0
  210. package/dist/lib/components/form/index.d.ts.map +1 -0
  211. package/dist/lib/components/form/index.js +14 -0
  212. package/dist/lib/components/gradient/Gradient.svelte +66 -0
  213. package/dist/lib/components/gradient/Gradient.svelte.d.ts +4 -0
  214. package/dist/lib/components/gradient/Gradient.svelte.d.ts.map +1 -0
  215. package/dist/lib/components/gradient/index.d.ts +2 -0
  216. package/dist/lib/components/gradient/index.d.ts.map +1 -0
  217. package/dist/lib/components/gradient/index.js +1 -0
  218. package/dist/lib/components/safe/index.d.ts +3 -0
  219. package/dist/lib/components/safe/index.d.ts.map +1 -0
  220. package/dist/lib/components/safe/index.js +2 -0
  221. package/dist/lib/components/safe/safe.svelte +20 -0
  222. package/dist/lib/components/safe/safe.svelte.d.ts +9 -0
  223. package/dist/lib/components/safe/safe.svelte.d.ts.map +1 -0
  224. package/dist/lib/components/search/combinations/searchPopover.svelte.d.ts +2 -11
  225. package/dist/lib/components/search/combinations/searchPopover.svelte.d.ts.map +1 -0
  226. package/dist/lib/components/search/components/search-empty.svelte.d.ts +2 -2
  227. package/dist/lib/components/search/components/search-empty.svelte.d.ts.map +1 -0
  228. package/dist/lib/components/search/components/search-input.svelte.d.ts +2 -2
  229. package/dist/lib/components/search/components/search-input.svelte.d.ts.map +1 -0
  230. package/dist/lib/components/search/components/search-list.svelte +2 -2
  231. package/dist/lib/components/search/components/search-list.svelte.d.ts +2 -2
  232. package/dist/lib/components/search/components/search-list.svelte.d.ts.map +1 -0
  233. package/dist/lib/components/search/components/search-pagnation.svelte.d.ts +2 -6
  234. package/dist/lib/components/search/components/search-pagnation.svelte.d.ts.map +1 -0
  235. package/dist/lib/components/search/components/search.svelte.d.ts +2 -2
  236. package/dist/lib/components/search/components/search.svelte.d.ts.map +1 -0
  237. package/dist/lib/components/search/exports.d.ts +1 -0
  238. package/dist/lib/components/search/exports.d.ts.map +1 -0
  239. package/dist/lib/components/search/index.d.ts +1 -0
  240. package/dist/lib/components/search/index.d.ts.map +1 -0
  241. package/dist/lib/components/search/search.svelte.d.ts +1 -0
  242. package/dist/lib/components/search/search.svelte.d.ts.map +1 -0
  243. package/dist/lib/components/search/types.d.ts +1 -0
  244. package/dist/lib/components/search/types.d.ts.map +1 -0
  245. package/dist/lib/components/sidebar/README.md +10 -0
  246. package/dist/lib/components/sidebar/constants.d.ts +7 -0
  247. package/dist/lib/components/sidebar/constants.d.ts.map +1 -0
  248. package/dist/lib/components/sidebar/constants.js +6 -0
  249. package/dist/lib/components/sidebar/context.svelte.d.ts +52 -0
  250. package/dist/lib/components/sidebar/context.svelte.d.ts.map +1 -0
  251. package/dist/lib/components/sidebar/context.svelte.js +57 -0
  252. package/dist/lib/components/sidebar/index.d.ts +26 -0
  253. package/dist/lib/components/sidebar/index.d.ts.map +1 -0
  254. package/dist/lib/components/sidebar/index.js +27 -0
  255. package/dist/lib/components/sidebar/sidebar-content.svelte +24 -0
  256. package/dist/lib/components/sidebar/sidebar-content.svelte.d.ts +4 -0
  257. package/dist/lib/components/sidebar/sidebar-content.svelte.d.ts.map +1 -0
  258. package/dist/lib/components/sidebar/sidebar-footer.svelte +21 -0
  259. package/dist/lib/components/sidebar/sidebar-footer.svelte.d.ts +4 -0
  260. package/dist/lib/components/sidebar/sidebar-footer.svelte.d.ts.map +1 -0
  261. package/dist/lib/components/sidebar/sidebar-group-action.svelte +36 -0
  262. package/dist/lib/components/sidebar/sidebar-group-action.svelte.d.ts +4 -0
  263. package/dist/lib/components/sidebar/sidebar-group-action.svelte.d.ts.map +1 -0
  264. package/dist/lib/components/sidebar/sidebar-group-content.svelte +21 -0
  265. package/dist/lib/components/sidebar/sidebar-group-content.svelte.d.ts +4 -0
  266. package/dist/lib/components/sidebar/sidebar-group-content.svelte.d.ts.map +1 -0
  267. package/dist/lib/components/sidebar/sidebar-group-label.svelte +34 -0
  268. package/dist/lib/components/sidebar/sidebar-group-label.svelte.d.ts +4 -0
  269. package/dist/lib/components/sidebar/sidebar-group-label.svelte.d.ts.map +1 -0
  270. package/dist/lib/components/sidebar/sidebar-group.svelte +21 -0
  271. package/dist/lib/components/sidebar/sidebar-group.svelte.d.ts +4 -0
  272. package/dist/lib/components/sidebar/sidebar-group.svelte.d.ts.map +1 -0
  273. package/dist/lib/components/sidebar/sidebar-header.svelte +21 -0
  274. package/dist/lib/components/sidebar/sidebar-header.svelte.d.ts +4 -0
  275. package/dist/lib/components/sidebar/sidebar-header.svelte.d.ts.map +1 -0
  276. package/dist/lib/components/sidebar/sidebar-input.svelte +23 -0
  277. package/dist/lib/components/sidebar/sidebar-input.svelte.d.ts +4 -0
  278. package/dist/lib/components/sidebar/sidebar-input.svelte.d.ts.map +1 -0
  279. package/dist/lib/components/sidebar/sidebar-inset.svelte +31 -0
  280. package/dist/lib/components/sidebar/sidebar-inset.svelte.d.ts +4 -0
  281. package/dist/lib/components/sidebar/sidebar-inset.svelte.d.ts.map +1 -0
  282. package/dist/lib/components/sidebar/sidebar-menu-action.svelte +56 -0
  283. package/dist/lib/components/sidebar/sidebar-menu-action.svelte.d.ts +4 -0
  284. package/dist/lib/components/sidebar/sidebar-menu-action.svelte.d.ts.map +1 -0
  285. package/dist/lib/components/sidebar/sidebar-menu-badge.svelte +29 -0
  286. package/dist/lib/components/sidebar/sidebar-menu-badge.svelte.d.ts +4 -0
  287. package/dist/lib/components/sidebar/sidebar-menu-badge.svelte.d.ts.map +1 -0
  288. package/dist/lib/components/sidebar/sidebar-menu-button.svelte +150 -0
  289. package/dist/lib/components/sidebar/sidebar-menu-button.svelte.d.ts +38 -0
  290. package/dist/lib/components/sidebar/sidebar-menu-button.svelte.d.ts.map +1 -0
  291. package/dist/lib/components/sidebar/sidebar-menu-item.svelte +21 -0
  292. package/dist/lib/components/sidebar/sidebar-menu-item.svelte.d.ts +4 -0
  293. package/dist/lib/components/sidebar/sidebar-menu-item.svelte.d.ts.map +1 -0
  294. package/dist/lib/components/sidebar/sidebar-menu-skeleton.svelte +36 -0
  295. package/dist/lib/components/sidebar/sidebar-menu-skeleton.svelte.d.ts +4 -0
  296. package/dist/lib/components/sidebar/sidebar-menu-skeleton.svelte.d.ts.map +1 -0
  297. package/dist/lib/components/sidebar/sidebar-menu-sub-button.svelte +53 -0
  298. package/dist/lib/components/sidebar/sidebar-menu-sub-button.svelte.d.ts +4 -0
  299. package/dist/lib/components/sidebar/sidebar-menu-sub-button.svelte.d.ts.map +1 -0
  300. package/dist/lib/components/sidebar/sidebar-menu-sub-item.svelte +16 -0
  301. package/dist/lib/components/sidebar/sidebar-menu-sub-item.svelte.d.ts +4 -0
  302. package/dist/lib/components/sidebar/sidebar-menu-sub-item.svelte.d.ts.map +1 -0
  303. package/dist/lib/components/sidebar/sidebar-menu-sub.svelte +25 -0
  304. package/dist/lib/components/sidebar/sidebar-menu-sub.svelte.d.ts +4 -0
  305. package/dist/lib/components/sidebar/sidebar-menu-sub.svelte.d.ts.map +1 -0
  306. package/dist/lib/components/sidebar/sidebar-menu.svelte +21 -0
  307. package/dist/lib/components/sidebar/sidebar-menu.svelte.d.ts +4 -0
  308. package/dist/lib/components/sidebar/sidebar-menu.svelte.d.ts.map +1 -0
  309. package/dist/lib/components/sidebar/sidebar-provider.svelte +57 -0
  310. package/dist/lib/components/sidebar/sidebar-provider.svelte.d.ts +4 -0
  311. package/dist/lib/components/sidebar/sidebar-provider.svelte.d.ts.map +1 -0
  312. package/dist/lib/components/sidebar/sidebar-rail.svelte +55 -0
  313. package/dist/lib/components/sidebar/sidebar-rail.svelte.d.ts +4 -0
  314. package/dist/lib/components/sidebar/sidebar-rail.svelte.d.ts.map +1 -0
  315. package/dist/lib/components/sidebar/sidebar-separator.svelte +18 -0
  316. package/dist/lib/components/sidebar/sidebar-separator.svelte.d.ts +4 -0
  317. package/dist/lib/components/sidebar/sidebar-separator.svelte.d.ts.map +1 -0
  318. package/dist/lib/components/sidebar/sidebar-trigger.svelte +36 -0
  319. package/dist/lib/components/sidebar/sidebar-trigger.svelte.d.ts +4 -0
  320. package/dist/lib/components/sidebar/sidebar-trigger.svelte.d.ts.map +1 -0
  321. package/dist/lib/components/sidebar/sidebar.svelte +162 -0
  322. package/dist/lib/components/sidebar/sidebar.svelte.d.ts +4 -0
  323. package/dist/lib/components/sidebar/sidebar.svelte.d.ts.map +1 -0
  324. package/dist/lib/components/utilities/arrow/arrow.svelte.d.ts +2 -1
  325. package/dist/lib/components/utilities/arrow/arrow.svelte.d.ts.map +1 -0
  326. package/dist/lib/components/utilities/arrow/index.d.ts +1 -0
  327. package/dist/lib/components/utilities/arrow/index.d.ts.map +1 -0
  328. package/dist/lib/components/utilities/arrow/types.d.ts +1 -0
  329. package/dist/lib/components/utilities/arrow/types.d.ts.map +1 -0
  330. package/dist/lib/components/utilities/floating-layer/components/floating-layer-anchor.svelte.d.ts +2 -2
  331. package/dist/lib/components/utilities/floating-layer/components/floating-layer-anchor.svelte.d.ts.map +1 -0
  332. package/dist/lib/components/utilities/floating-layer/components/floating-layer-arrow.svelte.d.ts +2 -1
  333. package/dist/lib/components/utilities/floating-layer/components/floating-layer-arrow.svelte.d.ts.map +1 -0
  334. package/dist/lib/components/utilities/floating-layer/components/floating-layer-content-static.svelte.d.ts +2 -11
  335. package/dist/lib/components/utilities/floating-layer/components/floating-layer-content-static.svelte.d.ts.map +1 -0
  336. package/dist/lib/components/utilities/floating-layer/components/floating-layer-content.svelte.d.ts +2 -2
  337. package/dist/lib/components/utilities/floating-layer/components/floating-layer-content.svelte.d.ts.map +1 -0
  338. package/dist/lib/components/utilities/floating-layer/components/floating-layer.svelte.d.ts +2 -5
  339. package/dist/lib/components/utilities/floating-layer/components/floating-layer.svelte.d.ts.map +1 -0
  340. package/dist/lib/components/utilities/floating-layer/components/index.d.ts +1 -0
  341. package/dist/lib/components/utilities/floating-layer/components/index.d.ts.map +1 -0
  342. package/dist/lib/components/utilities/floating-layer/index.d.ts +1 -0
  343. package/dist/lib/components/utilities/floating-layer/index.d.ts.map +1 -0
  344. package/dist/lib/components/utilities/floating-layer/types.d.ts +1 -0
  345. package/dist/lib/components/utilities/floating-layer/types.d.ts.map +1 -0
  346. package/dist/lib/components/utilities/floating-layer/use-floating-layer.svelte.d.ts +1 -0
  347. package/dist/lib/components/utilities/floating-layer/use-floating-layer.svelte.d.ts.map +1 -0
  348. package/dist/lib/index.d.ts +3 -1
  349. package/dist/lib/index.d.ts.map +1 -0
  350. package/dist/lib/index.js +2 -1
  351. package/dist/lib/utils/asyncDerived.svelte.d.ts +1 -0
  352. package/dist/lib/utils/asyncDerived.svelte.d.ts.map +1 -0
  353. package/dist/lib/utils/bits.d.ts +1 -0
  354. package/dist/lib/utils/bits.d.ts.map +1 -0
  355. package/dist/lib/utils/index.d.ts +5 -3
  356. package/dist/lib/utils/index.d.ts.map +1 -0
  357. package/dist/lib/utils/index.js +4 -3
  358. package/dist/lib/utils/reactive.svelte.d.ts +25 -0
  359. package/dist/lib/utils/reactive.svelte.d.ts.map +1 -0
  360. package/dist/lib/utils/reactive.svelte.js +34 -0
  361. package/dist/lib/utils/utils.d.ts +1 -0
  362. package/dist/lib/utils/utils.d.ts.map +1 -0
  363. package/dist/lib/vite/index.d.ts +2 -0
  364. package/dist/lib/vite/index.d.ts.map +1 -0
  365. package/dist/lib/vite/index.js +1 -0
  366. package/dist/lib/vite/vite-plugin-component-source-collector.d.ts +17 -0
  367. package/dist/lib/vite/vite-plugin-component-source-collector.d.ts.map +1 -0
  368. package/dist/lib/vite/vite-plugin-component-source-collector.js +84 -0
  369. package/dist/routes/+layout.svelte.d.ts +4 -11
  370. package/dist/routes/+layout.svelte.d.ts.map +1 -0
  371. package/package.json +48 -33
  372. package/src/app.css +0 -4
  373. package/src/lib/api/form.svelte.ts +65 -0
  374. package/src/lib/api/index.ts +2 -0
  375. package/src/lib/api/query.svelte.ts +59 -0
  376. package/src/lib/components/animated/animated.svelte +5 -3
  377. package/src/lib/components/carousel/carousel-content.svelte +44 -0
  378. package/src/lib/components/carousel/carousel-dots.svelte +28 -0
  379. package/src/lib/components/carousel/carousel-item.svelte +27 -0
  380. package/src/lib/components/carousel/carousel-next.svelte +38 -0
  381. package/src/lib/components/carousel/carousel-previous.svelte +38 -0
  382. package/src/lib/components/carousel/carousel.svelte +103 -0
  383. package/src/lib/components/carousel/context.ts +59 -0
  384. package/src/lib/components/carousel/index.ts +22 -0
  385. package/src/lib/components/dnd/context.svelte.ts +11 -8
  386. package/src/lib/components/dnd/dnd-draghandle.svelte +7 -1
  387. package/src/lib/components/dnd/dnd-sortable-item.svelte +9 -5
  388. package/src/lib/components/dnd/sortable.svelte.ts +4 -1
  389. package/src/lib/components/dnd/utils.svelte.ts +14 -3
  390. package/src/lib/components/form/form-button.svelte +20 -0
  391. package/src/lib/components/form/form-description.svelte +17 -0
  392. package/src/lib/components/form/form-element-field.svelte +24 -0
  393. package/src/lib/components/form/form-field-errors.svelte +30 -0
  394. package/src/lib/components/form/form-field.svelte +29 -0
  395. package/src/lib/components/form/form-fieldset.svelte +15 -0
  396. package/src/lib/components/form/form-label.svelte +24 -0
  397. package/src/lib/components/form/form-legend.svelte +16 -0
  398. package/src/lib/components/form/form.svelte +36 -0
  399. package/src/lib/components/form/index.ts +36 -0
  400. package/src/lib/components/gradient/Gradient.svelte +66 -0
  401. package/src/lib/components/gradient/index.ts +1 -0
  402. package/src/lib/components/safe/index.ts +3 -0
  403. package/src/lib/components/safe/safe.svelte +20 -0
  404. package/src/lib/components/search/components/search-list.svelte +2 -2
  405. package/src/lib/components/sidebar/README.md +10 -0
  406. package/src/lib/components/sidebar/constants.ts +6 -0
  407. package/src/lib/components/sidebar/context.svelte.ts +84 -0
  408. package/src/lib/components/sidebar/index.ts +75 -0
  409. package/src/lib/components/sidebar/sidebar-content.svelte +24 -0
  410. package/src/lib/components/sidebar/sidebar-footer.svelte +21 -0
  411. package/src/lib/components/sidebar/sidebar-group-action.svelte +36 -0
  412. package/src/lib/components/sidebar/sidebar-group-content.svelte +21 -0
  413. package/src/lib/components/sidebar/sidebar-group-label.svelte +34 -0
  414. package/src/lib/components/sidebar/sidebar-group.svelte +21 -0
  415. package/src/lib/components/sidebar/sidebar-header.svelte +21 -0
  416. package/src/lib/components/sidebar/sidebar-input.svelte +23 -0
  417. package/src/lib/components/sidebar/sidebar-inset.svelte +31 -0
  418. package/src/lib/components/sidebar/sidebar-menu-action.svelte +56 -0
  419. package/src/lib/components/sidebar/sidebar-menu-badge.svelte +29 -0
  420. package/src/lib/components/sidebar/sidebar-menu-button.svelte +150 -0
  421. package/src/lib/components/sidebar/sidebar-menu-item.svelte +21 -0
  422. package/src/lib/components/sidebar/sidebar-menu-skeleton.svelte +36 -0
  423. package/src/lib/components/sidebar/sidebar-menu-sub-button.svelte +53 -0
  424. package/src/lib/components/sidebar/sidebar-menu-sub-item.svelte +16 -0
  425. package/src/lib/components/sidebar/sidebar-menu-sub.svelte +25 -0
  426. package/src/lib/components/sidebar/sidebar-menu.svelte +21 -0
  427. package/src/lib/components/sidebar/sidebar-provider.svelte +57 -0
  428. package/src/lib/components/sidebar/sidebar-rail.svelte +55 -0
  429. package/src/lib/components/sidebar/sidebar-separator.svelte +18 -0
  430. package/src/lib/components/sidebar/sidebar-trigger.svelte +36 -0
  431. package/src/lib/components/sidebar/sidebar.svelte +162 -0
  432. package/src/lib/index.ts +2 -1
  433. package/src/lib/utils/index.ts +4 -3
  434. package/src/lib/utils/reactive.svelte.ts +38 -0
  435. package/src/lib/vite/index.ts +1 -0
  436. package/src/lib/vite/vite-plugin-component-source-collector.ts +115 -0
  437. package/dist/lib/components/Typeahead.svelte.d.ts +0 -47
  438. package/dist/lib/components/Typeahead.svelte.js +0 -150
  439. package/dist/lib/components/combo/combo.svelte +0 -186
  440. package/dist/lib/components/combo/combo.svelte.d.ts +0 -21
  441. package/dist/lib/components/combo/index.d.ts +0 -2
  442. package/dist/lib/components/combo/index.js +0 -2
  443. package/src/lib/components/Typeahead.svelte.ts +0 -200
  444. package/src/lib/components/combo/combo.svelte +0 -186
  445. package/src/lib/components/combo/index.ts +0 -3
@@ -1,150 +0,0 @@
1
- import Fuse from 'fuse.js';
2
- import fuse, {} from 'fuse.js';
3
- import { value } from '../utils/args';
4
- import { untrack } from 'svelte';
5
- export class Typeahead {
6
- // Props
7
- args = $state(null);
8
- initialValue = $derived(value(this.args?.initialValue));
9
- data = $derived(value(this.args?.data));
10
- searchWith = $derived(value(this.args?.searchWith));
11
- onStopTyping = $derived(this.args?.onStopTyping);
12
- debounceDelay = $derived(300);
13
- onInput = $derived(this.args?.onInput);
14
- // DOM elements
15
- inputE = $state(null);
16
- wrapperE = $state(null);
17
- // State
18
- _value = $state('');
19
- debounceTimer = $state(null);
20
- // Fuse
21
- fuse = $derived.by(() => {
22
- const options = {
23
- threshold: 0.6,
24
- includeMatches: true
25
- };
26
- // if (keys) options.keys = keys;
27
- return new Fuse(this.data, options);
28
- });
29
- _suggestions = $state([]);
30
- showSuggestions = $state(false);
31
- constructor(args) {
32
- this.args = args;
33
- $effect(() => {
34
- if (this.data) {
35
- untrack(() => {
36
- if (this.inputE) {
37
- const searchResult = this.fuse.search(this.searchWith ?? this.inputE.value);
38
- this._suggestions = searchResult;
39
- }
40
- });
41
- }
42
- });
43
- }
44
- get elements() {
45
- return {
46
- /**
47
- * The input element
48
- */
49
- input: (node) => {
50
- this.inputE = node;
51
- this.inputE.spellcheck = false;
52
- $effect(() => {
53
- this.inputE.value = this.initialValue;
54
- this._value = this.initialValue;
55
- });
56
- node.oninput = (e) => {
57
- this._value = this.inputE.value;
58
- this.onInput(e);
59
- const isSynthetic = e.isSynthetic === true;
60
- const searchResult = this.fuse.search(this.searchWith ?? this.inputE.value);
61
- this._suggestions = searchResult;
62
- // Don't show suggestions if the input is synthetic (ie from a click)
63
- if (!isSynthetic)
64
- this.showSuggestions = true;
65
- if (this.onStopTyping) {
66
- // Clear any existing timer
67
- if (this.debounceTimer !== null) {
68
- clearTimeout(this.debounceTimer);
69
- }
70
- // Set a new timer
71
- this.debounceTimer = setTimeout(() => {
72
- if (this.onStopTyping) {
73
- this.onStopTyping(this._value);
74
- }
75
- this.debounceTimer = null;
76
- }, this.debounceDelay);
77
- }
78
- };
79
- this.inputE.onfocus = () => {
80
- if (this.inputE)
81
- this._suggestions = this.fuse.search(this.inputE.value);
82
- this.showSuggestions = true;
83
- };
84
- },
85
- /**
86
- * The wrapper element
87
- */
88
- wrapper: (node) => {
89
- this.wrapperE = node;
90
- this.wrapperE.addEventListener('focusout', (event) => {
91
- const relatedTarget = event.relatedTarget;
92
- if (!relatedTarget || !event.currentTarget.contains(relatedTarget)) {
93
- this.showSuggestions = false;
94
- }
95
- });
96
- },
97
- /**
98
- * Suggestion button
99
- */
100
- suggestionButton: (node, suggestion) => {
101
- const selectSuggestion = () => {
102
- if (this.inputE) {
103
- this.inputE.value = suggestion.item;
104
- const e = new InputEvent('input', { bubbles: true, cancelable: true });
105
- e.isSynthetic = true;
106
- this.inputE.dispatchEvent(e);
107
- }
108
- // Un focus so that the suggestions go away
109
- if (this.wrapperE) {
110
- this.wrapperE.blur();
111
- const focusableChildren = this.wrapperE.querySelectorAll('button, input, textarea, select, a, [tabindex]');
112
- focusableChildren.forEach((child) => child.blur());
113
- }
114
- };
115
- node.onmousedown = selectSuggestion.bind(this);
116
- node.onkeydown = (e) => {
117
- if (e.key === 'Enter')
118
- selectSuggestion.bind(this)();
119
- };
120
- },
121
- /**
122
- * Produces html with matches given the 'highlight' class
123
- */
124
- matches: (suggestion) => {
125
- let result = '';
126
- let lastIndex = 0;
127
- const text = suggestion.item;
128
- const matches = suggestion.matches?.[0];
129
- if (!matches)
130
- return text;
131
- for (const [start, end] of matches.indices) {
132
- result += text.slice(lastIndex, start);
133
- result += `<span class="bg-primary/70 rounded-xs">${text.slice(start, end + 1)}</span>`;
134
- lastIndex = end + 1;
135
- }
136
- result += text.slice(lastIndex); // Add remaining unhighlighted part
137
- return result;
138
- }
139
- };
140
- }
141
- get suggestions() {
142
- return this._suggestions.length !== 0 && this.showSuggestions ? this._suggestions : undefined;
143
- }
144
- get value() {
145
- return this._value;
146
- }
147
- get input() {
148
- return this.inputE;
149
- }
150
- }
@@ -1,186 +0,0 @@
1
- <script lang="ts" module>
2
- </script>
3
-
4
- <script lang="ts">
5
- import { cn } from '../../utils/utils.js';
6
- import * as Popover from '$shadcn/popover/index.js';
7
- import { Button } from '$shadcn/button/index.js';
8
- import * as Command from '$shadcn/command/index.js';
9
- import { tick, type Snippet } from 'svelte';
10
- import { watch } from 'runed';
11
- import * as Pagination from '$shadcn/pagination/index.js';
12
- import { Input } from '$shadcn/input/index.js';
13
-
14
- import type { HTMLDivAttributes } from '../../utils';
15
- import CommandInput from '$shadcn/command/command-input.svelte';
16
-
17
- type Props = HTMLDivAttributes & {
18
- value: string;
19
- total: number;
20
- allItems: { label: string; value: string }[];
21
- activeItems: { label: string; value: string }[];
22
- itemSnippet: Snippet<[item: { label: string; value: string }]>;
23
- };
24
-
25
- // TODO move away from command
26
- // TODO make all items optional in the case where searching should be external
27
- let {
28
- value = $bindable(),
29
- activeItems = $bindable(),
30
- class: className = '',
31
- itemSnippet,
32
- total,
33
- allItems,
34
- children,
35
- ...restProps
36
- }: Props = $props();
37
-
38
- const itemsPerPage = 2;
39
-
40
- let open = $state(false);
41
- let triggerRef = $state<HTMLButtonElement>(null!);
42
-
43
- let page = $state(1);
44
- let start = $state(0);
45
- let end = $state(Math.min(total, itemsPerPage));
46
-
47
- let searchTerm = $state('');
48
- let validItems = $state(allItems);
49
-
50
- // Allows total to start as 0 and be set later
51
- watch(
52
- () => total,
53
- () => {
54
- if (end === 0 && total > 0) {
55
- end = Math.min(total, itemsPerPage);
56
- }
57
- }
58
- );
59
-
60
- // Change the start and end when the page changes
61
- $effect(() => {
62
- start = page * itemsPerPage - itemsPerPage;
63
- end = Math.min(total, start + itemsPerPage);
64
- });
65
-
66
- // Get items when the start/end changes
67
- $effect(() => {
68
- if (open) {
69
- activeItems = validItems.slice(start, end);
70
- } else {
71
- activeItems = [];
72
- }
73
- });
74
-
75
- // Search through all items and set valid items
76
- $effect(() => {
77
- if (searchTerm) {
78
- validItems = allItems.filter((item) => item.label.toLowerCase().includes(searchTerm.toLowerCase()));
79
- } else {
80
- validItems = allItems;
81
- }
82
- });
83
-
84
- let selectedLabel = $state('');
85
-
86
- // We want to refocus the trigger button when the user selects
87
- // an item from the list so users can continue navigating the
88
- // rest of the form with the keyboard.
89
- function closeAndFocusTrigger() {
90
- open = false;
91
- tick().then(() => {
92
- triggerRef.focus();
93
- });
94
- }
95
- </script>
96
-
97
- <div {...restProps} class={cn(className)}>
98
- {@render children?.()}
99
- </div>
100
-
101
- <Popover.Root bind:open>
102
- <Popover.Trigger bind:ref={triggerRef}>
103
- {#snippet child({ props })}
104
- <Button variant="outline" class="w-full justify-between" {...props} role="combobox" aria-expanded={open}>
105
- {selectedLabel || 'Select an item...'}
106
- <span class="icon-[lucide--chevrons-up-down] opacity-50"></span>
107
- </Button>
108
- {/snippet}
109
- </Popover.Trigger>
110
- <Popover.Content class="w-full p-0">
111
- <Command.Root shouldFilter={false}>
112
- <CommandInput placeholder="Search item..." bind:value={searchTerm} />
113
- <!-- <div class="flex items-center border-b px-2" data-command-input-wrapper="">
114
- <Search class="mr-2 size-4 shrink-0 opacity-50" />
115
- <Input
116
- class="
117
- placeholder:text-muted-foreground
118
- flex h-11 w-full rounded-md bg-transparent py-3 text-base outline-none
119
- disabled:cursor-not-allowed disabled:opacity-50
120
- md:text-sm
121
- "
122
- placeholder="Search item..."
123
- bind:value={searchTerm}
124
- />
125
- </div> -->
126
- <div class="flex flex-col items-center justify-center gap-2 p-1">
127
- <Command.List
128
- class="
129
- scrollbar-thin scrollbar-track-sidebar scrollbar-track-rounded-full scrollbar-thumb-sidebar-accent
130
- scrollbar-thumb-rounded-full
131
- scrollbar-hover:scrollbar-thumb-sidebar-primary/30
132
- scrollbar-active:scrollbar-thumb-sidebar-primary/60
133
- "
134
- >
135
- <Command.Empty>No item found.</Command.Empty>
136
- <Command.Group>
137
- {#each activeItems as item (item.value)}
138
- <Command.Item
139
- value={item.label}
140
- onSelect={() => {
141
- value = item.value;
142
- selectedLabel = item.label;
143
- closeAndFocusTrigger();
144
- }}
145
- >
146
- <span class={cn('icon-[lucide--check]', value !== item.value && 'text-transparent')}> </span>
147
-
148
- {#if itemSnippet}
149
- {@render itemSnippet(item)}
150
- {:else}
151
- {item.label}
152
- {/if}
153
- </Command.Item>
154
- {/each}
155
- </Command.Group>
156
- </Command.List>
157
-
158
- <Pagination.Root count={validItems.length} perPage={itemsPerPage} bind:page>
159
- {#snippet children({ pages, currentPage })}
160
- <Pagination.Content>
161
- <Pagination.Item>
162
- <Pagination.PrevButton />
163
- </Pagination.Item>
164
- {#each pages as page (page.key)}
165
- {#if page.type === 'ellipsis'}
166
- <Pagination.Item>
167
- <Pagination.Ellipsis />
168
- </Pagination.Item>
169
- {:else}
170
- <Pagination.Item isVisible={currentPage === page.value}>
171
- <Pagination.Link {page} isActive={currentPage === page.value}>
172
- {page.value}
173
- </Pagination.Link>
174
- </Pagination.Item>
175
- {/if}
176
- {/each}
177
- <Pagination.Item>
178
- <Pagination.NextButton />
179
- </Pagination.Item>
180
- </Pagination.Content>
181
- {/snippet}
182
- </Pagination.Root>
183
- </div>
184
- </Command.Root>
185
- </Popover.Content>
186
- </Popover.Root>
@@ -1,21 +0,0 @@
1
- import { type Snippet } from 'svelte';
2
- import type { HTMLDivAttributes } from '../../utils';
3
- type Props = HTMLDivAttributes & {
4
- value: string;
5
- total: number;
6
- allItems: {
7
- label: string;
8
- value: string;
9
- }[];
10
- activeItems: {
11
- label: string;
12
- value: string;
13
- }[];
14
- itemSnippet: Snippet<[item: {
15
- label: string;
16
- value: string;
17
- }]>;
18
- };
19
- declare const Combo: import("svelte").Component<Props, {}, "value" | "activeItems">;
20
- type Combo = ReturnType<typeof Combo>;
21
- export default Combo;
@@ -1,2 +0,0 @@
1
- import Combo from './combo.svelte';
2
- export { Combo };
@@ -1,2 +0,0 @@
1
- import Combo from './combo.svelte';
2
- export { Combo };
@@ -1,200 +0,0 @@
1
- import Fuse from 'fuse.js';
2
- import fuse, { type FuseResult, type IFuseOptions } from 'fuse.js';
3
- import { value, type Wrap } from '../utils/args';
4
- import { untrack } from 'svelte';
5
-
6
- // <div use:wrapper class="typeahead">
7
- // <input use:input />
8
-
9
- // {#if suggestions.length !== 0 && showSuggestions}
10
- // <ol transition:slide={{ axis: 'y', duration: 100 }}>
11
- // {#each suggestions as suggestion, index (suggestion.item)}
12
- // <li animate:flip={{ delay: 0, duration: 200 }}>
13
- // <button use:suggestionButton={suggestion}>
14
- // {@html matches(suggestion)}
15
- // </button>
16
- // </li>
17
- // {/each}
18
- // </ol>
19
- // {/if}
20
- // </div>
21
-
22
- export type Args = Wrap<{
23
- onInput: (e: InputEvent) => void;
24
- searchWith?: () => string;
25
- initialValue: () => string;
26
- onStopTyping?: (value: string) => void;
27
- data: string[];
28
- }>;
29
-
30
- export class Typeahead {
31
- // Props
32
- private args: Args | null = $state(null);
33
- private initialValue: string = $derived(value(this.args?.initialValue));
34
- private data: string[] = $derived(value(this.args?.data));
35
- private searchWith: string = $derived(value(this.args?.searchWith));
36
- private onStopTyping: ((value: string) => void) | undefined = $derived(this.args?.onStopTyping);
37
- private debounceDelay: number = $derived(300);
38
-
39
- private onInput: (e: InputEvent) => void = $derived(this.args?.onInput);
40
-
41
- // DOM elements
42
- private inputE: HTMLInputElement | null = $state(null);
43
- private wrapperE: HTMLDivElement | null = $state(null);
44
-
45
- // State
46
- private _value = $state('');
47
- private debounceTimer: number | null = $state(null);
48
-
49
- // Fuse
50
- private fuse = $derived.by(() => {
51
- const options: IFuseOptions<string> = {
52
- threshold: 0.6,
53
- includeMatches: true
54
- };
55
- // if (keys) options.keys = keys;
56
-
57
- return new Fuse(this.data, options);
58
- });
59
- private _suggestions: FuseResult<string>[] = $state([]);
60
- private showSuggestions: boolean = $state(false);
61
-
62
- constructor(args: Args) {
63
- this.args = args;
64
-
65
- $effect(() => {
66
- if (this.data) {
67
- untrack(() => {
68
- if (this.inputE) {
69
- const searchResult = this.fuse.search(this.searchWith ?? this.inputE.value);
70
- this._suggestions = searchResult;
71
- }
72
- });
73
- }
74
- });
75
- }
76
-
77
- get elements() {
78
- return {
79
- /**
80
- * The input element
81
- */
82
- input: (node: HTMLInputElement) => {
83
- this.inputE = node;
84
- this.inputE.spellcheck = false;
85
-
86
- $effect(() => {
87
- this.inputE.value = this.initialValue;
88
- this._value = this.initialValue;
89
- });
90
-
91
- node.oninput = (e: InputEvent) => {
92
- this._value = this.inputE.value;
93
- this.onInput(e);
94
-
95
- const isSynthetic = (e as any).isSynthetic === true;
96
-
97
- const searchResult = this.fuse.search(this.searchWith ?? this.inputE.value);
98
-
99
- this._suggestions = searchResult;
100
-
101
- // Don't show suggestions if the input is synthetic (ie from a click)
102
- if (!isSynthetic) this.showSuggestions = true;
103
-
104
- if (this.onStopTyping) {
105
- // Clear any existing timer
106
- if (this.debounceTimer !== null) {
107
- clearTimeout(this.debounceTimer);
108
- }
109
-
110
- // Set a new timer
111
- this.debounceTimer = setTimeout(() => {
112
- if (this.onStopTyping) {
113
- this.onStopTyping(this._value);
114
- }
115
- this.debounceTimer = null;
116
- }, this.debounceDelay) as unknown as number;
117
- }
118
- };
119
-
120
- this.inputE.onfocus = () => {
121
- if (this.inputE) this._suggestions = this.fuse.search(this.inputE.value);
122
- this.showSuggestions = true;
123
- };
124
- },
125
-
126
- /**
127
- * The wrapper element
128
- */
129
- wrapper: (node: HTMLDivElement) => {
130
- this.wrapperE = node;
131
- this.wrapperE.addEventListener('focusout', (event: FocusEvent) => {
132
- const relatedTarget = event.relatedTarget;
133
- if (!relatedTarget || !event.currentTarget.contains(relatedTarget)) {
134
- this.showSuggestions = false;
135
- }
136
- });
137
- },
138
-
139
- /**
140
- * Suggestion button
141
- */
142
- suggestionButton: (node: HTMLButtonElement, suggestion: FuseResult<string>) => {
143
- const selectSuggestion = () => {
144
- if (this.inputE) {
145
- this.inputE.value = suggestion.item;
146
- const e = new InputEvent('input', { bubbles: true, cancelable: true });
147
- (e as any).isSynthetic = true;
148
- this.inputE.dispatchEvent(e);
149
- }
150
-
151
- // Un focus so that the suggestions go away
152
- if (this.wrapperE) {
153
- this.wrapperE.blur();
154
- const focusableChildren = this.wrapperE.querySelectorAll('button, input, textarea, select, a, [tabindex]');
155
- focusableChildren.forEach((child) => child.blur());
156
- }
157
- };
158
-
159
- node.onmousedown = selectSuggestion.bind(this);
160
- node.onkeydown = (e) => {
161
- if (e.key === 'Enter') selectSuggestion.bind(this)();
162
- };
163
- },
164
-
165
- /**
166
- * Produces html with matches given the 'highlight' class
167
- */
168
- matches: (suggestion: FuseResult<string>) => {
169
- let result = '';
170
- let lastIndex = 0;
171
-
172
- const text = suggestion.item;
173
- const matches = suggestion.matches?.[0];
174
-
175
- if (!matches) return text;
176
-
177
- for (const [start, end] of matches.indices) {
178
- result += text.slice(lastIndex, start);
179
- result += `<span class="bg-primary/70 rounded-xs">${text.slice(start, end + 1)}</span>`;
180
- lastIndex = end + 1;
181
- }
182
-
183
- result += text.slice(lastIndex); // Add remaining unhighlighted part
184
- return result;
185
- }
186
- };
187
- }
188
-
189
- get suggestions() {
190
- return this._suggestions.length !== 0 && this.showSuggestions ? this._suggestions : undefined;
191
- }
192
-
193
- get value() {
194
- return this._value;
195
- }
196
-
197
- get input() {
198
- return this.inputE;
199
- }
200
- }