mirror of
https://github.com/immich-app/immich.git
synced 2025-12-09 21:13:45 +09:00
Some checks failed
CodeQL / Analyze (javascript) (push) Has been cancelled
CodeQL / Analyze (python) (push) Has been cancelled
Docker / pre-job (push) Has been cancelled
Docker / Re-Tag ML () (push) Has been cancelled
Docker / Re-Tag ML (-armnn) (push) Has been cancelled
Docker / Re-Tag ML (-cuda) (push) Has been cancelled
Docker / Re-Tag ML (-openvino) (push) Has been cancelled
Docker / Re-Tag ML (-rknn) (push) Has been cancelled
Docker / Re-Tag ML (-rocm) (push) Has been cancelled
Docker / Re-Tag Server () (push) Has been cancelled
Docker / Build and Push ML (armnn, linux/arm64, -armnn) (push) Has been cancelled
Docker / Build and Push ML (cpu, ) (push) Has been cancelled
Docker / Build and Push ML (cuda, linux/amd64, -cuda) (push) Has been cancelled
Docker / Build and Push ML (openvino, linux/amd64, -openvino) (push) Has been cancelled
Docker / Build and Push ML (rknn, linux/arm64, -rknn) (push) Has been cancelled
Docker / Build and Push ML (rocm, linux/amd64, {"linux/amd64": "mich"}, -rocm) (push) Has been cancelled
Docker / Build and Push Server (push) Has been cancelled
Docker / Docker Build & Push Server Success (push) Has been cancelled
Docker / Docker Build & Push ML Success (push) Has been cancelled
Docs build / pre-job (push) Has been cancelled
Docs build / Docs Build (push) Has been cancelled
Zizmor / Zizmor (push) Has been cancelled
Static Code Analysis / pre-job (push) Has been cancelled
Static Code Analysis / Run Dart Code Analysis (push) Has been cancelled
Test / pre-job (push) Has been cancelled
Test / Test & Lint Server (push) Has been cancelled
Test / Unit Test CLI (push) Has been cancelled
Test / Unit Test CLI (Windows) (push) Has been cancelled
Test / Lint Web (push) Has been cancelled
Test / Test Web (push) Has been cancelled
Test / Test i18n (push) Has been cancelled
Test / End-to-End Lint (push) Has been cancelled
Test / Medium Tests (Server) (push) Has been cancelled
Test / End-to-End Tests (Server & CLI) (ubuntu-24.04-arm) (push) Has been cancelled
Test / End-to-End Tests (Server & CLI) (ubuntu-latest) (push) Has been cancelled
Test / End-to-End Tests (Web) (ubuntu-24.04-arm) (push) Has been cancelled
Test / End-to-End Tests (Web) (ubuntu-latest) (push) Has been cancelled
Test / End-to-End Tests Success (push) Has been cancelled
Test / Unit Test Mobile (push) Has been cancelled
Test / Unit Test ML (push) Has been cancelled
Test / .github Files Formatting (push) Has been cancelled
Test / ShellCheck (push) Has been cancelled
Test / OpenAPI Clients (push) Has been cancelled
Test / SQL Schema Checks (push) Has been cancelled
75 lines
2.4 KiB
Svelte
75 lines
2.4 KiB
Svelte
<script lang="ts">
|
|
import { page } from '$app/state';
|
|
import { Icon } from '@immich/ui';
|
|
import { mdiChevronDown, mdiChevronLeft } from '@mdi/js';
|
|
import type { Snippet } from 'svelte';
|
|
import { t } from 'svelte-i18n';
|
|
|
|
interface Props {
|
|
title: string;
|
|
href: string;
|
|
icon: string;
|
|
flippedLogo?: boolean;
|
|
isSelected?: boolean;
|
|
preloadData?: boolean;
|
|
dropDownContent?: Snippet;
|
|
dropdownOpen?: boolean;
|
|
}
|
|
|
|
let {
|
|
title,
|
|
href,
|
|
icon,
|
|
flippedLogo = false,
|
|
isSelected = $bindable(false),
|
|
preloadData = true,
|
|
dropDownContent: hasDropdown,
|
|
dropdownOpen = $bindable(false),
|
|
}: Props = $props();
|
|
|
|
$effect(() => {
|
|
isSelected = page.url.pathname.startsWith(href);
|
|
});
|
|
</script>
|
|
|
|
<div class="relative">
|
|
{#if hasDropdown}
|
|
<span class="hidden md:block absolute start-1 h-full">
|
|
<button
|
|
type="button"
|
|
aria-label={$t('recent-albums')}
|
|
class="relative flex cursor-default pt-4 pb-4 select-none justify-center hover:cursor-pointer hover:bg-subtle hover:fill-gray hover:text-immich-primary dark:text-immich-dark-fg dark:hover:bg-immich-dark-gray dark:hover:text-immich-dark-primary rounded h-fill"
|
|
onclick={() => (dropdownOpen = !dropdownOpen)}
|
|
>
|
|
<Icon
|
|
icon={dropdownOpen ? mdiChevronDown : mdiChevronLeft}
|
|
size="1em"
|
|
class="shrink-0 delay-100 duration-100 "
|
|
flipped={flippedLogo}
|
|
aria-hidden
|
|
/>
|
|
</button>
|
|
</span>
|
|
{/if}
|
|
<a
|
|
{href}
|
|
data-sveltekit-preload-data={preloadData ? 'hover' : 'off'}
|
|
draggable="false"
|
|
aria-current={isSelected ? 'page' : undefined}
|
|
class="flex w-full place-items-center gap-4 rounded-e-full py-3 transition-[padding] delay-100 duration-100 hover:cursor-pointer hover:bg-subtle hover:text-immich-primary dark:text-immich-dark-fg dark:hover:bg-immich-dark-gray dark:hover:text-immich-dark-primary
|
|
{isSelected
|
|
? 'bg-immich-primary/10 dark:text-primary text-primary hover:bg-immich-primary/10 dark:bg-immich-dark-primary/10'
|
|
: ''}"
|
|
>
|
|
<div class="flex w-full place-items-center gap-4 ps-5 overflow-hidden truncate">
|
|
<Icon {icon} size="1.5em" class="shrink-0" flipped={flippedLogo} aria-hidden />
|
|
<span class="text-sm font-medium">{title}</span>
|
|
</div>
|
|
<div></div>
|
|
</a>
|
|
</div>
|
|
|
|
{#if hasDropdown && dropdownOpen}
|
|
{@render hasDropdown?.()}
|
|
{/if}
|