fix: correcciones parciales - ProjectController, ProfileController, Phase features, project-map JS

This commit is contained in:
2026-05-08 01:16:20 +02:00
parent 156aa14bbb
commit 199fb487c2
5 changed files with 98 additions and 14 deletions
@@ -0,0 +1,55 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
use Illuminate\Validation\Rules\Password;
class ProfileController extends Controller
{
/**
* Show the profile edit form.
*/
public function edit()
{
return view('profile');
}
/**
* Update the user's profile information.
*/
public function update(Request $request)
{
$user = Auth::user();
$validated = $request->validate([
'name' => 'required|string|max:255',
'email' => 'required|email|max:255|unique:users,email,' . $user->id,
]);
$user->update($validated);
return redirect()->route('profile')->with('success', 'Perfil actualizado.');
}
/**
* Delete the user's account.
*/
public function destroy(Request $request)
{
$request->validate([
'password' => ['required', 'current_password'],
]);
$user = Auth::user();
Auth::logout();
$user->delete();
$request->session()->invalidate();
$request->session()->regenerateToken();
return redirect('/');
}
}
+3 -2
View File
@@ -8,6 +8,7 @@ use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Gate;
use App\Models\Project;
class ProjectController extends Controller
{
@@ -53,9 +54,9 @@ class ProjectController extends Controller
/**
* Display the specified resource.
*/
public function show(string $id)
public function show(Project $project)
{
// No usamos show, redirigimos al mapa o a edición
// No usamos show, redirigimos al mapa
return redirect()->route('projects.map', $project);
}
+1
View File
@@ -101,6 +101,7 @@ class ProjectMap extends Component
*/
public function selectFeature($featureId)
{
$this->selectedFeature = null;
$feature = Feature::with('template')->find($featureId);
if (!$feature) return;
+8
View File
@@ -30,4 +30,12 @@ class Phase extends Model
{
return $this->hasOne(Layer::class)->latestOfMany();
}
/**
* Get all features across all layers of this phase.
*/
public function features()
{
return $this->hasManyThrough(Feature::class, Layer::class);
}
}