Files
2026-06-24 16:20:36 -03:00

201 lines
9.6 KiB
PHP

<!doctype html>
<html lang="es">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Mis Clientes - Profesional</title>
<script>
(function () {
const root = document.documentElement;
root.classList.add('sidebar-nav-pending');
const releasePending = function () {
root.classList.remove('sidebar-nav-pending');
};
const timeoutId = window.setTimeout(releasePending, 1200);
if (document.querySelector('.admin-sidebar')) {
window.clearTimeout(timeoutId);
releasePending();
return;
}
const observer = new MutationObserver(function () {
if (!document.querySelector('.admin-sidebar')) {
return;
}
observer.disconnect();
window.clearTimeout(timeoutId);
releasePending();
});
observer.observe(document.documentElement, {
childList: true,
subtree: true,
});
})();
</script>
<style>
@media (min-width: 992px) {
html.sidebar-nav-pending main {
visibility: hidden;
}
}
</style>
@vite(['resources/css/app.css', 'resources/js/app.js'])
</head>
<body id="top" class="d-flex flex-column min-vh-100 bg-light">
<header class="app-navbar">
<nav class="navbar navbar-expand-lg">
<div class="container">
@php
$nombreSesion = trim((string) session('personal_nombre', 'Profesional'));
$nombreSaludo = $nombreSesion !== '' ? explode(' ', $nombreSesion)[0] : 'Profesional';
@endphp
<a class="navbar-brand d-flex align-items-center gap-2" href="/profesional/dashboard">
<div class="d-flex align-items-center justify-content-center" style="width: 130px; height: 52px;">
<img src="{{ asset('images/logo.png') }}" alt="Logo" class="img-fluid" style="max-height: 70px; width: auto; object-fit: contain;">
</div>
<span class="fw-semibold">¡Hola, {{ $nombreSaludo }}!</span>
</a>
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#menuPrincipal" aria-controls="menuPrincipal" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="menuPrincipal">
<ul class="navbar-nav mx-auto mb-2 mb-lg-0">
<li class="nav-item"><a class="btn app-navbar-link" href="/profesional/dashboard">Mi Agenda</a></li>
<li class="nav-item"><a class="btn app-navbar-link" href="/profesional/clientes">Mis Clientes</a></li>
<li class="nav-item"><a class="btn app-navbar-link" href="/profesional/mis-datos">Mis Datos</a></li>
<li class="nav-item">
<a class="btn app-navbar-link position-relative" href="/profesional/formularios">
Revisar Formularios
@if(($formulariosPendientesCount ?? 0) > 0)
<span class="position-absolute top-0 start-100 translate-middle p-1 bg-danger rounded-circle js-notificaciones-badge">
<span class="visually-hidden">Hay formularios pendientes</span>
</span>
@endif
</a>
</li>
<li class="nav-item">
<a class="btn app-navbar-link position-relative" href="/profesional/notificaciones" data-notificaciones-claves='@json($notificacionesClaves ?? [])'>
Notificaciones
@if(($notificacionesCount ?? 0) > 0)
<span class="position-absolute top-0 start-100 translate-middle p-1 bg-danger rounded-circle js-notificaciones-badge d-none">
<span class="visually-hidden">Hay notificaciones</span>
</span>
@endif
</a>
</li>
</ul>
<a class="btn app-navbar-link" href="/logout">Cerrar Sesion</a>
</div>
</div>
</nav>
</header>
<main class="container py-4 flex-grow-1">
<div class="d-flex justify-content-between align-items-center mb-3">
<h1 class="h4 mb-0">Mis Clientes</h1>
<a href="/profesional/dashboard" class="btn btn-outline-secondary btn-sm">Volver</a>
</div>
<div class="card border shadow-sm mb-3">
<div class="card-body">
<form method="GET" action="/profesional/clientes" class="row g-3 align-items-end">
<div class="col-12 col-md-6">
<label for="q" class="form-label">Buscar cliente</label>
<input id="q" name="q" type="text" class="form-control" value="{{ request('q') }}" placeholder="Nombre, apellido, DNI o correo">
</div>
<div class="col-12 col-md-3">
<label for="estado" class="form-label">Estado</label>
<select id="estado" name="estado" class="form-select">
<option value="">Todos</option>
<option value="activos" @selected(request('estado') === 'activos')>Activos</option>
<option value="inactivos" @selected(request('estado') === 'inactivos')>Inactivos</option>
</select>
</div>
<div class="col-12 col-md-3 d-flex gap-2">
<button type="submit" class="btn btn-primary w-100">Filtrar</button>
<a href="/profesional/clientes" class="btn btn-outline-secondary w-100">Limpiar</a>
</div>
</form>
</div>
</div>
<div class="table-responsive bg-white border rounded shadow-sm">
<table class="table table-striped table-hover mb-0 align-middle">
<thead class="table-light">
<tr>
<th>ID</th>
<th>Nombre</th>
<th>Apellido</th>
<th>DNI</th>
<th>Correo</th>
<th>Estado</th>
<th>Acciones</th>
</tr>
</thead>
<tbody>
@forelse($clientes as $cliente)
@php
$persona = $cliente->persona;
@endphp
<tr>
<td>{{ $cliente->id }}</td>
<td>{{ $persona?->nombre ?? '-' }}</td>
<td>{{ $persona?->apellido ?? '-' }}</td>
<td>{{ $cliente->dni }}</td>
<td>{{ $cliente->correo }}</td>
<td>
@if((int) $cliente->baja_id === 1)
<span class="badge text-bg-success">Activo</span>
@else
<span class="badge text-bg-danger">Inactivo</span>
@endif
</td>
<td>
<div class="d-flex flex-wrap gap-2">
<a href="/profesional/clientes/{{ $cliente->id }}/editar" class="btn btn-sm btn-outline-primary">Editar</a>
<form method="POST" action="/profesional/clientes/{{ $cliente->id }}/baja" onsubmit="return confirm('{{ (int) $cliente->baja_id !== 1 ? '¿Confirmás reactivar a este cliente?' : '¿Confirmás dar de baja a este cliente?' }}');" class="d-inline">
@csrf
<button type="submit" class="btn btn-sm {{ (int) $cliente->baja_id !== 1 ? 'btn-outline-success' : 'btn-outline-danger' }}">
{{ (int) $cliente->baja_id !== 1 ? 'Alta' : 'Baja' }}
</button>
</form>
<a href="/profesional/clientes/{{ $cliente->id }}/documentacion" class="btn btn-sm btn-outline-secondary">Docs</a>
</div>
</td>
</tr>
@empty
<tr>
<td colspan="7" class="text-center text-muted py-4">No hay clientes cargados.</td>
</tr>
@endforelse
</tbody>
</table>
</div>
@if($clientes->hasPages())
<div class="d-flex justify-content-center mt-3">
{{ $clientes->links() }}
</div>
@endif
<div class="mt-3 text-center">
<a href="/profesional/clientes/crear" class="btn btn-primary">Agregar nuevo cliente</a>
</div>
</main>
@include('partials.reportar-falla-boton')
</body>
</html>