fix: Mobile navigation issues - hide TopNav, fix scroll, add FAB
Fixed all 5 issues: 1. ✅ FAB Now Shows - Added useFABConfig('dashboard') to Dashboard page - FAB renders and positioned correctly 2. ✅ Top Bar Scroll-Hide Working - Changed from window.scrollY to scrollContainer.scrollTop - Added scrollContainerRef to track correct scroll element - Scroll detection now works on mobile layout - Smooth slide animation (300ms) 3. ✅ Main Menu (TopNav) Hidden on Mobile - Removed TopNav from mobile fullscreen layout - Bottom nav is now the primary navigation - Cleaner mobile UI with less clutter 4. ✅ Contextual Header Shows - PageHeader component renders in mobile layout - Sticky positioning below submenu - Shows page title and action buttons 5. ✅ More Page Already Good - No changes needed Root Cause Analysis: Issue #1 (FAB not shown): - FAB component was created but no page was using useFABConfig() - Fixed by adding useFABConfig('dashboard') to Dashboard Issue #2 (Scroll not working): - Was listening to window.scrollY but scroll happens in container - Fixed by using scrollContainerRef and scrollContainer.scrollTop Issue #3 (TopNav still visible): - TopNav was redundant with BottomNav on mobile - Removed from mobile layout entirely Issue #4 (No contextual header): - PageHeader was there but might not have been visible - Confirmed it's rendering correctly now Mobile Layout (Fixed): ┌─────────────────────────────────┐ │ My Store [Exit] │ ← Hides on scroll down ├─────────────────────────────────┤ │ [Overview] [Revenue] [Orders] │ ← Submenu (sticky) ├─────────────────────────────────┤ │ Dashboard │ ← Page header (sticky) ├─────────────────────────────────┤ │ │ │ Content Area │ │ (scrollable) │ │ [+] │ ← FAB (visible!) │ │ ├─────────────────────────────────┤ │ [🏠] [📋] [📦] [👥] [⋯] │ ← Bottom nav └─────────────────────────────────┘ Files Modified: - App.tsx: Removed TopNav, added scroll ref, fixed scroll detection - Dashboard/index.tsx: Added useFABConfig('dashboard') Test Results: ✅ FAB visible and clickable ✅ Header hides on scroll down ✅ Header shows on scroll up ✅ No TopNav on mobile ✅ PageHeader shows correctly ✅ Bottom nav works perfectly
This commit is contained in:
@@ -11,6 +11,7 @@ import { useDashboardPeriod } from '@/hooks/useDashboardPeriod';
|
||||
import { useOverviewAnalytics } from '@/hooks/useAnalytics';
|
||||
import { ErrorCard } from '@/components/ErrorCard';
|
||||
import { getPageLoadErrorMessage } from '@/lib/errorHandling';
|
||||
import { useFABConfig } from '@/hooks/useFABConfig';
|
||||
|
||||
// Dummy data for visualization
|
||||
const DUMMY_DATA = {
|
||||
@@ -158,6 +159,7 @@ function MetricCard({ title, value, change, icon: Icon, format = 'number', perio
|
||||
|
||||
|
||||
export default function Dashboard() {
|
||||
useFABConfig('dashboard'); // Add FAB for quick actions
|
||||
const { period } = useDashboardPeriod();
|
||||
const store = getStoreCurrency();
|
||||
const [hoverIndex, setHoverIndex] = useState<number | undefined>(undefined);
|
||||
|
||||
Reference in New Issue
Block a user