Paywall navigation and button added
This commit is contained in:
parent
fa26c4a31b
commit
8ebfaf1964
36
src/App.js
36
src/App.js
@ -1,5 +1,6 @@
|
||||
import React, { useState} from 'react';
|
||||
import { Routes, Route, Navigate } from 'react-router-dom';
|
||||
// App.js
|
||||
import React, { useState } from 'react';
|
||||
import { Routes, Route, Navigate, useNavigate, useLocation } from 'react-router-dom';
|
||||
import SessionExpiredHandler from './components/SessionExpiredHandler.js';
|
||||
import GettingStarted from './components/GettingStarted.js';
|
||||
import SignIn from './components/SignIn.js';
|
||||
@ -9,27 +10,39 @@ import Dashboard from './components/Dashboard.js';
|
||||
import UserProfile from './components/UserProfile.js';
|
||||
import FinancialProfileForm from './components/FinancialProfileForm.js';
|
||||
import MilestoneTracker from "./components/MilestoneTracker.js";
|
||||
import Paywall from "./components/Paywall.js";
|
||||
import './App.css';
|
||||
|
||||
function App() {
|
||||
console.log("App rendered");
|
||||
const navigate = useNavigate();
|
||||
const location = useLocation();
|
||||
|
||||
const [isAuthenticated, setIsAuthenticated] = useState(() => {
|
||||
return !!localStorage.getItem('token'); // Check localStorage
|
||||
});
|
||||
const [isAuthenticated, setIsAuthenticated] = useState(() => !!localStorage.getItem('token'));
|
||||
|
||||
const premiumPaths = ['/milestone-tracker', '/paywall', '/financial-profile'];
|
||||
|
||||
const showPremiumCTA = !premiumPaths.includes(location.pathname);
|
||||
|
||||
return (
|
||||
<div className="App">
|
||||
<header className="app-header">
|
||||
<h1>AptivaAI - Career Guidance Platform (beta)</h1>
|
||||
<Routes>
|
||||
{/* Redirect root to /signin */}
|
||||
<Route path="/" element={<Navigate to="/signin" />} />
|
||||
{showPremiumCTA && (
|
||||
<button
|
||||
className="premium-cta"
|
||||
onClick={() => navigate('/paywall')}
|
||||
>
|
||||
Upgrade to Premium
|
||||
</button>
|
||||
)}
|
||||
</header>
|
||||
|
||||
{/* Public routes */}
|
||||
<Routes>
|
||||
<Route path="/" element={<Navigate to="/signin" />} />
|
||||
<Route path="/signin" element={<SignIn setIsAuthenticated={setIsAuthenticated} />} />
|
||||
<Route path="/signup" element={<SignUp />} />
|
||||
<Route path="/paywall" element={<Paywall />} />
|
||||
|
||||
{/* Protected routes */}
|
||||
{isAuthenticated && (
|
||||
<>
|
||||
<Route path="/getting-started" element={<GettingStarted />} />
|
||||
@ -41,7 +54,6 @@ function App() {
|
||||
</>
|
||||
)}
|
||||
|
||||
{/* Catch-all for unknown routes */}
|
||||
<Route path="*" element={<Navigate to="/signin" />} />
|
||||
</Routes>
|
||||
<SessionExpiredHandler />
|
||||
|
@ -384,6 +384,7 @@ function Dashboard() {
|
||||
)}
|
||||
|
||||
<div className="dashboard-content">
|
||||
|
||||
<div className="career-suggestions-container">
|
||||
<div
|
||||
className="career-suggestions-header"
|
||||
@ -461,6 +462,8 @@ function Dashboard() {
|
||||
)}
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<div
|
||||
className="data-source-acknowledgment"
|
||||
style={{
|
||||
|
BIN
user_profile.db
BIN
user_profile.db
Binary file not shown.
Loading…
Reference in New Issue
Block a user