281 lines
15 KiB
PHP
281 lines
15 KiB
PHP
<!doctype html>
|
|
<html lang="es">
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
<title>Editar 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">
|
|
<a class="navbar-brand d-flex align-items-center" href="/administrador/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="app-navbar-greeting ms-2">¡Hola, Administrador!</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="/administrador/profesionales">Profesionales</a></li>
|
|
<li class="nav-item"><a class="btn app-navbar-link" href="/administrador/dashboard">Mis Datos</a></li>
|
|
<li class="nav-item"><a class="btn app-navbar-link" href="/administrador/contenido-web">Contenido</a></li>
|
|
<li class="nav-item"><a class="btn app-navbar-link" href="/administrador/emails">Emails</a></li>
|
|
<li class="nav-item"><a class="btn app-navbar-link" href="/administrador/logs">Logs</a></li>
|
|
<li class="nav-item"><a class="btn app-navbar-link" href="/administrador/fallas">Fallas</a></li>
|
|
<li class="nav-item">
|
|
<a class="btn app-navbar-link position-relative" href="/administrador/bugs">
|
|
Bugs
|
|
@if(($bugsPendientesCount ?? 0) > 0)
|
|
<span class="position-absolute top-0 start-100 translate-middle p-1 bg-danger rounded-circle">
|
|
<span class="visually-hidden">Hay bugs pendientes</span>
|
|
</span>
|
|
@endif
|
|
</a>
|
|
</li>
|
|
<li class="nav-item"><a class="btn app-navbar-link" href="/administrador/backups">Backup</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="row justify-content-center">
|
|
<div class="col-12 col-lg-9">
|
|
<h1 class="h4 mb-3">Editar profesional</h1>
|
|
|
|
@if($errors->any())
|
|
<div class="alert alert-danger" role="alert">
|
|
<ul class="mb-0 ps-3">
|
|
@foreach($errors->all() as $error)
|
|
<li>{{ $error }}</li>
|
|
@endforeach
|
|
</ul>
|
|
</div>
|
|
@endif
|
|
|
|
<div class="card border shadow-sm">
|
|
<div class="card-body">
|
|
<form method="POST" action="/administrador/profesionales/{{ $profesional->id }}" class="row g-3" enctype="multipart/form-data">
|
|
@csrf
|
|
@method('PUT')
|
|
|
|
<div class="col-12">
|
|
<label for="dni" class="form-label">DNI</label>
|
|
<input id="dni" name="dni" type="text" class="form-control" value="{{ old('dni', $profesional->dni) }}" pattern="[0-9A-Za-z]{7,20}" maxlength="20" title="Ingrese entre 7 y 20 caracteres alfanuméricos." required>
|
|
<div class="form-text">Se permiten letras y números.</div>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label for="nombre" class="form-label">Nombre</label>
|
|
<input id="nombre" name="nombre" type="text" class="form-control" value="{{ old('nombre', $profesional->persona?->nombre ?? '') }}" required>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label for="apellido" class="form-label">Apellido</label>
|
|
<input id="apellido" name="apellido" type="text" class="form-control" value="{{ old('apellido', $profesional->persona?->apellido ?? '') }}" required>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label for="cuil" class="form-label">CUIL</label>
|
|
<input id="cuil" name="cuil" type="text" class="form-control" value="{{ old('cuil', $profesional->persona?->cuil ?? '') }}" required>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label for="fechanac" class="form-label">Fecha de nacimiento</label>
|
|
<input id="fechanac" name="fechanac" type="date" class="form-control" value="{{ old('fechanac', $profesional->persona?->fechanac ? \Illuminate\Support\Carbon::parse($profesional->persona->fechanac)->format('Y-m-d') : '') }}" required>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label class="form-label">Usuario credencial</label>
|
|
<input type="text" class="form-control border-danger bg-light" value="{{ $profesional->credencialProfesional?->usuario ?? '' }}" readonly>
|
|
<div class="form-text text-danger">No editable</div>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label class="form-label">Rol credencial</label>
|
|
<input type="text" class="form-control border-danger bg-light" value="{{ $profesional->credencialProfesional?->rol ?? '' }}" readonly>
|
|
<div class="form-text text-danger">No editable</div>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label class="form-label">Estado baja</label>
|
|
<input type="text" class="form-control border-danger bg-light" value="{{ (int) $profesional->baja_id === 1 ? 'Activo' : 'De baja' }}" readonly>
|
|
<div class="form-text text-danger">No editable</div>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label for="correo" class="form-label">Correo</label>
|
|
<input id="correo" name="correo" type="email" class="form-control" value="{{ old('correo', $profesional->correo) }}" required>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label for="foto" class="form-label">Foto del profesional</label>
|
|
<input type="hidden" id="quitar_foto" name="quitar_foto" value="{{ old('quitar_foto', '0') }}">
|
|
@if($profesional->persona?->Foto)
|
|
<div class="mb-2">
|
|
<img src="{{ asset($profesional->persona->Foto->ruta) }}" alt="Foto actual" class="img-thumbnail" style="max-height: 180px; object-fit: cover;">
|
|
<p class="form-text">Foto actual. Si subís una nueva, reemplazará la actual.</p>
|
|
</div>
|
|
@else
|
|
<p class="form-text text-muted">Este profesional no tiene foto cargada.</p>
|
|
@endif
|
|
<input id="foto" name="foto" type="file" class="form-control @error('foto') is-invalid @enderror" accept="image/jpeg,image/png,image/webp">
|
|
@error('foto')
|
|
<div class="invalid-feedback">{{ $message }}</div>
|
|
@enderror
|
|
<div class="mt-2 d-flex align-items-center gap-2">
|
|
<button type="button" id="btn-quitar-foto" class="btn btn-sm btn-outline-danger">Quitar foto</button>
|
|
<span id="quitar-foto-estado" class="small text-muted"></span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label for="matricula" class="form-label">Matrícula</label>
|
|
<input id="matricula" name="matricula" type="text" class="form-control" value="{{ old('matricula', $profesional->matricula) }}" required>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label for="profesion_id" class="form-label">Profesión</label>
|
|
<input type="hidden" id="profesion_id" name="profesion_id" value="{{ (string) $profesional->profesion_id }}">
|
|
<input type="text" class="form-control border-danger bg-light" value="{{ $profesional->profesion?->titulo ?? '-' }}" readonly>
|
|
<div class="form-text text-danger">No editable</div>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label class="form-label d-block">Servicios que ofrece</label>
|
|
@php
|
|
$serviciosSeleccionadosFinal = array_map(
|
|
'strval',
|
|
old('servicio_ids', array_map('strval', $serviciosSeleccionados ?? []))
|
|
);
|
|
@endphp
|
|
<div id="servicios-container" class="d-flex flex-wrap gap-3 border rounded p-3 bg-light">
|
|
@foreach($servicios as $servicio)
|
|
<div class="form-check" data-profesion-id="{{ $servicio->profesion_id }}">
|
|
<input
|
|
class="form-check-input"
|
|
type="checkbox"
|
|
id="servicio_{{ $servicio->id }}"
|
|
name="servicio_ids[]"
|
|
value="{{ $servicio->id }}"
|
|
@checked(in_array((string) $servicio->id, $serviciosSeleccionadosFinal, true))
|
|
>
|
|
<label class="form-check-label" for="servicio_{{ $servicio->id }}">{{ $servicio->titulo }}</label>
|
|
</div>
|
|
@endforeach
|
|
</div>
|
|
<div class="form-text">Solo se muestran servicios de la profesión seleccionada.</div>
|
|
</div>
|
|
|
|
<div class="col-12 d-flex gap-2 justify-content-end mt-2">
|
|
<a href="/administrador/profesionales" class="btn btn-outline-secondary">Cancelar</a>
|
|
<button type="submit" class="btn btn-primary">Guardar cambios</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</main>
|
|
|
|
<script>
|
|
(function () {
|
|
const serviciosContainer = document.getElementById('servicios-container');
|
|
const itemsServicio = Array.from(serviciosContainer.querySelectorAll('[data-profesion-id]'));
|
|
const profesionSelect = document.getElementById('profesion_id');
|
|
const quitarFotoInput = document.getElementById('quitar_foto');
|
|
const quitarFotoBtn = document.getElementById('btn-quitar-foto');
|
|
const quitarFotoEstado = document.getElementById('quitar-foto-estado');
|
|
|
|
const filtrarServicios = () => {
|
|
const profesionId = profesionSelect?.value ?? '';
|
|
|
|
itemsServicio.forEach((item) => {
|
|
const checkbox = item.querySelector('input[type="checkbox"]');
|
|
const visible = item.dataset.profesionId === profesionId;
|
|
|
|
item.hidden = !visible;
|
|
if (checkbox) {
|
|
checkbox.disabled = !visible;
|
|
if (!visible) checkbox.checked = false;
|
|
}
|
|
});
|
|
};
|
|
|
|
filtrarServicios();
|
|
profesionSelect?.addEventListener('change', filtrarServicios);
|
|
|
|
if (quitarFotoInput && quitarFotoBtn && quitarFotoEstado) {
|
|
const syncQuitarFoto = () => {
|
|
const activo = quitarFotoInput.value === '1';
|
|
quitarFotoBtn.classList.toggle('btn-danger', activo);
|
|
quitarFotoBtn.classList.toggle('btn-outline-danger', !activo);
|
|
quitarFotoEstado.textContent = activo ? 'Se quitará la foto al guardar.' : '';
|
|
};
|
|
|
|
quitarFotoBtn.addEventListener('click', () => {
|
|
quitarFotoInput.value = quitarFotoInput.value === '1' ? '0' : '1';
|
|
syncQuitarFoto();
|
|
});
|
|
|
|
syncQuitarFoto();
|
|
}
|
|
})();
|
|
</script>
|
|
@include('partials.reportar-falla-boton')
|
|
</body>
|
|
</html>
|
|
|
|
|
|
|