Skip to content

Commit

Permalink
Add authentication context
Browse files Browse the repository at this point in the history
  • Loading branch information
BissonnetteVincent committed Mar 23, 2024
1 parent f5b8c8d commit def2b61
Show file tree
Hide file tree
Showing 5 changed files with 72 additions and 30 deletions.
5 changes: 4 additions & 1 deletion .vscode/settings.json
Original file line number Diff line number Diff line change
Expand Up @@ -156,5 +156,8 @@
"evenBetterToml.formatter.reorderArrays": true,
"evenBetterToml.formatter.trailingNewline": true,
// We like keeping TOML keys in a certain non-alphabetical order that feels more natural
"evenBetterToml.formatter.reorderKeys": false
"evenBetterToml.formatter.reorderKeys": false,
"[typescriptreact]": {
"editor.defaultFormatter": "vscode.typescript-language-features"
}
}
1 change: 1 addition & 0 deletions canopeum_frontend/.eslintrc.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -23,5 +23,6 @@ module.exports = {
'no-autofix/no-relative-import-paths/no-relative-import-paths': 'off',
// Using Bootraps directly without a React wrapper will cause us to have to add classes to React Components
'react/forbid-component-props': 'off',
"react/display-name": [false, { "ignoreTranspilerName": false, "checkContextObjects": false }]
},
}
27 changes: 15 additions & 12 deletions canopeum_frontend/src/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,20 +10,23 @@ import Login from './pages/Login';
import Map from './pages/Map';
import UserManagement from './pages/UserManagement';
import Utilities from './pages/Utilities';
import AuthenticationContextProvider from './components/context/AuthenticationContext';

const App = () => (
<BrowserRouter>
<Navbar />
<Routes>
<Route element={<Home />} path="/home" />
<Route element={<Home />} path="/" />
<Route element={<Analytics />} path="/analytics" />
<Route element={<Map />} path="/map" />
<Route element={<UserManagement />} path="/user-management" />
<Route element={<Login />} path="/login" />
<Route element={<Utilities />} path="/utilities" />
</Routes>
</BrowserRouter>
<AuthenticationContextProvider>
<BrowserRouter>
<Navbar />
<Routes>
<Route element={<Home />} path="/home" />
<Route element={<Home />} path="/" />
<Route element={<Analytics />} path="/analytics" />
<Route element={<Map />} path="/map" />
<Route element={<UserManagement />} path="/user-management" />
<Route element={<Login />} path="/login" />
<Route element={<Utilities />} path="/utilities" />
</Routes>
</BrowserRouter>
</AuthenticationContextProvider>
);

export default App;
35 changes: 35 additions & 0 deletions canopeum_frontend/src/components/context/AuthenticationContext.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
import type { FunctionComponent, ReactNode } from 'react';
import { createContext, memo, useState } from 'react'

type User = {
name: string
}

type IAuthenticationContext = {
authenticate: (user: User) => void
isAuthenticated: boolean
currentUser: User | undefined
}

export const AuthenticationContext = createContext<IAuthenticationContext>({
authenticate: (_: User) => { },
isAuthenticated: false,
currentUser: undefined
});

const AuthenticationContextProvider: FunctionComponent<{ readonly children?: ReactNode }> = memo((props) => {
const [user, setUser] = useState<User | undefined>(undefined)

const authenticate = (user: User) => setUser(user)

return <AuthenticationContext.Provider
value={{
currentUser: user,
isAuthenticated: user !== undefined,
authenticate,
}}>
{props.children}
</AuthenticationContext.Provider>
})

export default AuthenticationContextProvider
34 changes: 17 additions & 17 deletions canopeum_frontend/src/pages/Home.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -31,23 +31,23 @@ const Home = () => {
<div className="bg-white rounded-2 px-3 py-2">
<h1>Home</h1>
{isLoading
? (
<p>Loading...</p>
)
: error
? (
<p>Error: {error.message}</p>
)
: (
<div>
<p>Example request from API:</p>
<ul>
{data.map((item) => (
<li key={item.id}>{item.name}</li>
))}
</ul>
</div>
)}
? (
<p>Loading...</p>
)
: error
? (
<p>Error: {error.message}</p>
)
: (
<div>
<p>Example request from API:</p>
<ul>
{data.map((item) => (
<li key={item.id}>{item.name}</li>
))}
</ul>
</div>
)}
</div>
</div>
</div>
Expand Down

0 comments on commit def2b61

Please sign in to comment.