Commit Graph

91 Commits

Author SHA1 Message Date
Eric Gullickson
715250d50d Add error handling for Google Maps DOM conflicts with React
The Google Maps API and React both manipulate the DOM, which can cause
conflicts where Google Maps removes nodes that React still has references
to. Add graceful error handling:

1. Remove async flag from Google Maps script - use defer only
2. Add try-catch in marker update useEffect to ignore removeChild errors
3. Add cleanup function to properly tear down markers on unmount
4. Log warnings instead of crashing when DOM conflicts occur

This allows the app to continue functioning even when there are minor
DOM reconciliation issues between Google Maps and React.

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 19:37:27 -06:00
Eric Gullickson
8e52f3fb0e Fix Google Maps API callback for async loading
The loading=async parameter requires a callback to notify when the API
is ready. Without a callback, google.maps is not properly initialized.

Use a global callback function with a timestamp suffix to handle the
async initialization properly, ensuring google.maps.Map constructor
is available when the component tries to initialize the map.

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 19:36:03 -06:00
Eric Gullickson
4151f58fa5 Fix Google Maps async loading parameter
Add loading=async query parameter to Google Maps API URL to prevent
synchronous DOM manipulation. This fixes the warning:
'Google Maps JavaScript API has been loaded directly without loading=async'

The loading=async parameter tells Google Maps to defer API initialization
until the script is fully loaded, preventing race conditions with React's
DOM management.

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 19:33:12 -06:00
Eric Gullickson
def2494ed7 Replace promise-based auth initialization with polling
The promise-based waitForAuthInit() approach wasn't reliably triggering
React state updates when setAuthInitialized(true) was called. Replace with
a polling mechanism that actively checks isAuthInitialized() every 50ms
with exponential backoff, ensuring state updates trigger properly.

This fixes the hanging "Initializing session..." issue where the auth gate
remained stuck waiting indefinitely.

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 19:31:03 -06:00
Eric Gullickson
f1dd48808b Fix blank stations page - add auth gate guard in App.tsx
ROOT CAUSE: Race condition where StationsPage renders before auth
token is ready, causing DOM state mismatch.

Timeline of the bug:
1. Auth0 sets isAuthenticated=true
2. App renders StationsPage before isAuthInitialized=true
3. useSavedStations hook is disabled (enabled: false)
4. Google Maps loads and manipulates DOM
5. Auth token finally acquired, isAuthInitialized=true
6. Component re-renders with query now enabled
7. React tries to remove DOM nodes already removed by Google Maps
8. NotFoundError: removeChild fails

SOLUTION: Add isAuthGateReady check in App.tsx before rendering
protected routes. Show "Initializing session..." until auth gate is
fully initialized.

Changes:
- Import useIsAuthInitialized hook in App.tsx
- Call hook in App component
- Add guard check after isAuthenticated check
- Show loading UI if authenticated but auth gate not ready
- Add debug logs to track render flow

Now the page won't render until BOTH:
1. isAuthenticated=true (Auth0)
2. isAuthInitialized=true (our token gate)

This prevents the race condition that causes the removeChild DOM error.

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 19:26:21 -06:00
Eric Gullickson
050f1b030e Enable console debugging and add debug statements
- Enable console logging in vite.config.ts:
  - Set drop_console to false
  - Disabled pure_funcs stripping for console.log
  - Changed esbuild to only drop debugger, keep console

- Add debug logging to auth-gate.ts:
  - Log setAuthInitialized calls

- Add debug logging to useSavedStations.ts:
  - Log hook invocations
  - Log query function execution and results
  - Added retry configuration

- Add debug logging to StationsPage.tsx:
  - Log component renders
  - Log useSavedStations result state

These logs will show us what's happening with auth initialization and
query state transitions that are causing the React DOM removeChild error.

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 19:24:20 -06:00
Eric Gullickson
0e8d8e7d5e Fix blank stations page by waiting for auth initialization
- Add useIsAuthInitialized hook to auth-gate for reactive auth state
  - Returns true once auth token is acquired and ready
  - Waits for waitForAuthInit() promise to resolve

- Update useSavedStations hook to wait for auth before fetching
  - Add 'enabled: isAuthInitialized' to useQuery config
  - Prevents 401 errors from requests made before token is ready
  - Fixes race condition where hook fires before interceptor is set up

The stations page was blank because useSavedStations() made an API call
with refetchOnMount:true before the auth token interceptor was added,
causing a 401 response that made the component unmount/remount, creating
a React DOM error in the error boundary.

Now the hook waits for isAuthInitialized to be true before making the
initial API call, ensuring the token interceptor is ready.

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 19:15:03 -06:00
Eric Gullickson
9a41a3c417 Fix API endpoint routing errors and Traefik configuration
- Fix: Remove double /api prefix in stations API calls
  - stations.api.ts was using '/api/stations' but apiClient already prepends '/api'
  - Changed API_BASE from '/api/stations' to '/stations'
  - This resolves 404 errors on /api/api/stations/saved and similar endpoints

- Fix: Remove invalid access-log middleware from Traefik config
  - The accessLog field is only valid in traefik.yml main config, not as a middleware
  - Removed the invalid access-log middleware definition
  - This resolves Traefik configuration errors during startup

