svelte-firekit 0.1.7 → 0.1.9

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 (355) hide show
  1. package/README.md +365 -308
  2. package/dist/components/docs/doc-content.svelte +19 -0
  3. package/dist/components/docs/doc-content.svelte.d.ts +6 -0
  4. package/dist/components/docs/doc-header.svelte +24 -0
  5. package/dist/components/docs/doc-header.svelte.d.ts +13 -0
  6. package/dist/components/docs/doc-renderer.svelte +27 -0
  7. package/dist/components/docs/doc-renderer.svelte.d.ts +8 -0
  8. package/dist/components/docs/mobile-table-of-contents.svelte +42 -0
  9. package/dist/components/docs/mobile-table-of-contents.svelte.d.ts +3 -0
  10. package/dist/components/docs/table-of-contents.svelte +33 -0
  11. package/dist/components/docs/table-of-contents.svelte.d.ts +4 -0
  12. package/dist/components/docs/toc.svelte.d.ts +16 -0
  13. package/dist/components/docs/toc.svelte.js +59 -0
  14. package/dist/components/{Collection.svelte → firekit/Collection.svelte} +2 -2
  15. package/dist/components/{Doc.svelte → firekit/Doc.svelte} +11 -11
  16. package/dist/components/{Doc.svelte.d.ts → firekit/Doc.svelte.d.ts} +1 -1
  17. package/dist/components/{Node.svelte → firekit/Node.svelte} +2 -2
  18. package/dist/components/{auth-guard.svelte → firekit/auth-guard.svelte} +5 -5
  19. package/dist/components/{auth-guard.svelte.d.ts → firekit/auth-guard.svelte.d.ts} +1 -1
  20. package/dist/components/{custom-guard.svelte → firekit/custom-guard.svelte} +5 -5
  21. package/dist/components/{custom-guard.svelte.d.ts → firekit/custom-guard.svelte.d.ts} +1 -1
  22. package/dist/components/{download-url.svelte → firekit/download-url.svelte} +2 -2
  23. package/dist/components/{firebase-app.svelte → firekit/firebase-app.svelte} +1 -1
  24. package/dist/components/{node-list.svelte → firekit/node-list.svelte} +2 -2
  25. package/dist/components/{signed-in.svelte → firekit/signed-in.svelte} +3 -3
  26. package/dist/components/{signed-in.svelte.d.ts → firekit/signed-in.svelte.d.ts} +1 -1
  27. package/dist/components/{signed-out.svelte → firekit/signed-out.svelte} +2 -2
  28. package/dist/components/{storage-list.svelte → firekit/storage-list.svelte} +2 -2
  29. package/dist/components/{upload-task.svelte → firekit/upload-task.svelte} +2 -2
  30. package/dist/components/nav/app-sidebar.svelte +175 -0
  31. package/dist/components/nav/app-sidebar.svelte.d.ts +9 -0
  32. package/dist/components/nav/auto-breadcrumb.svelte +41 -0
  33. package/dist/components/nav/auto-breadcrumb.svelte.d.ts +3 -0
  34. package/dist/components/nav/dark-mode-toggle.svelte +17 -0
  35. package/dist/components/nav/dark-mode-toggle.svelte.d.ts +18 -0
  36. package/dist/components/nav/nav-components.svelte +24 -0
  37. package/dist/components/nav/nav-components.svelte.d.ts +11 -0
  38. package/dist/components/nav/nav-main.svelte +45 -0
  39. package/dist/components/nav/nav-main.svelte.d.ts +11 -0
  40. package/dist/components/nav/nav-secondary.svelte +32 -0
  41. package/dist/components/nav/nav-secondary.svelte.d.ts +14 -0
  42. package/dist/components/nav/site-header.svelte +32 -0
  43. package/dist/components/nav/site-header.svelte.d.ts +18 -0
  44. package/dist/components/ui/avatar/avatar-fallback.svelte +17 -0
  45. package/dist/components/ui/avatar/avatar-fallback.svelte.d.ts +4 -0
  46. package/dist/components/ui/avatar/avatar-image.svelte +17 -0
  47. package/dist/components/ui/avatar/avatar-image.svelte.d.ts +4 -0
  48. package/dist/components/ui/avatar/avatar.svelte +19 -0
  49. package/dist/components/ui/avatar/avatar.svelte.d.ts +4 -0
  50. package/dist/components/ui/avatar/index.d.ts +4 -0
  51. package/dist/components/ui/avatar/index.js +6 -0
  52. package/dist/components/ui/badge/badge.svelte +50 -0
  53. package/dist/components/ui/badge/badge.svelte.d.ts +32 -0
  54. package/dist/components/ui/badge/index.d.ts +2 -0
  55. package/dist/components/ui/badge/index.js +2 -0
  56. package/dist/components/ui/breadcrumb/breadcrumb-ellipsis.svelte +23 -0
  57. package/dist/components/ui/breadcrumb/breadcrumb-ellipsis.svelte.d.ts +5 -0
  58. package/dist/components/ui/breadcrumb/breadcrumb-item.svelte +20 -0
  59. package/dist/components/ui/breadcrumb/breadcrumb-item.svelte.d.ts +5 -0
  60. package/dist/components/ui/breadcrumb/breadcrumb-link.svelte +31 -0
  61. package/dist/components/ui/breadcrumb/breadcrumb-link.svelte.d.ts +11 -0
  62. package/dist/components/ui/breadcrumb/breadcrumb-list.svelte +23 -0
  63. package/dist/components/ui/breadcrumb/breadcrumb-list.svelte.d.ts +5 -0
  64. package/dist/components/ui/breadcrumb/breadcrumb-page.svelte +23 -0
  65. package/dist/components/ui/breadcrumb/breadcrumb-page.svelte.d.ts +5 -0
  66. package/dist/components/ui/breadcrumb/breadcrumb-separator.svelte +27 -0
  67. package/dist/components/ui/breadcrumb/breadcrumb-separator.svelte.d.ts +5 -0
  68. package/dist/components/ui/breadcrumb/breadcrumb.svelte +21 -0
  69. package/dist/components/ui/breadcrumb/breadcrumb.svelte.d.ts +5 -0
  70. package/dist/components/ui/breadcrumb/index.d.ts +8 -0
  71. package/dist/components/ui/breadcrumb/index.js +10 -0
  72. package/dist/components/ui/button/button.svelte +80 -0
  73. package/dist/components/ui/button/button.svelte.d.ts +58 -0
  74. package/dist/components/ui/button/index.d.ts +2 -0
  75. package/dist/components/ui/button/index.js +4 -0
  76. package/dist/components/ui/card/card-action.svelte +20 -0
  77. package/dist/components/ui/card/card-action.svelte.d.ts +5 -0
  78. package/dist/components/ui/card/card-content.svelte +15 -0
  79. package/dist/components/ui/card/card-content.svelte.d.ts +5 -0
  80. package/dist/components/ui/card/card-description.svelte +20 -0
  81. package/dist/components/ui/card/card-description.svelte.d.ts +5 -0
  82. package/dist/components/ui/card/card-footer.svelte +20 -0
  83. package/dist/components/ui/card/card-footer.svelte.d.ts +5 -0
  84. package/dist/components/ui/card/card-header.svelte +23 -0
  85. package/dist/components/ui/card/card-header.svelte.d.ts +5 -0
  86. package/dist/components/ui/card/card-title.svelte +20 -0
  87. package/dist/components/ui/card/card-title.svelte.d.ts +5 -0
  88. package/dist/components/ui/card/card.svelte +23 -0
  89. package/dist/components/ui/card/card.svelte.d.ts +5 -0
  90. package/dist/components/ui/card/index.d.ts +8 -0
  91. package/dist/components/ui/card/index.js +10 -0
  92. package/dist/components/ui/chart/chart-container.svelte +80 -0
  93. package/dist/components/ui/chart/chart-container.svelte.d.ts +9 -0
  94. package/dist/components/ui/chart/chart-style.svelte +36 -0
  95. package/dist/components/ui/chart/chart-style.svelte.d.ts +8 -0
  96. package/dist/components/ui/chart/chart-tooltip.svelte +159 -0
  97. package/dist/components/ui/chart/chart-tooltip.svelte.d.ts +27 -0
  98. package/dist/components/ui/chart/chart-utils.d.ts +36 -0
  99. package/dist/components/ui/chart/chart-utils.js +33 -0
  100. package/dist/components/ui/chart/index.d.ts +4 -0
  101. package/dist/components/ui/chart/index.js +4 -0
  102. package/dist/components/ui/checkbox/checkbox.svelte +36 -0
  103. package/dist/components/ui/checkbox/checkbox.svelte.d.ts +4 -0
  104. package/dist/components/ui/checkbox/index.d.ts +2 -0
  105. package/dist/components/ui/checkbox/index.js +4 -0
  106. package/dist/components/ui/data-table/data-table.svelte.d.ts +40 -0
  107. package/dist/components/ui/data-table/data-table.svelte.js +110 -0
  108. package/dist/components/ui/data-table/flex-render.svelte +36 -0
  109. package/dist/components/ui/data-table/flex-render.svelte.d.ts +30 -0
  110. package/dist/components/ui/data-table/index.d.ts +3 -0
  111. package/dist/components/ui/data-table/index.js +3 -0
  112. package/dist/components/ui/data-table/render-helpers.d.ts +90 -0
  113. package/dist/components/ui/data-table/render-helpers.js +99 -0
  114. package/dist/components/ui/dialog/dialog-close.svelte +7 -0
  115. package/dist/components/ui/dialog/dialog-close.svelte.d.ts +4 -0
  116. package/dist/components/ui/dialog/dialog-content.svelte +43 -0
  117. package/dist/components/ui/dialog/dialog-content.svelte.d.ts +11 -0
  118. package/dist/components/ui/dialog/dialog-description.svelte +17 -0
  119. package/dist/components/ui/dialog/dialog-description.svelte.d.ts +4 -0
  120. package/dist/components/ui/dialog/dialog-footer.svelte +20 -0
  121. package/dist/components/ui/dialog/dialog-footer.svelte.d.ts +5 -0
  122. package/dist/components/ui/dialog/dialog-header.svelte +20 -0
  123. package/dist/components/ui/dialog/dialog-header.svelte.d.ts +5 -0
  124. package/dist/components/ui/dialog/dialog-overlay.svelte +20 -0
  125. package/dist/components/ui/dialog/dialog-overlay.svelte.d.ts +4 -0
  126. package/dist/components/ui/dialog/dialog-title.svelte +17 -0
  127. package/dist/components/ui/dialog/dialog-title.svelte.d.ts +4 -0
  128. package/dist/components/ui/dialog/dialog-trigger.svelte +7 -0
  129. package/dist/components/ui/dialog/dialog-trigger.svelte.d.ts +4 -0
  130. package/dist/components/ui/dialog/index.d.ts +11 -0
  131. package/dist/components/ui/dialog/index.js +14 -0
  132. package/dist/components/ui/drawer/drawer-close.svelte +7 -0
  133. package/dist/components/ui/drawer/drawer-close.svelte.d.ts +4 -0
  134. package/dist/components/ui/drawer/drawer-content.svelte +37 -0
  135. package/dist/components/ui/drawer/drawer-content.svelte.d.ts +7 -0
  136. package/dist/components/ui/drawer/drawer-description.svelte +17 -0
  137. package/dist/components/ui/drawer/drawer-description.svelte.d.ts +4 -0
  138. package/dist/components/ui/drawer/drawer-footer.svelte +20 -0
  139. package/dist/components/ui/drawer/drawer-footer.svelte.d.ts +5 -0
  140. package/dist/components/ui/drawer/drawer-header.svelte +20 -0
  141. package/dist/components/ui/drawer/drawer-header.svelte.d.ts +5 -0
  142. package/dist/components/ui/drawer/drawer-nested.svelte +12 -0
  143. package/dist/components/ui/drawer/drawer-nested.svelte.d.ts +3 -0
  144. package/dist/components/ui/drawer/drawer-overlay.svelte +20 -0
  145. package/dist/components/ui/drawer/drawer-overlay.svelte.d.ts +4 -0
  146. package/dist/components/ui/drawer/drawer-title.svelte +17 -0
  147. package/dist/components/ui/drawer/drawer-title.svelte.d.ts +4 -0
  148. package/dist/components/ui/drawer/drawer-trigger.svelte +7 -0
  149. package/dist/components/ui/drawer/drawer-trigger.svelte.d.ts +4 -0
  150. package/dist/components/ui/drawer/drawer.svelte +12 -0
  151. package/dist/components/ui/drawer/drawer.svelte.d.ts +3 -0
  152. package/dist/components/ui/drawer/index.d.ts +13 -0
  153. package/dist/components/ui/drawer/index.js +15 -0
  154. package/dist/components/ui/dropdown-menu/dropdown-menu-checkbox-item.svelte +41 -0
  155. package/dist/components/ui/dropdown-menu/dropdown-menu-checkbox-item.svelte.d.ts +9 -0
  156. package/dist/components/ui/dropdown-menu/dropdown-menu-content.svelte +27 -0
  157. package/dist/components/ui/dropdown-menu/dropdown-menu-content.svelte.d.ts +7 -0
  158. package/dist/components/ui/dropdown-menu/dropdown-menu-group-heading.svelte +22 -0
  159. package/dist/components/ui/dropdown-menu/dropdown-menu-group-heading.svelte.d.ts +8 -0
  160. package/dist/components/ui/dropdown-menu/dropdown-menu-group.svelte +7 -0
  161. package/dist/components/ui/dropdown-menu/dropdown-menu-group.svelte.d.ts +4 -0
  162. package/dist/components/ui/dropdown-menu/dropdown-menu-item.svelte +27 -0
  163. package/dist/components/ui/dropdown-menu/dropdown-menu-item.svelte.d.ts +8 -0
  164. package/dist/components/ui/dropdown-menu/dropdown-menu-label.svelte +24 -0
  165. package/dist/components/ui/dropdown-menu/dropdown-menu-label.svelte.d.ts +8 -0
  166. package/dist/components/ui/dropdown-menu/dropdown-menu-radio-group.svelte +16 -0
  167. package/dist/components/ui/dropdown-menu/dropdown-menu-radio-group.svelte.d.ts +4 -0
  168. package/dist/components/ui/dropdown-menu/dropdown-menu-radio-item.svelte +31 -0
  169. package/dist/components/ui/dropdown-menu/dropdown-menu-radio-item.svelte.d.ts +4 -0
  170. package/dist/components/ui/dropdown-menu/dropdown-menu-separator.svelte +17 -0
  171. package/dist/components/ui/dropdown-menu/dropdown-menu-separator.svelte.d.ts +4 -0
  172. package/dist/components/ui/dropdown-menu/dropdown-menu-shortcut.svelte +20 -0
  173. package/dist/components/ui/dropdown-menu/dropdown-menu-shortcut.svelte.d.ts +5 -0
  174. package/dist/components/ui/dropdown-menu/dropdown-menu-sub-content.svelte +20 -0
  175. package/dist/components/ui/dropdown-menu/dropdown-menu-sub-content.svelte.d.ts +4 -0
  176. package/dist/components/ui/dropdown-menu/dropdown-menu-sub-trigger.svelte +29 -0
  177. package/dist/components/ui/dropdown-menu/dropdown-menu-sub-trigger.svelte.d.ts +7 -0
  178. package/dist/components/ui/dropdown-menu/dropdown-menu-trigger.svelte +7 -0
  179. package/dist/components/ui/dropdown-menu/dropdown-menu-trigger.svelte.d.ts +4 -0
  180. package/dist/components/ui/dropdown-menu/index.d.ts +25 -0
  181. package/dist/components/ui/dropdown-menu/index.js +17 -0
  182. package/dist/components/ui/input/index.d.ts +2 -0
  183. package/dist/components/ui/input/index.js +4 -0
  184. package/dist/components/ui/input/input.svelte +51 -0
  185. package/dist/components/ui/input/input.svelte.d.ts +13 -0
  186. package/dist/components/ui/label/index.d.ts +2 -0
  187. package/dist/components/ui/label/index.js +4 -0
  188. package/dist/components/ui/label/label.svelte +20 -0
  189. package/dist/components/ui/label/label.svelte.d.ts +4 -0
  190. package/dist/components/ui/scroll-area/index.d.ts +3 -0
  191. package/dist/components/ui/scroll-area/index.js +5 -0
  192. package/dist/components/ui/scroll-area/scroll-area-scrollbar.svelte +31 -0
  193. package/dist/components/ui/scroll-area/scroll-area-scrollbar.svelte.d.ts +4 -0
  194. package/dist/components/ui/scroll-area/scroll-area.svelte +40 -0
  195. package/dist/components/ui/scroll-area/scroll-area.svelte.d.ts +10 -0
  196. package/dist/components/ui/select/index.d.ts +11 -0
  197. package/dist/components/ui/select/index.js +14 -0
  198. package/dist/components/ui/select/select-content.svelte +40 -0
  199. package/dist/components/ui/select/select-content.svelte.d.ts +8 -0
  200. package/dist/components/ui/select/select-group-heading.svelte +21 -0
  201. package/dist/components/ui/select/select-group-heading.svelte.d.ts +10 -0
  202. package/dist/components/ui/select/select-group.svelte +7 -0
  203. package/dist/components/ui/select/select-group.svelte.d.ts +4 -0
  204. package/dist/components/ui/select/select-item.svelte +38 -0
  205. package/dist/components/ui/select/select-item.svelte.d.ts +4 -0
  206. package/dist/components/ui/select/select-label.svelte +20 -0
  207. package/dist/components/ui/select/select-label.svelte.d.ts +6 -0
  208. package/dist/components/ui/select/select-scroll-down-button.svelte +20 -0
  209. package/dist/components/ui/select/select-scroll-down-button.svelte.d.ts +4 -0
  210. package/dist/components/ui/select/select-scroll-up-button.svelte +20 -0
  211. package/dist/components/ui/select/select-scroll-up-button.svelte.d.ts +4 -0
  212. package/dist/components/ui/select/select-separator.svelte +18 -0
  213. package/dist/components/ui/select/select-separator.svelte.d.ts +4 -0
  214. package/dist/components/ui/select/select-trigger.svelte +29 -0
  215. package/dist/components/ui/select/select-trigger.svelte.d.ts +8 -0
  216. package/dist/components/ui/separator/index.d.ts +2 -0
  217. package/dist/components/ui/separator/index.js +4 -0
  218. package/dist/components/ui/separator/separator.svelte +20 -0
  219. package/dist/components/ui/separator/separator.svelte.d.ts +4 -0
  220. package/dist/components/ui/sheet/index.d.ts +11 -0
  221. package/dist/components/ui/sheet/index.js +14 -0
  222. package/dist/components/ui/sheet/sheet-close.svelte +7 -0
  223. package/dist/components/ui/sheet/sheet-close.svelte.d.ts +4 -0
  224. package/dist/components/ui/sheet/sheet-content.svelte +58 -0
  225. package/dist/components/ui/sheet/sheet-content.svelte.d.ts +35 -0
  226. package/dist/components/ui/sheet/sheet-description.svelte +17 -0
  227. package/dist/components/ui/sheet/sheet-description.svelte.d.ts +4 -0
  228. package/dist/components/ui/sheet/sheet-footer.svelte +20 -0
  229. package/dist/components/ui/sheet/sheet-footer.svelte.d.ts +5 -0
  230. package/dist/components/ui/sheet/sheet-header.svelte +20 -0
  231. package/dist/components/ui/sheet/sheet-header.svelte.d.ts +5 -0
  232. package/dist/components/ui/sheet/sheet-overlay.svelte +20 -0
  233. package/dist/components/ui/sheet/sheet-overlay.svelte.d.ts +4 -0
  234. package/dist/components/ui/sheet/sheet-title.svelte +17 -0
  235. package/dist/components/ui/sheet/sheet-title.svelte.d.ts +4 -0
  236. package/dist/components/ui/sheet/sheet-trigger.svelte +7 -0
  237. package/dist/components/ui/sheet/sheet-trigger.svelte.d.ts +4 -0
  238. package/dist/components/ui/sidebar/constants.d.ts +6 -0
  239. package/dist/components/ui/sidebar/constants.js +6 -0
  240. package/dist/components/ui/sidebar/context.svelte.d.ts +42 -0
  241. package/dist/components/ui/sidebar/context.svelte.js +54 -0
  242. package/dist/components/ui/sidebar/index.d.ts +25 -0
  243. package/dist/components/ui/sidebar/index.js +27 -0
  244. package/dist/components/ui/sidebar/sidebar-content.svelte +24 -0
  245. package/dist/components/ui/sidebar/sidebar-content.svelte.d.ts +5 -0
  246. package/dist/components/ui/sidebar/sidebar-footer.svelte +21 -0
  247. package/dist/components/ui/sidebar/sidebar-footer.svelte.d.ts +5 -0
  248. package/dist/components/ui/sidebar/sidebar-group-action.svelte +36 -0
  249. package/dist/components/ui/sidebar/sidebar-group-action.svelte.d.ts +11 -0
  250. package/dist/components/ui/sidebar/sidebar-group-content.svelte +21 -0
  251. package/dist/components/ui/sidebar/sidebar-group-content.svelte.d.ts +5 -0
  252. package/dist/components/ui/sidebar/sidebar-group-label.svelte +34 -0
  253. package/dist/components/ui/sidebar/sidebar-group-label.svelte.d.ts +11 -0
  254. package/dist/components/ui/sidebar/sidebar-group.svelte +21 -0
  255. package/dist/components/ui/sidebar/sidebar-group.svelte.d.ts +5 -0
  256. package/dist/components/ui/sidebar/sidebar-header.svelte +21 -0
  257. package/dist/components/ui/sidebar/sidebar-header.svelte.d.ts +5 -0
  258. package/dist/components/ui/sidebar/sidebar-input.svelte +21 -0
  259. package/dist/components/ui/sidebar/sidebar-input.svelte.d.ts +11 -0
  260. package/dist/components/ui/sidebar/sidebar-inset.svelte +24 -0
  261. package/dist/components/ui/sidebar/sidebar-inset.svelte.d.ts +5 -0
  262. package/dist/components/ui/sidebar/sidebar-menu-action.svelte +43 -0
  263. package/dist/components/ui/sidebar/sidebar-menu-action.svelte.d.ts +12 -0
  264. package/dist/components/ui/sidebar/sidebar-menu-badge.svelte +29 -0
  265. package/dist/components/ui/sidebar/sidebar-menu-badge.svelte.d.ts +5 -0
  266. package/dist/components/ui/sidebar/sidebar-menu-button.svelte +103 -0
  267. package/dist/components/ui/sidebar/sidebar-menu-button.svelte.d.ts +51 -0
  268. package/dist/components/ui/sidebar/sidebar-menu-item.svelte +21 -0
  269. package/dist/components/ui/sidebar/sidebar-menu-item.svelte.d.ts +5 -0
  270. package/dist/components/ui/sidebar/sidebar-menu-skeleton.svelte +36 -0
  271. package/dist/components/ui/sidebar/sidebar-menu-skeleton.svelte.d.ts +8 -0
  272. package/dist/components/ui/sidebar/sidebar-menu-sub-button.svelte +43 -0
  273. package/dist/components/ui/sidebar/sidebar-menu-sub-button.svelte.d.ts +13 -0
  274. package/dist/components/ui/sidebar/sidebar-menu-sub-item.svelte +21 -0
  275. package/dist/components/ui/sidebar/sidebar-menu-sub-item.svelte.d.ts +5 -0
  276. package/dist/components/ui/sidebar/sidebar-menu-sub.svelte +25 -0
  277. package/dist/components/ui/sidebar/sidebar-menu-sub.svelte.d.ts +5 -0
  278. package/dist/components/ui/sidebar/sidebar-menu.svelte +21 -0
  279. package/dist/components/ui/sidebar/sidebar-menu.svelte.d.ts +5 -0
  280. package/dist/components/ui/sidebar/sidebar-provider.svelte +53 -0
  281. package/dist/components/ui/sidebar/sidebar-provider.svelte.d.ts +9 -0
  282. package/dist/components/ui/sidebar/sidebar-rail.svelte +36 -0
  283. package/dist/components/ui/sidebar/sidebar-rail.svelte.d.ts +5 -0
  284. package/dist/components/ui/sidebar/sidebar-separator.svelte +19 -0
  285. package/dist/components/ui/sidebar/sidebar-separator.svelte.d.ts +13 -0
  286. package/dist/components/ui/sidebar/sidebar-trigger.svelte +35 -0
  287. package/dist/components/ui/sidebar/sidebar-trigger.svelte.d.ts +8 -0
  288. package/dist/components/ui/sidebar/sidebar.svelte +104 -0
  289. package/dist/components/ui/sidebar/sidebar.svelte.d.ts +10 -0
  290. package/dist/components/ui/skeleton/index.d.ts +2 -0
  291. package/dist/components/ui/skeleton/index.js +4 -0
  292. package/dist/components/ui/skeleton/skeleton.svelte +17 -0
  293. package/dist/components/ui/skeleton/skeleton.svelte.d.ts +5 -0
  294. package/dist/components/ui/table/index.d.ts +9 -0
  295. package/dist/components/ui/table/index.js +11 -0
  296. package/dist/components/ui/table/table-body.svelte +20 -0
  297. package/dist/components/ui/table/table-body.svelte.d.ts +5 -0
  298. package/dist/components/ui/table/table-caption.svelte +20 -0
  299. package/dist/components/ui/table/table-caption.svelte.d.ts +5 -0
  300. package/dist/components/ui/table/table-cell.svelte +20 -0
  301. package/dist/components/ui/table/table-cell.svelte.d.ts +5 -0
  302. package/dist/components/ui/table/table-footer.svelte +20 -0
  303. package/dist/components/ui/table/table-footer.svelte.d.ts +5 -0
  304. package/dist/components/ui/table/table-head.svelte +23 -0
  305. package/dist/components/ui/table/table-head.svelte.d.ts +5 -0
  306. package/dist/components/ui/table/table-header.svelte +20 -0
  307. package/dist/components/ui/table/table-header.svelte.d.ts +5 -0
  308. package/dist/components/ui/table/table-row.svelte +23 -0
  309. package/dist/components/ui/table/table-row.svelte.d.ts +5 -0
  310. package/dist/components/ui/table/table.svelte +22 -0
  311. package/dist/components/ui/table/table.svelte.d.ts +5 -0
  312. package/dist/components/ui/tabs/index.d.ts +5 -0
  313. package/dist/components/ui/tabs/index.js +7 -0
  314. package/dist/components/ui/tabs/tabs-content.svelte +17 -0
  315. package/dist/components/ui/tabs/tabs-content.svelte.d.ts +4 -0
  316. package/dist/components/ui/tabs/tabs-list.svelte +20 -0
  317. package/dist/components/ui/tabs/tabs-list.svelte.d.ts +4 -0
  318. package/dist/components/ui/tabs/tabs-trigger.svelte +20 -0
  319. package/dist/components/ui/tabs/tabs-trigger.svelte.d.ts +4 -0
  320. package/dist/components/ui/tabs/tabs.svelte +19 -0
  321. package/dist/components/ui/tabs/tabs.svelte.d.ts +4 -0
  322. package/dist/components/ui/toggle/index.d.ts +3 -0
  323. package/dist/components/ui/toggle/index.js +5 -0
  324. package/dist/components/ui/toggle/toggle.svelte +52 -0
  325. package/dist/components/ui/toggle/toggle.svelte.d.ts +43 -0
  326. package/dist/components/ui/toggle-group/index.d.ts +3 -0
  327. package/dist/components/ui/toggle-group/index.js +5 -0
  328. package/dist/components/ui/toggle-group/toggle-group-item.svelte +34 -0
  329. package/dist/components/ui/toggle-group/toggle-group-item.svelte.d.ts +6 -0
  330. package/dist/components/ui/toggle-group/toggle-group.svelte +47 -0
  331. package/dist/components/ui/toggle-group/toggle-group.svelte.d.ts +8 -0
  332. package/dist/components/ui/tooltip/index.d.ts +7 -0
  333. package/dist/components/ui/tooltip/index.js +9 -0
  334. package/dist/components/ui/tooltip/tooltip-content.svelte +47 -0
  335. package/dist/components/ui/tooltip/tooltip-content.svelte.d.ts +7 -0
  336. package/dist/components/ui/tooltip/tooltip-trigger.svelte +7 -0
  337. package/dist/components/ui/tooltip/tooltip-trigger.svelte.d.ts +4 -0
  338. package/dist/hooks/is-mobile.svelte.d.ts +4 -0
  339. package/dist/hooks/is-mobile.svelte.js +7 -0
  340. package/dist/index.d.ts +12 -12
  341. package/dist/index.js +12 -12
  342. package/dist/services/auth.js +10 -0
  343. package/dist/types/docs.d.ts +67 -0
  344. package/dist/types/docs.js +1 -0
  345. package/dist/utils.d.ts +15 -0
  346. package/dist/utils.js +44 -0
  347. package/package.json +34 -6
  348. /package/dist/components/{Collection.svelte.d.ts → firekit/Collection.svelte.d.ts} +0 -0
  349. /package/dist/components/{Node.svelte.d.ts → firekit/Node.svelte.d.ts} +0 -0
  350. /package/dist/components/{download-url.svelte.d.ts → firekit/download-url.svelte.d.ts} +0 -0
  351. /package/dist/components/{firebase-app.svelte.d.ts → firekit/firebase-app.svelte.d.ts} +0 -0
  352. /package/dist/components/{node-list.svelte.d.ts → firekit/node-list.svelte.d.ts} +0 -0
  353. /package/dist/components/{signed-out.svelte.d.ts → firekit/signed-out.svelte.d.ts} +0 -0
  354. /package/dist/components/{storage-list.svelte.d.ts → firekit/storage-list.svelte.d.ts} +0 -0
  355. /package/dist/components/{upload-task.svelte.d.ts → firekit/upload-task.svelte.d.ts} +0 -0
