Files
sistema-abogadas-litoral/resources/views/administrador/editar-servicio.blade.php
T
2026-06-24 16:21:44 -03:00

182 lines
9.4 KiB
PHP

<!doctype html>
<html lang="es">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Editar Servicio - Administrador</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 servicio</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/servicios/{{ $servicio->id }}" class="row g-3" enctype="multipart/form-data">
@csrf
@method('PUT')
<div class="col-12 col-md-6">
<label for="titulo" class="form-label">Título</label>
<input id="titulo" name="titulo" type="text" class="form-control" value="{{ old('titulo', $servicio->titulo) }}" required>
</div>
<div class="col-12 col-md-6">
<label for="estado" class="form-label">Estado</label>
<select id="estado" name="estado" class="form-select" required>
<option value="activo" @selected(old('estado', $servicio->estado) === 'activo')>Activo</option>
<option value="inactivo" @selected(old('estado', $servicio->estado) === 'inactivo')>Inactivo</option>
</select>
</div>
<div class="col-12 col-md-6">
<label for="visibleenweb" class="form-label">Visible en web</label>
<select id="visibleenweb" name="visibleenweb" class="form-select" required>
<option value="si" @selected(old('visibleenweb', $servicio->visibleenweb ?? 'si') === 'si')>Si</option>
<option value="no" @selected(old('visibleenweb', $servicio->visibleenweb) === 'no')>No</option>
</select>
</div>
<div class="col-12 col-md-6">
<label for="profesion_id" class="form-label">Profesión</label>
<select id="profesion_id" name="profesion_id" class="form-select" required>
<option value="">Seleccionar profesión</option>
@foreach($profesiones as $profesion)
<option value="{{ $profesion->id }}" @selected((string) old('profesion_id', $servicio->profesion_id) === (string) $profesion->id)>
{{ $profesion->titulo }}
</option>
@endforeach
</select>
</div>
<div class="col-12">
<label for="descripcion" class="form-label">Descripción</label>
<textarea id="descripcion" name="descripcion" class="form-control" rows="4" required>{{ old('descripcion', $servicio->descripcion) }}</textarea>
</div>
<div class="col-12">
<label for="foto" class="form-label">Foto del servicio</label>
@if($servicio->foto)
<div class="mb-2">
<img src="{{ asset($servicio->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 servicio 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>
<div class="col-12 d-flex gap-2 justify-content-end mt-2">
<a href="/administrador/contenido/servicios" class="btn btn-outline-secondary">Cancelar</a>
<button type="submit" class="btn btn-primary">Guardar cambios</button>
</div>
</form>
</div>
</div>
</div>
</div>
</main>
@include('partials.reportar-falla-boton')
</body>
</html>