dev1/src/App.js

54 lines
1.8 KiB
JavaScript

import React, { useState} from 'react';
import { Routes, Route, Navigate } from 'react-router-dom';
import GettingStarted from './components/GettingStarted.js';
import SignIn from './components/SignIn.js';
import SignUp from './components/SignUp.js';
import InterestInventory from './components/InterestInventory.js';
import Dashboard from './components/Dashboard.js';
import UserProfile from './components/UserProfile.js';
import './App.css';
function App() {
console.log("App.js is rendering!");
const [isAuthenticated, setIsAuthenticated] = useState(() => {
return !!localStorage.getItem('token'); // Check localStorage
});
return (
<div className="App">
<h1>AptivaAI - Career Guidance Platform (beta)</h1>
<Routes>
{/* Redirect root to /signin */}
<Route path="/" element={<Navigate to="/signin" />} />
{/* Public routes */}
<Route path="/signin" element={<SignIn setIsAuthenticated={setIsAuthenticated} />} />
<Route path="/signup" element={<SignUp />} />
{/* Protected routes */}
<Route
path="/getting-started"
element={isAuthenticated ? <GettingStarted /> : <Navigate to="/signin" />}
/>
<Route
path="/interest-inventory"
element={isAuthenticated ? <InterestInventory /> : <Navigate to="/signin" />}
/>
<Route
path="/dashboard"
element={isAuthenticated ? <Dashboard /> : <Navigate to="/signin" />}
/>
<Route
path="/profile"
element={isAuthenticated ? <UserProfile /> : <Navigate to="/signin" />}
/>
{/* Catch-all for unknown routes */}
<Route path="*" element={<Navigate to="/signin" />} />
</Routes>
</div>
);
}
export default App;