media-rip/frontend/src/components/AppHeader.vue
xpltd 0d9e6b18ac M002/S04: URL preview, playlist support, admin improvements, UX polish
URL preview & playlist support:
- POST /url-info endpoint extracts metadata (title, type, entry count)
- Preview box shows playlist contents before downloading (up to 10 items)
- Auto-detect audio-only sources (SoundCloud, etc) and switch to Audio mode
- Video toggle grayed out for audio-only sources
- Enable playlist downloading (noplaylist=False)

Admin panel improvements:
- Expandable session rows show per-session job list with filename, size,
  status, timestamp, and source URL link
- GET /admin/sessions/{id}/jobs endpoint for session job details
- Logout now redirects to home page instead of staying on login form
- Logo in header is clickable → navigates to home

UX polish:
- Tooltips on output format chips (explains Auto vs specific formats)
- Format tooltips change based on video/audio mode
2026-03-19 02:32:14 -05:00

66 lines
1.5 KiB
Vue

<script setup lang="ts">
import { useRouter } from 'vue-router'
import DarkModeToggle from '@/components/DarkModeToggle.vue'
const router = useRouter()
function goHome(): void {
router.push('/')
}
</script>
<template>
<header class="app-header">
<div class="header-content">
<h1 class="header-title" @click="goHome" role="link" tabindex="0" @keydown.enter="goHome" title="Back to downloads">
<span class="title-media">media</span><span class="title-dot">.</span><span class="title-rip">rip</span><span class="title-parens">()</span>
</h1>
<div class="header-right">
<DarkModeToggle />
</div>
</div>
</header>
</template>
<style scoped>
.app-header {
position: sticky;
top: 0;
z-index: 100;
height: var(--header-height);
background: var(--color-surface);
border-bottom: 1px solid var(--color-border);
display: flex;
align-items: center;
}
.header-content {
width: 100%;
max-width: var(--content-max-width);
margin: 0 auto;
padding: 0 var(--space-md);
display: flex;
justify-content: space-between;
align-items: center;
}
.header-title {
font-size: var(--font-size-xl);
font-weight: 700;
font-family: var(--font-display);
letter-spacing: -0.02em;
cursor: pointer;
user-select: none;
}
.title-media { color: var(--color-text); }
.title-dot { color: var(--color-accent); }
.title-rip { color: var(--color-accent); }
.title-parens { color: var(--color-text-muted); }
.header-right {
display: flex;
align-items: center;
gap: var(--space-md);
}
</style>