236 lines
14 KiB
PHP
236 lines
14 KiB
PHP
<!doctype html>
|
|
<html lang="es">
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
<title>Agregar Cliente - 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-4">
|
|
<h1 class="h4 mb-0">Agregar Nuevo Cliente</h1>
|
|
<a href="/profesional/clientes" class="btn btn-outline-secondary btn-sm">Volver</a>
|
|
</div>
|
|
|
|
<div class="row justify-content-center">
|
|
<div class="col-lg-8">
|
|
<div class="card shadow-sm">
|
|
<div class="card-body">
|
|
<form action="/profesional/clientes/crear" method="GET" class="mb-4">
|
|
<label for="dni_consulta" class="form-label">DNI <span class="text-danger">*</span></label>
|
|
<div class="input-group">
|
|
<input type="text" class="form-control @error('dni') is-invalid @enderror" id="dni_consulta" name="dni" value="{{ $dniConsultado ?? '' }}" pattern="[0-9A-Za-z]{7,20}" maxlength="20" title="Números y letras: 7 a 20 caracteres" required>
|
|
<button type="submit" class="btn btn-primary">Verificar DNI</button>
|
|
</div>
|
|
@error('dni')
|
|
<div class="invalid-feedback d-block">{{ $message }}</div>
|
|
@enderror
|
|
</form>
|
|
|
|
@if ($errors->any())
|
|
<div class="alert alert-danger alert-dismissible fade show" role="alert">
|
|
<strong>¡Error!</strong>
|
|
<ul class="mb-0">
|
|
@foreach ($errors->all() as $error)
|
|
<li>{{ $error }}</li>
|
|
@endforeach
|
|
</ul>
|
|
<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>
|
|
</div>
|
|
@endif
|
|
|
|
@if (($estadoDni ?? null) === 'cliente-existente')
|
|
<div class="alert alert-warning mb-0" role="alert">
|
|
Esta persona ya es cliente.
|
|
</div>
|
|
@elseif (($estadoDni ?? null) === 'persona-existente')
|
|
<div class="alert alert-info" role="alert">
|
|
El DNI pertenece a {{ trim(($personaDni?->nombre ?? '') . ' ' . ($personaDni?->apellido ?? '')) }}. Solo se necesita el correo. La contrasena inicial sera el DNI del cliente.
|
|
</div>
|
|
|
|
<form action="/profesional/clientes/store" method="POST">
|
|
@csrf
|
|
<input type="hidden" name="dni" value="{{ $dniConsultado }}">
|
|
|
|
<div class="mb-3">
|
|
<label for="correo" class="form-label">Correo Electrónico <span class="text-danger">*</span></label>
|
|
<input type="email" class="form-control @error('correo') is-invalid @enderror" id="correo" name="correo" value="{{ old('correo') }}" required>
|
|
@error('correo')
|
|
<div class="invalid-feedback">{{ $message }}</div>
|
|
@enderror
|
|
</div>
|
|
|
|
<div class="d-flex gap-2 justify-content-center">
|
|
<button type="submit" class="btn btn-primary">Guardar Cliente</button>
|
|
<a href="/profesional/clientes" class="btn btn-secondary">Cancelar</a>
|
|
</div>
|
|
</form>
|
|
@elseif (($estadoDni ?? null) === 'persona-nueva')
|
|
<div class="alert alert-info" role="alert">
|
|
No existe una persona con ese DNI. Complete los datos para crear persona, cliente, credenciales y telefono. La contrasena inicial sera el DNI del cliente.
|
|
</div>
|
|
|
|
<form action="/profesional/clientes/store" method="POST">
|
|
@csrf
|
|
<input type="hidden" name="dni" value="{{ $dniConsultado }}">
|
|
|
|
<div class="row mb-3">
|
|
<div class="col-md-6">
|
|
<label for="nombre" class="form-label">Nombre <span class="text-danger">*</span></label>
|
|
<input type="text" class="form-control @error('nombre') is-invalid @enderror" id="nombre" name="nombre" value="{{ old('nombre') }}" pattern="[A-Za-zÁÉÍÓÚáéíóúÑñ\s]+" oninput="this.value=this.value.replace(/[^A-Za-zÁÉÍÓÚáéíóúÑñ\s]/g,'')" required>
|
|
@error('nombre')
|
|
<div class="invalid-feedback">{{ $message }}</div>
|
|
@enderror
|
|
</div>
|
|
<div class="col-md-6">
|
|
<label for="apellido" class="form-label">Apellido <span class="text-danger">*</span></label>
|
|
<input type="text" class="form-control @error('apellido') is-invalid @enderror" id="apellido" name="apellido" value="{{ old('apellido') }}" pattern="[A-Za-zÁÉÍÓÚáéíóúÑñ\s]+" oninput="this.value=this.value.replace(/[^A-Za-zÁÉÍÓÚáéíóúÑñ\s]/g,'')" required>
|
|
@error('apellido')
|
|
<div class="invalid-feedback">{{ $message }}</div>
|
|
@enderror
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row mb-3">
|
|
<div class="col-md-6">
|
|
<label for="cuil" class="form-label">CUIL</label>
|
|
<input type="text" class="form-control @error('cuil') is-invalid @enderror" id="cuil" name="cuil" value="{{ old('cuil') }}" inputmode="numeric" pattern="[0-9]+" oninput="this.value=this.value.replace(/\D/g,'')">
|
|
@error('cuil')
|
|
<div class="invalid-feedback">{{ $message }}</div>
|
|
@enderror
|
|
</div>
|
|
<div class="col-md-6">
|
|
<label for="fechanac" class="form-label">Fecha de Nacimiento</label>
|
|
<input type="date" class="form-control @error('fechanac') is-invalid @enderror" id="fechanac" name="fechanac" value="{{ old('fechanac') }}">
|
|
@error('fechanac')
|
|
<div class="invalid-feedback">{{ $message }}</div>
|
|
@enderror
|
|
</div>
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label for="telefono" class="form-label">Teléfono/Celular <span class="text-danger">*</span></label>
|
|
<input type="tel" class="form-control @error('telefono') is-invalid @enderror" id="telefono" name="telefono" value="{{ old('telefono') }}" inputmode="numeric" pattern="[0-9]+" oninput="this.value=this.value.replace(/\D/g,'')" placeholder="Ej: 3512345678" required>
|
|
@error('telefono')
|
|
<div class="invalid-feedback">{{ $message }}</div>
|
|
@enderror
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label for="correo" class="form-label">Correo Electrónico <span class="text-danger">*</span></label>
|
|
<input type="email" class="form-control @error('correo') is-invalid @enderror" id="correo" name="correo" value="{{ old('correo') }}" required>
|
|
@error('correo')
|
|
<div class="invalid-feedback">{{ $message }}</div>
|
|
@enderror
|
|
</div>
|
|
|
|
<div class="d-flex gap-2 justify-content-center">
|
|
<button type="submit" class="btn btn-primary">Guardar Cliente</button>
|
|
<a href="/profesional/clientes" class="btn btn-secondary">Cancelar</a>
|
|
</div>
|
|
</form>
|
|
@endif
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</main>
|
|
@include('partials.reportar-falla-boton')
|
|
</body>
|
|
</html>
|
|
|
|
|
|
|