@@ -0,0 +1,24 @@
1
+ <script lang="ts">
2
+ import { cn, type WithElementRef } from "../../../utils.js";
3
+ import type { HTMLAttributes } from "svelte/elements";
4
+
5
+ let {
6
+ ref = $bindable(null),
7
+ class: className,
8
+ children,
9
+ ...restProps
10
+ }: WithElementRef<HTMLAttributes<HTMLElement>> = $props();
11
+ </script>
12
+
13
+ <main
14
+ bind:this={ref}
15
+ data-slot="sidebar-inset"
16
+ class={cn(
17
+ "bg-background relative flex w-full flex-1 flex-col",
18
+ "md:peer-data-[variant=inset]:m-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:peer-data-[state=collapsed]:ml-2 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow-sm",
19
+ className
20
+ )}
21
+ {...restProps}
22
+ >
23
+ {@render children?.()}
24
+ </main>
@@ -0,0 +1,5 @@
1
+ import { type WithElementRef } from "../../../utils.js";
2
+ import type { HTMLAttributes } from "svelte/elements";
3
+ declare const SidebarInset: import("svelte").Component<WithElementRef<HTMLAttributes<HTMLElement>>, {}, "ref">;
4
+ type SidebarInset = ReturnType<typeof SidebarInset>;
5
+ export default SidebarInset;
@@ -0,0 +1,43 @@
1
+ <script lang="ts">
2
+ import { cn, type WithElementRef } from "../../../utils.js";
3
+ import type { Snippet } from "svelte";
4
+ import type { HTMLButtonAttributes } from "svelte/elements";
5
+
6
+ let {
7
+ ref = $bindable(null),
8
+ class: className,
9
+ showOnHover = false,
10
+ children,
11
+ child,
12
+ ...restProps
13
+ }: WithElementRef<HTMLButtonAttributes> & {
14
+ child?: Snippet<[{ props: Record<string, unknown> }]>;
15
+ showOnHover?: boolean;
16
+ } = $props();
17
+
18
+ const mergedProps = $derived({
19
+ class: cn(
20
+ "text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground peer-hover/menu-button:text-sidebar-accent-foreground outline-hidden absolute right-1 top-1.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 transition-transform focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0",
21
+ // Increases the hit area of the button on mobile.
22
+ "after:absolute after:-inset-2 md:after:hidden",
23
+ "peer-data-[size=sm]/menu-button:top-1",
24
+ "peer-data-[size=default]/menu-button:top-1.5",
25
+ "peer-data-[size=lg]/menu-button:top-2.5",
26
+ "group-data-[collapsible=icon]:hidden",
27
+ showOnHover &&
28
+ "peer-data-[active=true]/menu-button:text-sidebar-accent-foreground group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 data-[state=open]:opacity-100 md:opacity-0",
29
+ className
30
+ ),
31
+ "data-slot": "sidebar-menu-action",
32
+ "data-sidebar": "menu-action",
33
+ ...restProps,
34
+ });
35
+ </script>
36
+
37
+ {#if child}
38
+ {@render child({ props: mergedProps })}
39
+ {:else}
40
+ <button bind:this={ref} {...mergedProps}>
41
+ {@render children?.()}
42
+ </button>
43
+ {/if}
@@ -0,0 +1,12 @@
1
+ import { type WithElementRef } from "../../../utils.js";
2
+ import type { Snippet } from "svelte";
3
+ import type { HTMLButtonAttributes } from "svelte/elements";
4
+ type $$ComponentProps = WithElementRef<HTMLButtonAttributes> & {
5
+ child?: Snippet<[{
6
+ props: Record<string, unknown>;
7
+ }]>;
8
+ showOnHover?: boolean;
9
+ };
10
+ declare const SidebarMenuAction: import("svelte").Component<$$ComponentProps, {}, "ref">;
11
+ type SidebarMenuAction = ReturnType<typeof SidebarMenuAction>;
12
+ export default SidebarMenuAction;
@@ -0,0 +1,29 @@
1
+ <script lang="ts">
2
+ import { cn, type WithElementRef } from "../../../utils.js";
3
+ import type { HTMLAttributes } from "svelte/elements";
4
+
5
+ let {
6
+ ref = $bindable(null),
7
+ class: className,
8
+ children,
9
+ ...restProps
10
+ }: WithElementRef<HTMLAttributes<HTMLElement>> = $props();
11
+ </script>
12
+
13
+ <div
14
+ bind:this={ref}
15
+ data-slot="sidebar-menu-badge"
16
+ data-sidebar="menu-badge"
17
+ class={cn(
18
+ "text-sidebar-foreground pointer-events-none absolute right-1 flex h-5 min-w-5 select-none items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums",
19
+ "peer-hover/menu-button:text-sidebar-accent-foreground peer-data-[active=true]/menu-button:text-sidebar-accent-foreground",
20
+ "peer-data-[size=sm]/menu-button:top-1",
21
+ "peer-data-[size=default]/menu-button:top-1.5",
22
+ "peer-data-[size=lg]/menu-button:top-2.5",
23
+ "group-data-[collapsible=icon]:hidden",
24
+ className
25
+ )}
26
+ {...restProps}
27
+ >
28
+ {@render children?.()}
29
+ </div>
@@ -0,0 +1,5 @@
1
+ import { type WithElementRef } from "../../../utils.js";
2
+ import type { HTMLAttributes } from "svelte/elements";
3
+ declare const SidebarMenuBadge: import("svelte").Component<WithElementRef<HTMLAttributes<HTMLElement>>, {}, "ref">;
4
+ type SidebarMenuBadge = ReturnType<typeof SidebarMenuBadge>;
5
+ export default SidebarMenuBadge;
@@ -0,0 +1,103 @@
1
+ <script lang="ts" module>
2
+ import { tv, type VariantProps } from "tailwind-variants";
3
+
4
+ export const sidebarMenuButtonVariants = tv({
5
+ base: "peer/menu-button outline-hidden ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground active:bg-sidebar-accent active:text-sidebar-accent-foreground group-has-data-[sidebar=menu-action]/menu-item:pr-8 data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:size-8! group-data-[collapsible=icon]:p-2! flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm transition-[width,height,padding] focus-visible:ring-2 disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:font-medium [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0",
6
+ variants: {
7
+ variant: {
8
+ default: "hover:bg-sidebar-accent hover:text-sidebar-accent-foreground",
9
+ outline:
10
+ "bg-background hover:bg-sidebar-accent hover:text-sidebar-accent-foreground shadow-[0_0_0_1px_var(--sidebar-border)] hover:shadow-[0_0_0_1px_var(--sidebar-accent)]",
11
+ },
12
+ size: {
13
+ default: "h-8 text-sm",
14
+ sm: "h-7 text-xs",
15
+ lg: "group-data-[collapsible=icon]:p-0! h-12 text-sm",
16
+ },
17
+ },
18
+ defaultVariants: {
19
+ variant: "default",
20
+ size: "default",
21
+ },
22
+ });
23
+
24
+ export type SidebarMenuButtonVariant = VariantProps<
25
+ typeof sidebarMenuButtonVariants
26
+ >["variant"];
27
+ export type SidebarMenuButtonSize = VariantProps<typeof sidebarMenuButtonVariants>["size"];
28
+ </script>
29
+
30
+ <script lang="ts">
31
+ import * as Tooltip from "../tooltip/index.js";
32
+ import { cn, type WithElementRef, type WithoutChildrenOrChild } from "../../../utils.js";
33
+ import { mergeProps } from "bits-ui";
34
+ import type { ComponentProps, Snippet } from "svelte";
35
+ import type { HTMLAttributes } from "svelte/elements";
36
+ import { useSidebar } from "./context.svelte.js";
37
+
38
+ let {
39
+ ref = $bindable(null),
40
+ class: className,
41
+ children,
42
+ child,
43
+ variant = "default",
44
+ size = "default",
45
+ isActive = false,
46
+ tooltipContent,
47
+ tooltipContentProps,
48
+ ...restProps
49
+ }: WithElementRef<HTMLAttributes<HTMLButtonElement>, HTMLButtonElement> & {
50
+ isActive?: boolean;
51
+ variant?: SidebarMenuButtonVariant;
52
+ size?: SidebarMenuButtonSize;
53
+ tooltipContent?: Snippet | string;
54
+ tooltipContentProps?: WithoutChildrenOrChild<ComponentProps<typeof Tooltip.Content>>;
55
+ child?: Snippet<[{ props: Record<string, unknown> }]>;
56
+ } = $props();
57
+
58
+ const sidebar = useSidebar();
59
+
60
+ const buttonProps = $derived({
61
+ class: cn(sidebarMenuButtonVariants({ variant, size }), className),
62
+ "data-slot": "sidebar-menu-button",
63
+ "data-sidebar": "menu-button",
64
+ "data-size": size,
65
+ "data-active": isActive,
66
+ ...restProps,
67
+ });
68
+ </script>
69
+
70
+ {#snippet Button({ props }: { props?: Record<string, unknown> })}
71
+ {@const mergedProps = mergeProps(buttonProps, props)}
72
+ {#if child}
73
+ {@render child({ props: mergedProps })}
74
+ {:else}
75
+ <button bind:this={ref} {...mergedProps}>
76
+ {@render children?.()}
77
+ </button>
78
+ {/if}
79
+ {/snippet}
80
+
81
+ {#if !tooltipContent}
82
+ {@render Button({})}
83
+ {:else}
84
+ <Tooltip.Root>
85
+ <Tooltip.Trigger>
86
+ {#snippet child({ props })}
87
+ {@render Button({ props })}
88
+ {/snippet}
89
+ </Tooltip.Trigger>
90
+ <Tooltip.Content
91
+ side="right"
92
+ align="center"
93
+ hidden={sidebar.state !== "collapsed" || sidebar.isMobile}
94
+ {...tooltipContentProps}
95
+ >
96
+ {#if typeof tooltipContent === "string"}
97
+ {tooltipContent}
98
+ {:else if tooltipContent}
99
+ {@render tooltipContent()}
100
+ {/if}
101
+ </Tooltip.Content>
102
+ </Tooltip.Root>
103
+ {/if}
@@ -0,0 +1,51 @@
1
+ import { type VariantProps } from "tailwind-variants";
2
+ export declare const sidebarMenuButtonVariants: import("tailwind-variants").TVReturnType<{
3
+ variant: {
4
+ default: string;
5
+ outline: string;
6
+ };
7
+ size: {
8
+ default: string;
9
+ sm: string;
10
+ lg: string;
11
+ };
12
+ }, undefined, "peer/menu-button outline-hidden ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground active:bg-sidebar-accent active:text-sidebar-accent-foreground group-has-data-[sidebar=menu-action]/menu-item:pr-8 data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:size-8! group-data-[collapsible=icon]:p-2! flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm transition-[width,height,padding] focus-visible:ring-2 disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:font-medium [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0", {
13
+ variant: {
14
+ default: string;
15
+ outline: string;
16
+ };
17
+ size: {
18
+ default: string;
19
+ sm: string;
20
+ lg: string;
21
+ };
22
+ }, undefined, import("tailwind-variants").TVReturnType<{
23
+ variant: {
24
+ default: string;
25
+ outline: string;
26
+ };
27
+ size: {
28
+ default: string;
29
+ sm: string;
30
+ lg: string;
31
+ };
32
+ }, undefined, "peer/menu-button outline-hidden ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground active:bg-sidebar-accent active:text-sidebar-accent-foreground group-has-data-[sidebar=menu-action]/menu-item:pr-8 data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:size-8! group-data-[collapsible=icon]:p-2! flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm transition-[width,height,padding] focus-visible:ring-2 disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:font-medium [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0", unknown, unknown, undefined>>;
33
+ export type SidebarMenuButtonVariant = VariantProps<typeof sidebarMenuButtonVariants>["variant"];
34
+ export type SidebarMenuButtonSize = VariantProps<typeof sidebarMenuButtonVariants>["size"];
35
+ import * as Tooltip from "../tooltip/index.js";
36
+ import { type WithElementRef, type WithoutChildrenOrChild } from "../../../utils.js";
37
+ import type { ComponentProps, Snippet } from "svelte";
38
+ import type { HTMLAttributes } from "svelte/elements";
39
+ type $$ComponentProps = WithElementRef<HTMLAttributes<HTMLButtonElement>, HTMLButtonElement> & {
40
+ isActive?: boolean;
41
+ variant?: SidebarMenuButtonVariant;
42
+ size?: SidebarMenuButtonSize;
43
+ tooltipContent?: Snippet | string;
44
+ tooltipContentProps?: WithoutChildrenOrChild<ComponentProps<typeof Tooltip.Content>>;
45
+ child?: Snippet<[{
46
+ props: Record<string, unknown>;
47
+ }]>;
48
+ };
49
+ declare const SidebarMenuButton: import("svelte").Component<$$ComponentProps, {}, "ref">;
50
+ type SidebarMenuButton = ReturnType<typeof SidebarMenuButton>;
51
+ export default SidebarMenuButton;
@@ -0,0 +1,21 @@
1
+ <script lang="ts">
2
+ import { cn, type WithElementRef } from "../../../utils.js";
3
+ import type { HTMLAttributes } from "svelte/elements";
4
+
5
+ let {
6
+ ref = $bindable(null),
7
+ class: className,
8
+ children,
9
+ ...restProps
10
+ }: WithElementRef<HTMLAttributes<HTMLLIElement>, HTMLLIElement> = $props();
11
+ </script>
12
+
13
+ <li
14
+ bind:this={ref}
15
+ data-slot="sidebar-menu-item"
16
+ data-sidebar="menu-item"
17
+ class={cn("group/menu-item relative", className)}
18
+ {...restProps}
19
+ >
20
+ {@render children?.()}
21
+ </li>
@@ -0,0 +1,5 @@
1
+ import { type WithElementRef } from "../../../utils.js";
2
+ import type { HTMLAttributes } from "svelte/elements";
3
+ declare const SidebarMenuItem: import("svelte").Component<WithElementRef<HTMLAttributes<HTMLLIElement>, HTMLLIElement>, {}, "ref">;
4
+ type SidebarMenuItem = ReturnType<typeof SidebarMenuItem>;
5
+ export default SidebarMenuItem;
@@ -0,0 +1,36 @@
1
+ <script lang="ts">
2
+ import { cn, type WithElementRef } from "../../../utils.js";
3
+ import { Skeleton } from "../skeleton/index.js";
4
+ import type { HTMLAttributes } from "svelte/elements";
5
+
6
+ let {
7
+ ref = $bindable(null),
8
+ class: className,
9
+ showIcon = false,
10
+ children,
11
+ ...restProps
12
+ }: WithElementRef<HTMLAttributes<HTMLElement>> & {
13
+ showIcon?: boolean;
14
+ } = $props();
15
+
16
+ // Random width between 50% and 90%
17
+ const width = `${Math.floor(Math.random() * 40) + 50}%`;
18
+ </script>
19
+
20
+ <div
21
+ bind:this={ref}
22
+ data-slot="sidebar-menu-skeleton"
23
+ data-sidebar="menu-skeleton"
24
+ class={cn("flex h-8 items-center gap-2 rounded-md px-2", className)}
25
+ {...restProps}
26
+ >
27
+ {#if showIcon}
28
+ <Skeleton class="size-4 rounded-md" data-sidebar="menu-skeleton-icon" />
29
+ {/if}
30
+ <Skeleton
31
+ class="max-w-(--skeleton-width) h-4 flex-1"
32
+ data-sidebar="menu-skeleton-text"
33
+ style="--skeleton-width: {width};"
34
+ />
35
+ {@render children?.()}
36
+ </div>
@@ -0,0 +1,8 @@
1
+ import { type WithElementRef } from "../../../utils.js";
2
+ import type { HTMLAttributes } from "svelte/elements";
3
+ type $$ComponentProps = WithElementRef<HTMLAttributes<HTMLElement>> & {
4
+ showIcon?: boolean;
5
+ };
6
+ declare const SidebarMenuSkeleton: import("svelte").Component<$$ComponentProps, {}, "ref">;
7
+ type SidebarMenuSkeleton = ReturnType<typeof SidebarMenuSkeleton>;
8
+ export default SidebarMenuSkeleton;
@@ -0,0 +1,43 @@
1
+ <script lang="ts">
2
+ import { cn, type WithElementRef } from "../../../utils.js";
3
+ import type { Snippet } from "svelte";
4
+ import type { HTMLAnchorAttributes } from "svelte/elements";
5
+
6
+ let {
7
+ ref = $bindable(null),
8
+ children,
9
+ child,
10
+ class: className,
11
+ size = "md",
12
+ isActive = false,
13
+ ...restProps
14
+ }: WithElementRef<HTMLAnchorAttributes> & {
15
+ child?: Snippet<[{ props: Record<string, unknown> }]>;
16
+ size?: "sm" | "md";
17
+ isActive?: boolean;
18
+ } = $props();
19
+
20
+ const mergedProps = $derived({
21
+ class: cn(
22
+ "text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground active:bg-sidebar-accent active:text-sidebar-accent-foreground [&>svg]:text-sidebar-accent-foreground outline-hidden flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 focus-visible:ring-2 disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0",
23
+ "data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground",
24
+ size === "sm" && "text-xs",
25
+ size === "md" && "text-sm",
26
+ "group-data-[collapsible=icon]:hidden",
27
+ className
28
+ ),
29
+ "data-slot": "sidebar-menu-sub-button",
30
+ "data-sidebar": "menu-sub-button",
31
+ "data-size": size,
32
+ "data-active": isActive,
33
+ ...restProps,
34
+ });
35
+ </script>
36
+
37
+ {#if child}
38
+ {@render child({ props: mergedProps })}
39
+ {:else}
40
+ <a bind:this={ref} {...mergedProps}>
41
+ {@render children?.()}
42
+ </a>
43
+ {/if}
@@ -0,0 +1,13 @@
1
+ import { type WithElementRef } from "../../../utils.js";
2
+ import type { Snippet } from "svelte";
3
+ import type { HTMLAnchorAttributes } from "svelte/elements";
4
+ type $$ComponentProps = WithElementRef<HTMLAnchorAttributes> & {
5
+ child?: Snippet<[{
6
+ props: Record<string, unknown>;
7
+ }]>;
8
+ size?: "sm" | "md";
9
+ isActive?: boolean;
10
+ };
11
+ declare const SidebarMenuSubButton: import("svelte").Component<$$ComponentProps, {}, "ref">;
12
+ type SidebarMenuSubButton = ReturnType<typeof SidebarMenuSubButton>;
13
+ export default SidebarMenuSubButton;
@@ -0,0 +1,21 @@
1
+ <script lang="ts">
2
+ import { cn, type WithElementRef } from "../../../utils.js";
3
+ import type { HTMLAttributes } from "svelte/elements";
4
+
5
+ let {
6
+ ref = $bindable(null),
7
+ children,
8
+ class: className,
9
+ ...restProps
10
+ }: WithElementRef<HTMLAttributes<HTMLLIElement>> = $props();
11
+ </script>
12
+
13
+ <li
14
+ bind:this={ref}
15
+ data-slot="sidebar-menu-sub-item"
16
+ data-sidebar="menu-sub-item"
17
+ class={cn("group/menu-sub-item relative", className)}
18
+ {...restProps}
19
+ >
20
+ {@render children?.()}
21
+ </li>
@@ -0,0 +1,5 @@
1
+ import { type WithElementRef } from "../../../utils.js";
2
+ import type { HTMLAttributes } from "svelte/elements";
3
+ declare const SidebarMenuSubItem: import("svelte").Component<WithElementRef<HTMLAttributes<HTMLLIElement>>, {}, "ref">;
4
+ type SidebarMenuSubItem = ReturnType<typeof SidebarMenuSubItem>;
5
+ export default SidebarMenuSubItem;
@@ -0,0 +1,25 @@
1
+ <script lang="ts">
2
+ import { cn, type WithElementRef } from "../../../utils.js";
3
+ import type { HTMLAttributes } from "svelte/elements";
4
+
5
+ let {
6
+ ref = $bindable(null),
7
+ class: className,
8
+ children,
9
+ ...restProps
10
+ }: WithElementRef<HTMLAttributes<HTMLUListElement>> = $props();
11
+ </script>
12
+
13
+ <ul
14
+ bind:this={ref}
15
+ data-slot="sidebar-menu-sub"
16
+ data-sidebar="menu-sub"
17
+ class={cn(
18
+ "border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l px-2.5 py-0.5",
19
+ "group-data-[collapsible=icon]:hidden",
20
+ className
21
+ )}
22
+ {...restProps}
23
+ >
24
+ {@render children?.()}
25
+ </ul>
@@ -0,0 +1,5 @@
1
+ import { type WithElementRef } from "../../../utils.js";
2
+ import type { HTMLAttributes } from "svelte/elements";
3
+ declare const SidebarMenuSub: import("svelte").Component<WithElementRef<HTMLAttributes<HTMLUListElement>>, {}, "ref">;
4
+ type SidebarMenuSub = ReturnType<typeof SidebarMenuSub>;
5
+ export default SidebarMenuSub;
@@ -0,0 +1,21 @@
1
+ <script lang="ts">
2
+ import { cn, type WithElementRef } from "../../../utils.js";
3
+ import type { HTMLAttributes } from "svelte/elements";
4
+
5
+ let {
6
+ ref = $bindable(null),
7
+ class: className,
8
+ children,
9
+ ...restProps
10
+ }: WithElementRef<HTMLAttributes<HTMLUListElement>, HTMLUListElement> = $props();
11
+ </script>
12
+
13
+ <ul
14
+ bind:this={ref}
15
+ data-slot="sidebar-menu"
16
+ data-sidebar="menu"
17
+ class={cn("flex w-full min-w-0 flex-col gap-1", className)}
18
+ {...restProps}
19
+ >
20
+ {@render children?.()}
21
+ </ul>
@@ -0,0 +1,5 @@
1
+ import { type WithElementRef } from "../../../utils.js";
2
+ import type { HTMLAttributes } from "svelte/elements";
3
+ declare const SidebarMenu: import("svelte").Component<WithElementRef<HTMLAttributes<HTMLUListElement>, HTMLUListElement>, {}, "ref">;
4
+ type SidebarMenu = ReturnType<typeof SidebarMenu>;
5
+ export default SidebarMenu;
@@ -0,0 +1,53 @@
1
+ <script lang="ts">
2
+ import * as Tooltip from "../tooltip/index.js";
3
+ import { cn, type WithElementRef } from "../../../utils.js";
4
+ import type { HTMLAttributes } from "svelte/elements";
5
+ import {
6
+ SIDEBAR_COOKIE_MAX_AGE,
7
+ SIDEBAR_COOKIE_NAME,
8
+ SIDEBAR_WIDTH,
9
+ SIDEBAR_WIDTH_ICON,
10
+ } from "./constants.js";
11
+ import { setSidebar } from "./context.svelte.js";
12
+
13
+ let {
14
+ ref = $bindable(null),
15
+ open = $bindable(true),
16
+ onOpenChange = () => {},
17
+ class: className,
18
+ style,
19
+ children,
20
+ ...restProps
21
+ }: WithElementRef<HTMLAttributes<HTMLDivElement>> & {
22
+ open?: boolean;
23
+ onOpenChange?: (open: boolean) => void;
24
+ } = $props();
25
+
26
+ const sidebar = setSidebar({
27
+ open: () => open,
28
+ setOpen: (value: boolean) => {
29
+ open = value;
30
+ onOpenChange(value);
31
+
32
+ // This sets the cookie to keep the sidebar state.
33
+ document.cookie = `${SIDEBAR_COOKIE_NAME}=${open}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`;
34
+ },
35
+ });
36
+ </script>
37
+
38
+ <svelte:window onkeydown={sidebar.handleShortcutKeydown} />
39
+
40
+ <Tooltip.Provider delayDuration={0}>
41
+ <div
42
+ data-slot="sidebar-wrapper"
43
+ style="--sidebar-width: {SIDEBAR_WIDTH}; --sidebar-width-icon: {SIDEBAR_WIDTH_ICON}; {style}"
44
+ class={cn(
45
+ "group/sidebar-wrapper has-data-[variant=inset]:bg-sidebar flex min-h-svh w-full",
46
+ className
47
+ )}
48
+ bind:this={ref}
49
+ {...restProps}
50
+ >
51
+ {@render children?.()}
52
+ </div>
53
+ </Tooltip.Provider>
@@ -0,0 +1,9 @@
1
+ import { type WithElementRef } from "../../../utils.js";
2
+ import type { HTMLAttributes } from "svelte/elements";
3
+ type $$ComponentProps = WithElementRef<HTMLAttributes<HTMLDivElement>> & {
4
+ open?: boolean;
5
+ onOpenChange?: (open: boolean) => void;
6
+ };
7
+ declare const SidebarProvider: import("svelte").Component<$$ComponentProps, {}, "ref" | "open">;
8
+ type SidebarProvider = ReturnType<typeof SidebarProvider>;
9
+ export default SidebarProvider;
@@ -0,0 +1,36 @@
1
+ <script lang="ts">
2
+ import { cn, type WithElementRef } from "../../../utils.js";
3
+ import type { HTMLAttributes } from "svelte/elements";
4
+ import { useSidebar } from "./context.svelte.js";
5
+
6
+ let {
7
+ ref = $bindable(null),
8
+ class: className,
9
+ children,
10
+ ...restProps
11
+ }: WithElementRef<HTMLAttributes<HTMLButtonElement>, HTMLButtonElement> = $props();
12
+
13
+ const sidebar = useSidebar();
14
+ </script>
15
+
16
+ <button
17
+ bind:this={ref}
18
+ data-sidebar="rail"
19
+ data-slot="sidebar-rail"
20
+ aria-label="Toggle Sidebar"
21
+ tabIndex={-1}
22
+ onclick={sidebar.toggle}
23
+ title="Toggle Sidebar"
24
+ class={cn(
25
+ "hover:after:bg-sidebar-border absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear after:absolute after:inset-y-0 after:left-[calc(1/2*100%-1px)] after:w-[2px] group-data-[side=left]:-right-4 group-data-[side=right]:left-0 sm:flex",
26
+ "in-data-[side=left]:cursor-w-resize in-data-[side=right]:cursor-e-resize",
27
+ "[[data-side=left][data-state=collapsed]_&]:cursor-e-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize",
28
+ "hover:group-data-[collapsible=offcanvas]:bg-sidebar group-data-[collapsible=offcanvas]:translate-x-0 group-data-[collapsible=offcanvas]:after:left-full",
29
+ "[[data-side=left][data-collapsible=offcanvas]_&]:-right-2",
30
+ "[[data-side=right][data-collapsible=offcanvas]_&]:-left-2",
31
+ className
32
+ )}
33
+ {...restProps}
34
+ >
35
+ {@render children?.()}
36
+ </button>
@@ -0,0 +1,5 @@
1
+ import { type WithElementRef } from "../../../utils.js";
2
+ import type { HTMLAttributes } from "svelte/elements";
3
+ declare const SidebarRail: import("svelte").Component<WithElementRef<HTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, {}, "ref">;
4
+ type SidebarRail = ReturnType<typeof SidebarRail>;
5
+ export default SidebarRail;
@@ -0,0 +1,19 @@
1
+ <script lang="ts">
2
+ import { Separator } from "../separator/index.js";
3
+ import { cn } from "../../../utils.js";
4
+ import type { ComponentProps } from "svelte";
5
+
6
+ let {
7
+ ref = $bindable(null),
8
+ class: className,
9
+ ...restProps
10
+ }: ComponentProps<typeof Separator> = $props();
11
+ </script>
12
+
13
+ <Separator
14
+ bind:ref
15
+ data-slot="sidebar-separator"
16
+ data-sidebar="separator"
17
+ class={cn("bg-sidebar-border", className)}
18
+ {...restProps}
19
+ />
@@ -0,0 +1,13 @@
1
+ declare const SidebarSeparator: import("svelte").Component<Omit<{
2
+ orientation?: import("bits-ui").Orientation;
3
+ decorative?: boolean;
4
+ }, "children" | "child"> & {
5
+ child?: import("svelte").Snippet<[{
6
+ props: Record<string, unknown>;
7
+ }]> | undefined;
8
+ children?: import("svelte").Snippet<[]> | undefined;
9
+ style?: import("bits-ui").StyleProperties | string | null | undefined;
10
+ ref?: HTMLElement | null | undefined;
11
+ } & import("bits-ui").Without<import("bits-ui").BitsPrimitiveDivAttributes, import("bits-ui").SeparatorRootPropsWithoutHTML>, {}, "ref">;
12
+ type SidebarSeparator = ReturnType<typeof SidebarSeparator>;
13
+ export default SidebarSeparator;