Files
lidify/frontend/components/player/VibeOverlayContainer.tsx
Your Name cc8d0f6969 Release v1.3.0: Multi-source downloads, audio analyzer resilience, mobile improvements
Major Features:
- Multi-source download system (Soulseek/Lidarr with fallback)
- Configurable enrichment speed control (1-5x)
- Mobile touch drag support for seek sliders
- iOS PWA media controls (Control Center, Lock Screen)
- Artist name alias resolution via Last.fm
- Circuit breaker pattern for audio analysis

Critical Fixes:
- Audio analyzer stability (non-ASCII, BrokenProcessPool, OOM)
- Discovery system race conditions and import failures
- Radio decade categorization using originalYear
- LastFM API response normalization
- Mood bucket infinite loop prevention

Security:
- Bull Board admin authentication
- Lidarr webhook signature verification
- JWT token expiration and refresh
- Encryption key validation on startup

Closes #2, #6, #9, #13, #21, #26, #31, #34, #35, #37, #40, #43
2026-01-06 20:07:33 -06:00

44 lines
1.5 KiB
TypeScript

"use client";
import { useAudioState } from "@/lib/audio-state-context";
import { useState, useEffect, lazy, Suspense } from "react";
// Lazy load VibeOverlayEnhanced - only loads when vibe mode is active
const EnhancedVibeOverlay = lazy(() => import("./VibeOverlayEnhanced").then(mod => ({ default: mod.EnhancedVibeOverlay })));
/**
* Container component that manages the floating EnhancedVibeOverlay.
* Shows automatically when vibe mode is active on desktop.
*/
export function VibeOverlayContainer() {
const { vibeMode, queue, currentIndex } = useAudioState();
const [isVisible, setIsVisible] = useState(false);
const [isDismissed, setIsDismissed] = useState(false);
// Auto-show when vibe mode activates, reset dismissed state
useEffect(() => {
if (vibeMode) {
setIsVisible(true);
setIsDismissed(false);
} else {
setIsVisible(false);
setIsDismissed(false);
}
}, [vibeMode]);
// Get current track's audio features from the queue
const currentTrackFeatures = queue[currentIndex]?.audioFeatures || null;
// Don't render if not in vibe mode or dismissed
if (!vibeMode || isDismissed || !isVisible) return null;
return (
<Suspense fallback={null}>
<EnhancedVibeOverlay
currentTrackFeatures={currentTrackFeatures}
variant="floating"
onClose={() => setIsDismissed(true)}
/>
</Suspense>
);
}