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
WooNooW
WooNooW is a modern experience layer for WooCommerce — enhancing UX, speed, and reliability without data migration.
It keeps WooCommerce as the core engine while providing a modern React-powered interface for both the storefront (cart, checkout, my‑account) and the admin (orders, dashboard).
Three Admin Modes:
- Normal Mode: Traditional wp-admin integration (
/wp-admin/admin.php?page=woonoow) - Fullscreen Mode: Distraction-free interface (toggle in header)
- Standalone Mode: Complete standalone app at
yoursite.com/adminwith custom login ✨
🔍 Background
WooCommerce is the most used e‑commerce engine in the world, but its architecture has become heavy and fragmented.
With React‑based blocks (Checkout, Cart, Product Edit) and HPOS now rolling out, many existing addons are becoming obsolete or unstable.
WooNooW bridges the gap between Woo’s legacy PHP system and the new modern stack — so users get performance and simplicity without losing compatibility.
🚀 Key Principles
- No Migration Needed – Woo data stays intact.
- Safe Activate/Deactivate – revert to native Woo anytime, no data loss.
- Hybrid by Default – SSR + React islands for Cart/Checkout/My‑Account.
- Full SPA Toggle – optional React‑only mode for max performance.
- HPOS Mandatory – optimized datastore and async operations.
- Compat Layer – hook mirror + slot rendering for legacy addons.
- Async Mail & Tasks – powered by Action Scheduler.
🧱 Tech Stack
| Layer | Technology |
|---|---|
| Backend | PHP 8.2+, WordPress, WooCommerce (HPOS), Action Scheduler |
| Frontend | React 18 + TypeScript, Vite, React Query, Tailwind (optional) |
| Build & Package | Composer, NPM, ESM scripts, Zip automation |
| Architecture | Modular PSR‑4 classes, REST‑driven SPA islands |
🧩 Project Structure
woonoow/
├── admin-spa/
│ ├── src/
│ │ ├── components/
│ │ │ ├── filters/
│ │ │ │ ├── DateRange.tsx
│ │ │ │ └── OrderBy.tsx
│ │ │ └── CommandPalette.tsx
│ │ ├── hooks/
│ │ │ └── useShortcuts.tsx
│ │ ├── lib/
│ │ │ ├── api.ts
│ │ │ ├── currency.ts
│ │ │ ├── dates.ts
│ │ │ ├── query-params.ts
│ │ │ ├── useCommandStore.ts
│ │ │ └── utils.ts
│ │ ├── pages/
│ │ │ └── orders/
│ │ │ ├── partials
│ │ │ │ └── OrderForm.tsx
│ │ │ ├── Orders.tsx
│ │ │ ├── OrdersNew.tsx
│ │ │ └── OrderShow.tsx
│ │ ├── routes/
│ │ │ └── Dashboard.tsx
│ │ ├── types/
│ │ │ └── qrcode.d.ts
│ │ ├── App.tsx
│ │ ├── index.css
│ │ └── main.tsx
│ └── vite.config.ts
├── includes/
│ ├── Admin/
│ │ ├── Assets.php
│ │ └── Menu.php
│ ├── Api/
│ │ ├── CheckoutController.php
│ │ ├── OrdersController.php
│ │ ├── Permissions.php
│ │ └── Routes.php
│ ├── Compat/
│ │ ├── HideWooMenus.php
│ │ └── HooksShim.php
│ └── Core/
│ ├── DataStores/
│ │ ├── OrderStore_HPOS.php
│ │ └── OrderStore.php
│ ├── Mail/
│ │ ├── MailQueue.php
│ │ └── WooEmailOverride.php
│ ├── Bootstrap.php
│ └── Features.php
├── woonoow.php
└── docs (project notes, SOP, etc.)
⚙️ Development Workflow
- LocalWP / Docker setup with WordPress + WooCommerce.
- Activate plugin:
WooNooWshould appear in the admin menu. - Build SPAs:
npm run build - Package zip:
npm run pack - Upload
dist/woonoow.zipinto WordPress → Plugins → Add New → Upload.
🧭 Vision
“WooCommerce, reimagined for now.”
WooNooW delivers modern speed and UX while keeping WooCommerce’s ecosystem alive.
No migration. No lock‑in. Just Woo, evolved.