mirror of
https://git.imnavajas.es/jjimenez/safekat.git
synced 2025-07-25 22:52:08 +00:00
Revisados formularios de crear y editar, con su validacion
This commit is contained in:
@ -18,10 +18,7 @@ class CatalogoLibroModel extends Model
|
||||
protected $allowedFields = [
|
||||
'cliente_id',
|
||||
'proveedor_id',
|
||||
'user_created_id',
|
||||
'user_update_id',
|
||||
'cubierta_archivo',
|
||||
'cubierta_url',
|
||||
'ancho',
|
||||
'alto',
|
||||
'peso',
|
||||
@ -39,33 +36,31 @@ class CatalogoLibroModel extends Model
|
||||
'num_ilustr_color',
|
||||
'num_ilustr_bn',
|
||||
'coleccion',
|
||||
'isk',
|
||||
'isbn',
|
||||
'ean',
|
||||
'editorial',
|
||||
'resumen',
|
||||
'resumen_breve',
|
||||
'sello',
|
||||
'paginas',
|
||||
'tipo_impresion',
|
||||
'solapas_ancho',
|
||||
'cubiertas_ancho',
|
||||
'comentarios',
|
||||
'negro_paginas',
|
||||
'negro_papel',
|
||||
'negro_papel_id',
|
||||
'negro_gramaje',
|
||||
'color_paginas',
|
||||
'color_papel',
|
||||
'color_papel_id',
|
||||
'color_gramaje',
|
||||
'portada_paginas',
|
||||
'portada_papel',
|
||||
'portada_gramaje',
|
||||
'portada_acabado',
|
||||
'cubierta_paginas',
|
||||
'cubierta_papel',
|
||||
'cubierta_papel_id',
|
||||
'cubierta_gramaje',
|
||||
'cubierta_acabado',
|
||||
'encuardenacion',
|
||||
'cubierta_acabado_id',
|
||||
'cubierta_ancho_solapas',
|
||||
'sobrecubierta_paginas',
|
||||
'sobrecubierta_papel_id',
|
||||
'sobrecubierta_gramaje',
|
||||
'sobrecubierta_acabado_id',
|
||||
'sobrecubierta_ancho_solapas',
|
||||
'encuadernacion_id',
|
||||
'ubicacion',
|
||||
];
|
||||
|
||||
@ -77,10 +72,94 @@ class CatalogoLibroModel extends Model
|
||||
protected $deletedField = 'deleted_at';
|
||||
|
||||
// Opcional: reglas de validación
|
||||
protected $validationRules = [];
|
||||
protected $validationRules = [
|
||||
'cliente_id' => 'required|is_natural_no_zero',
|
||||
'titulo' => 'required|string|min_length[2]|max_length[300]',
|
||||
'paginas' => 'required|integer|greater_than[0]',
|
||||
'ancho' => 'required|decimal|greater_than[0]',
|
||||
'alto' => 'required|decimal|greater_than[0]',
|
||||
'tipo_impresion' => 'required|in_list[negro,negrohq,color,colorhq]',
|
||||
'isbn' => 'required|regex_match[/^[\d-]+$/]',
|
||||
'encuadernacion_id' => 'required|is_natural_no_zero',
|
||||
];
|
||||
protected $validationMessages = [];
|
||||
protected $skipValidation = false;
|
||||
|
||||
protected $beforeInsert = ['asignarIsk', 'asignarEan', 'asignarCubiertaUrl'];
|
||||
protected $beforeUpdate = ['asignarEan', 'asignarCubiertaUrl'];
|
||||
|
||||
protected function asignarIsk(array $data): array
|
||||
{
|
||||
$data['data']['isk'] = model('App\Models\Catalogo\IdentificadorIskModel')->newIsk();
|
||||
return $data;
|
||||
}
|
||||
|
||||
protected function asignarEan(array $data): array
|
||||
{
|
||||
if (!empty($data['data']['isbn'])) {
|
||||
$ean = $this->generarEanDesdeIsbn($data['data']['isbn']);
|
||||
|
||||
if ($ean !== null) {
|
||||
$data['data']['ean'] = $ean;
|
||||
}
|
||||
}
|
||||
|
||||
return $data;
|
||||
}
|
||||
|
||||
private function generarEanDesdeIsbn(string $isbn): ?string
|
||||
{
|
||||
// Elimina guiones o espacios y convierte a mayúsculas
|
||||
$isbn = preg_replace('/[^0-9X]/', '', strtoupper($isbn));
|
||||
|
||||
// Si ya es un ISBN-13 válido
|
||||
if (strlen($isbn) === 13 && preg_match('/^97[89][0-9]{10}$/', $isbn)) {
|
||||
return $isbn;
|
||||
}
|
||||
|
||||
// Si es un ISBN-10, lo convertimos a EAN-13
|
||||
if (strlen($isbn) === 10) {
|
||||
$isbnSinDigito = substr($isbn, 0, 9);
|
||||
$eanBase = '978' . $isbnSinDigito;
|
||||
$digitoControl = $this->calcularDigitoControlEan($eanBase);
|
||||
return $eanBase . $digitoControl;
|
||||
}
|
||||
|
||||
return null; // Formato inválido
|
||||
}
|
||||
|
||||
protected function asignarCubiertaUrl(array $data): array
|
||||
{
|
||||
// No sobreescribir si ya hay un archivo manual
|
||||
if (!empty($data['data']['cubierta_archivo'] ?? null)) {
|
||||
return $data;
|
||||
}
|
||||
|
||||
// Usamos el EAN generado
|
||||
$ean = $data['data']['ean'] ?? null;
|
||||
|
||||
if ($ean && preg_match('/^\d{13}$/', $ean)) {
|
||||
$ean0 = substr($ean, 0, 7);
|
||||
$ean12 = substr($ean, 0, 12);
|
||||
$data['data']['cubierta_url'] = "https://static.cegal.es/imagenes/marcadas/$ean0/$ean12.gif";
|
||||
}
|
||||
|
||||
return $data;
|
||||
}
|
||||
|
||||
private function calcularDigitoControlEan(string $eanBase): int
|
||||
{
|
||||
$suma = 0;
|
||||
|
||||
for ($i = 0; $i < 12; $i++) {
|
||||
$digito = (int) $eanBase[$i];
|
||||
$suma += ($i % 2 === 0) ? $digito : $digito * 3;
|
||||
}
|
||||
|
||||
$modulo = $suma % 10;
|
||||
return ($modulo === 0) ? 0 : 10 - $modulo;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
@ -92,21 +171,20 @@ class CatalogoLibroModel extends Model
|
||||
{
|
||||
$builder = $this->db
|
||||
->table($this->table . " t1")
|
||||
->select(
|
||||
"t1.id AS id,
|
||||
t1.titulo AS titulo,
|
||||
t2.nombre AS cliente,
|
||||
t1.titulo AS titulo,
|
||||
t1.num_edic AS edicion,
|
||||
t1.autor AS autor,
|
||||
t1.isbn AS isbn,
|
||||
t1.ean AS ean,
|
||||
t1.paginas AS paginas,
|
||||
t1.cubierta_archivo AS cubierta_archivo,
|
||||
t1.cubierta_url AS portada"
|
||||
)
|
||||
->join('clientes t2', 't1.cliente_id = t2.id');
|
||||
|
||||
->select("
|
||||
t1.id AS id,
|
||||
t1.titulo AS titulo,
|
||||
t2.nombre AS cliente,
|
||||
t1.num_edic AS edicion,
|
||||
t1.autor AS autor,
|
||||
t1.isbn AS isbn,
|
||||
t1.ean AS ean,
|
||||
t1.paginas AS paginas,
|
||||
t1.cubierta_archivo AS cubierta_archivo,
|
||||
t1.cubierta_url AS portada
|
||||
")
|
||||
->join('clientes t2', 't1.cliente_id = t2.id')
|
||||
->where('t1.deleted_at', null);
|
||||
return $builder;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user