fix: Update PrimeReact to v10.8.3 to fix missing modules
This commit is contained in:
81
app/auth/callback/page.tsx
Normal file
81
app/auth/callback/page.tsx
Normal file
@@ -0,0 +1,81 @@
|
||||
'use client';
|
||||
|
||||
import React, { useEffect, useState } from 'react';
|
||||
import { useRouter, useSearchParams } from 'next/navigation';
|
||||
import { ProgressSpinner } from 'primereact/progressspinner';
|
||||
|
||||
const AuthCallbackPage = () => {
|
||||
const router = useRouter();
|
||||
const searchParams = useSearchParams();
|
||||
const [status, setStatus] = useState('Traitement de l'authentification...');
|
||||
|
||||
useEffect(() => {
|
||||
const handleAuthCallback = async () => {
|
||||
try {
|
||||
const code = searchParams.get('code');
|
||||
const state = searchParams.get('state');
|
||||
const error = searchParams.get('error');
|
||||
|
||||
if (error) {
|
||||
setStatus(`Erreur d'authentification: ${error}`);
|
||||
setTimeout(() => router.push('/auth/login'), 3000);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!code) {
|
||||
setStatus('Code d\'autorisation manquant');
|
||||
setTimeout(() => router.push('/auth/login'), 3000);
|
||||
return;
|
||||
}
|
||||
|
||||
setStatus('Échange du code d\'autorisation...');
|
||||
|
||||
// Échanger le code contre des tokens
|
||||
const response = await fetch('/api/auth/token', {
|
||||
method: 'POST',
|
||||
headers: {
|
||||
'Content-Type': 'application/json',
|
||||
},
|
||||
body: JSON.stringify({ code, state }),
|
||||
});
|
||||
|
||||
if (!response.ok) {
|
||||
throw new Error('Échec de l\'échange de token');
|
||||
}
|
||||
|
||||
const tokens = await response.json();
|
||||
|
||||
setStatus('Authentification réussie, redirection...');
|
||||
|
||||
// Stocker les tokens
|
||||
if (tokens.access_token) {
|
||||
localStorage.setItem('accessToken', tokens.access_token);
|
||||
localStorage.setItem('refreshToken', tokens.refresh_token);
|
||||
localStorage.setItem('idToken', tokens.id_token);
|
||||
}
|
||||
|
||||
// Rediriger vers le dashboard
|
||||
router.push('/dashboard');
|
||||
|
||||
} catch (error) {
|
||||
console.error('Erreur lors du traitement de l\'authentification:', error);
|
||||
setStatus('Erreur lors de l\'authentification');
|
||||
setTimeout(() => router.push('/auth/login'), 3000);
|
||||
}
|
||||
};
|
||||
|
||||
handleAuthCallback();
|
||||
}, [searchParams, router]);
|
||||
|
||||
return (
|
||||
<div className="flex flex-column align-items-center justify-content-center min-h-screen">
|
||||
<div className="card p-4 text-center">
|
||||
<ProgressSpinner style={{ width: '50px', height: '50px' }} />
|
||||
<h3 className="mt-3">Authentification en cours</h3>
|
||||
<p className="text-600">{status}</p>
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
export default AuthCallbackPage;
|
||||
21
app/clients/page.tsx
Normal file
21
app/clients/page.tsx
Normal file
@@ -0,0 +1,21 @@
|
||||
'use client';
|
||||
|
||||
import React from 'react';
|
||||
import { useRouter } from 'next/navigation';
|
||||
|
||||
const ClientsPage = () => {
|
||||
const router = useRouter();
|
||||
|
||||
React.useEffect(() => {
|
||||
// Rediriger vers la page principale des clients dans (main)
|
||||
router.replace('/(main)/clients');
|
||||
}, [router]);
|
||||
|
||||
return (
|
||||
<div>
|
||||
<p>Redirection vers les clients...</p>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
export default ClientsPage;
|
||||
21
app/home/page.tsx
Normal file
21
app/home/page.tsx
Normal file
@@ -0,0 +1,21 @@
|
||||
'use client';
|
||||
|
||||
import React from 'react';
|
||||
import { useRouter } from 'next/navigation';
|
||||
|
||||
const HomePage = () => {
|
||||
const router = useRouter();
|
||||
|
||||
React.useEffect(() => {
|
||||
// Rediriger vers la page d'accueil principale
|
||||
router.replace('/');
|
||||
}, [router]);
|
||||
|
||||
return (
|
||||
<div>
|
||||
<p>Redirection vers l'accueil...</p>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
export default HomePage;
|
||||
21
app/login/page.tsx
Normal file
21
app/login/page.tsx
Normal file
@@ -0,0 +1,21 @@
|
||||
'use client';
|
||||
|
||||
import React from 'react';
|
||||
import { useRouter } from 'next/navigation';
|
||||
|
||||
const LoginPage = () => {
|
||||
const router = useRouter();
|
||||
|
||||
React.useEffect(() => {
|
||||
// Rediriger vers la page de connexion dans auth
|
||||
router.replace('/auth/login');
|
||||
}, [router]);
|
||||
|
||||
return (
|
||||
<div>
|
||||
<p>Redirection vers la connexion...</p>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
export default LoginPage;
|
||||
21
app/materiel/page.tsx
Normal file
21
app/materiel/page.tsx
Normal file
@@ -0,0 +1,21 @@
|
||||
'use client';
|
||||
|
||||
import React from 'react';
|
||||
import { useRouter } from 'next/navigation';
|
||||
|
||||
const MaterielPage = () => {
|
||||
const router = useRouter();
|
||||
|
||||
React.useEffect(() => {
|
||||
// Rediriger vers la page principale du matériel dans (main)
|
||||
router.replace('/(main)/materiels');
|
||||
}, [router]);
|
||||
|
||||
return (
|
||||
<div>
|
||||
<p>Redirection vers le matériel...</p>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
export default MaterielPage;
|
||||
Reference in New Issue
Block a user