These changes resolve the console errors:
- GET https://motovaultpro.com/api/vehicles 404
- GET https://motovaultpro.com/api/api/stations/saved 404

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 19:10:30 -06:00
Eric Gullickson
c6f43fe86b Merge branch 'main' of github.com:ericgullickson/motovaultpro 2025-11-04 18:47:06 -06:00
Eric Gullickson
5dc58d73b9 Gas Station Feature 2025-11-04 18:46:46 -06:00
Eric Gullickson
d4156cf521 Stuff 2025-11-04 18:38:06 -06:00
Eric Gullickson
eeb20543fa Homepage Redesign 2025-11-03 14:06:54 -06:00
Eric Gullickson
cde14f2766 URL Fix 2025-11-01 22:01:18 -05:00
Eric Gullickson
046c66fc7d Redesign 2025-11-01 21:27:42 -05:00
Eric Gullickson
5638d3960b Update 2025-10-16 19:20:30 -05:00
Eric Gullickson
775a1ff69e Added Documents Feature 2025-09-28 20:35:46 -05:00
Eric Gullickson
2e1b588270 UX Improvements 2025-09-26 14:45:03 -05:00
Eric Gullickson
56443d5b2f Record UX improvements 2025-09-25 15:07:31 -05:00
Eric Gullickson
82c66dafed Fixed mobile form 2025-09-25 14:21:23 -05:00
Eric gullickson
d4ca0ba8ae Debugging 2025-09-22 20:58:02 -05:00
Eric gullickson
d4befe31d1 Debugging 2025-09-22 20:49:44 -05:00
Eric gullickson
3c741c545f Merge branch 'main' of github.com:ericgullickson/motovaultpro 2025-09-22 20:33:44 -05:00
Eric gullickson
0f39e5eb7f Mobile Bug Fixes 2025-09-22 20:31:27 -05:00
Eric Gullickson
8fd7973656 Fix Auth Errors 2025-09-22 10:27:10 -05:00
Eric Gullickson
3588372cef Mobile Work 2025-09-19 11:33:31 -05:00
Eric Gullickson
040da4c759 k8s redesign complete 2025-09-18 22:44:30 -05:00
Eric Gullickson
17d27f4b92 k8s improvement 2025-09-17 20:47:42 -05:00
Eric Gullickson
a052040e3a Initial Commit 2025-09-17 16:09:15 -05:00
Eric Gullickson
0cdb9803de Updated frameworks. 2025-08-25 12:40:27 -05:00
Eric Gullickson
e22d643ae3 Security Fixes 2025-08-24 14:39:50 -05:00
Eric Gullickson
b534e92636 Modernization Project Complete. Updated to latest versions of frameworks. 2025-08-24 09:49:21 -05:00
Eric Gullickson
673fe7ce91 Phase 6 complete: Docker modernization with production-first architecture
- Multi-stage builds: Backend 347MB → 196MB (43% reduction)
- Production-ready containers with non-root security
- Eliminated dev/prod naming - single clean container approach
- TypeScript build issues resolved with relaxed build configs
- Ready for Phase 7: Vehicles Fastify migration

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-23 19:52:36 -05:00
Eric Gullickson
1064b8c3d7 Docker baseline before Phase 6 modernization
🔄 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-23 19:19:01 -05:00
Eric Gullickson
1603ce004d Phase 3 COMPLETED: React Compiler Integration
🚀 React Compiler Successfully Integrated
- Installed: babel-plugin-react-compiler@rc
- Configured: Vite with Babel plugin + 'infer' mode
- Performance: Expected 30-60% faster rendering
- Bundle: 768KB total (753KB→768KB, +15KB optimizations)
- Build time: 28.59s (similar to baseline)
- No manual memoization to remove (clean codebase)

 All Systems Working
- TypeScript compilation: 
- Production build: 
- Docker containers: 
- Application functionality: 

📊 Ready for Phase 4: Backend Evaluation
Next: Evaluate Express vs Fastify vs Hono performance

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-23 16:56:00 -05:00
Eric Gullickson
698db0ed4c Working React 19 before Compiler integration
🚀 Phase 2 Complete - React 19 Foundation
- React upgraded: 18.2.0 → 19.0.0 
- MUI upgraded: 5 → 6 
- React Router upgraded: 6 → 7 
- All packages updated and working 
- Production build: 995KB bundle 
- All containers working 

Ready for Phase 3: React Compiler integration

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-23 16:46:31 -05:00
Eric Gullickson
1288a4fb7d Complete Phase 2: React 19 Foundation upgrade
 PHASE 2 COMPLETED - React 19 Foundation established

## Successful Upgrades
- React: 18.2.0 → 19.1.1
- @mui/material: 5.15.0 → 6.0.0
- react-router-dom: 6.20.0 → 7.0.0
- framer-motion: 10.16.16 → 11.0.0
- @testing-library/react: 14.1.2 → 16.0.0
- @types/react: 18.2.42 → 19.0.0

## Build Performance
- Bundle size: 995KB (63KB increase from React 18 baseline)
- Build time: 23.7s (comparable to React 18 baseline)
- TypeScript compilation:  PASSING
- Docker containers:  REBUILT & TESTED

## System Status
- Frontend:  Serving at localhost:3000
- Backend:  Health endpoint responding
- Development environment:  FULLY OPERATIONAL
- All core functionality preserved

## Ready for Phase 3
- React Compiler integration prepared
- Performance baseline established for comparison
- Docker-first development workflow maintained

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-23 14:34:27 -05:00
Eric Gullickson
a5270c33a8 Fix container build 2025-08-23 10:47:58 -05:00
Eric Gullickson
ac97d03c78 Fixed Dockerfile 2025-08-23 10:34:21 -05:00
Eric Gullickson
6683f1eeff Very minimal MVP 2025-08-23 09:54:22 -05:00
Eric Gullickson
d60c3ec00e MVP with new UX 2025-08-09 17:45:54 -05:00
Eric Gullickson
8f5117a4e2 MVP Build 2025-08-09 12:47:15 -05:00