redirect()->route('dashboard')); Route::middleware(['auth', 'verified'])->group(function () { Route::get('/dashboard', [DashboardController::class, 'index'])->name('dashboard'); // Commandes Route::resource('commandes', CommandeController::class); Route::patch('/commandes/{commande}/transition', [CommandeController::class, 'transition']) ->name('commandes.transition'); Route::get('/commandes/{commande}/pdf', [CommandeController::class, 'exportPdf']) ->name('commandes.pdf'); // Contrats Route::resource('contrats', ContratController::class); // Domaines Route::resource('domaines', DomaineController::class)->except(['show']); Route::post('/domaines/{domaine}/sync-whois', [DomaineController::class, 'syncWhois']) ->name('domaines.sync-whois'); // Pièces jointes Route::post('/commandes/{commande}/pieces-jointes', [PieceJointeController::class, 'store']) ->name('pieces-jointes.store'); Route::post('/contrats/{contrat}/pieces-jointes', [PieceJointeController::class, 'storeContrat']) ->name('pieces-jointes.contrat.store'); Route::get('/pieces-jointes/{pieceJointe}/download', [PieceJointeController::class, 'download']) ->name('pieces-jointes.download'); Route::delete('/pieces-jointes/{pieceJointe}', [PieceJointeController::class, 'destroy']) ->name('pieces-jointes.destroy'); // Fournisseurs Route::resource('fournisseurs', FournisseurController::class); Route::patch('/fournisseurs/{fournisseur}/toggle-active', [FournisseurController::class, 'toggleActive']) ->name('fournisseurs.toggle-active'); // Catégories (pas de create/show/edit pages séparées — géré via modal dans Index) Route::post('/categories', [CategorieController::class, 'store'])->name('categories.store'); Route::put('/categories/{categorie}', [CategorieController::class, 'update'])->name('categories.update'); Route::delete('/categories/{categorie}', [CategorieController::class, 'destroy'])->name('categories.destroy'); Route::get('/categories', [CategorieController::class, 'index'])->name('categories.index'); // Articles Route::resource('articles', ArticleController::class)->except(['show']); // Profil Route::get('/profile', [ProfileController::class, 'edit'])->name('profile.edit'); Route::patch('/profile', [ProfileController::class, 'update'])->name('profile.update'); Route::delete('/profile', [ProfileController::class, 'destroy'])->name('profile.destroy'); // Administration (admin uniquement) Route::middleware('role:admin')->group(function () { Route::get('/services', [ServiceController::class, 'index'])->name('services.index'); Route::post('/services', [ServiceController::class, 'store'])->name('services.store'); Route::put('/services/{service}', [ServiceController::class, 'update'])->name('services.update'); Route::delete('/services/{service}', [ServiceController::class, 'destroy'])->name('services.destroy'); Route::get('/users', [UserController::class, 'index'])->name('users.index'); Route::get('/users/{user}/edit', [UserController::class, 'edit'])->name('users.edit'); Route::put('/users/{user}', [UserController::class, 'update'])->name('users.update'); Route::patch('/users/{user}/toggle-active', [UserController::class, 'toggleActive']) ->name('users.toggle-active'); }); }); require __DIR__ . '/auth.php';