|
2 | 2 | import type { ComponentProps, Snippet } from 'svelte';
|
3 | 3 |
|
4 | 4 | import { page } from '$app/state';
|
| 5 | + import * as Collapsible from '$comp/ui/collapsible'; |
5 | 6 | import * as Sidebar from '$comp/ui/sidebar';
|
6 | 7 | import { useSidebar } from '$comp/ui/sidebar';
|
| 8 | + import ChevronRight from '@lucide/svelte/icons/chevron-right'; |
| 9 | + import Settings from '@lucide/svelte/icons/settings-2'; |
7 | 10 |
|
8 | 11 | import type { NavigationItem } from '../../../routes.svelte';
|
9 | 12 |
|
|
14 | 17 | };
|
15 | 18 |
|
16 | 19 | let { footer, header, routes, ...props }: Props = $props();
|
17 |
| - const dashboardRoutes = routes.filter((route) => route.group === 'Dashboards'); |
| 20 | + const dashboardRoutes = $derived(routes.filter((route) => route.group === 'Dashboards')); |
| 21 | + const settingsRoutes = $derived(routes.filter((route) => route.group === 'Settings')); |
| 22 | + const settingsIsActive = $derived(settingsRoutes.some((route) => route.href === page.url.pathname)); |
18 | 23 |
|
19 | 24 | const sidebar = useSidebar();
|
20 | 25 |
|
|
49 | 54 | {/each}
|
50 | 55 | </Sidebar.Menu>
|
51 | 56 | </Sidebar.Group>
|
| 57 | + |
| 58 | + <Sidebar.Group> |
| 59 | + <Sidebar.Menu> |
| 60 | + <Collapsible.Root open={settingsIsActive} class="group/collapsible"> |
| 61 | + {#snippet child({ props })} |
| 62 | + <Sidebar.MenuItem {...props}> |
| 63 | + <Collapsible.Trigger> |
| 64 | + {#snippet child({ props })} |
| 65 | + <Sidebar.MenuButton {...props}> |
| 66 | + <Settings /> |
| 67 | + <span>Settings</span> |
| 68 | + <ChevronRight class="ml-auto transition-transform duration-200 group-data-[state=open]/collapsible:rotate-90" /> |
| 69 | + </Sidebar.MenuButton> |
| 70 | + {/snippet} |
| 71 | + </Collapsible.Trigger> |
| 72 | + <Collapsible.Content> |
| 73 | + <Sidebar.MenuSub> |
| 74 | + {#each settingsRoutes as subItem (subItem.href)} |
| 75 | + <Sidebar.MenuSubItem> |
| 76 | + <Sidebar.MenuSubButton isActive={subItem.href === page.url.pathname}> |
| 77 | + {#snippet child({ props })} |
| 78 | + <a href={subItem.href} title={subItem.title} onclick={onMenuClick} {...props}> |
| 79 | + <span>{subItem.title}</span> |
| 80 | + </a> |
| 81 | + {/snippet} |
| 82 | + </Sidebar.MenuSubButton> |
| 83 | + </Sidebar.MenuSubItem> |
| 84 | + {/each} |
| 85 | + </Sidebar.MenuSub> |
| 86 | + </Collapsible.Content> |
| 87 | + </Sidebar.MenuItem> |
| 88 | + {/snippet} |
| 89 | + </Collapsible.Root> |
| 90 | + </Sidebar.Menu> |
| 91 | + </Sidebar.Group> |
52 | 92 | </Sidebar.Content>
|
53 | 93 | <Sidebar.Rail />
|
54 | 94 | <Sidebar.Footer>
|
|
0 commit comments