diff --git a/ci4/app/Controllers/Presupuestos/Presupuestocliente.php b/ci4/app/Controllers/Presupuestos/Presupuestocliente.php index 03ff9410..cfd405ad 100755 --- a/ci4/app/Controllers/Presupuestos/Presupuestocliente.php +++ b/ci4/app/Controllers/Presupuestos/Presupuestocliente.php @@ -118,7 +118,9 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController $datosPresupuesto->tapa = 'blanda'; $datosPresupuesto->clienteList = $this->getClienteListItems($clienteId ?? null); + $datosPresupuesto->paginasCuadernillo = [32, 28, 24, 20 , 16]; $presupuestoEntity->estado_id = 1; + $presupuestoEntity->paginas_por_cuadernillo = 32; $this->viewData['formAction'] = 'add'; @@ -185,6 +187,9 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController if($presupuestoEntity->estado_id == 2){ $this->generarResumen($presupuestoEntity); } + + $datosPresupuesto->paginasCuadernillo = [32, 28, 24, 20 , 16]; + $presupuestoEntity->paginas_por_cuadernillo = $this->obtenerPaginasCuadernillo($presupuestoEntity); $this->viewData['formAction'] = 'edit'; @@ -371,6 +376,8 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController $servicios = $reqData['servicios'] ?? []; + $paginasCuadernillo = $reqData['paginasCuadernillo'] ?? null; + $datos_presupuesto = array( 'tirada' => $tirada, 'tamanio' => $tamanio, @@ -378,6 +385,7 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController 'clienteId' => $cliente_id, 'isColor' => $isColor, 'isHq' => $isHq, + 'paginasCuadernillo' => $paginasCuadernillo, 'interior' => array( 'papel_generico' => $papel_generico, @@ -600,6 +608,7 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController $cliente_id = $reqData['datos_libro']['clienteId'] ?? -1; $isColor = intval($reqData['datos_libro']['isColor']) ?? 0; $isHq = intval($reqData['datos_libro']['isHq']) ?? 0; + $paginasCuadernillo = $reqData['datos_libro']['paginasCuadernillo'] ?? null; // Interior $papel_generico = [ @@ -637,6 +646,7 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController 'clienteId' => $cliente_id, 'isColor' => $isColor, 'isHq' => $isHq, + 'paginasCuadernillo' => $paginasCuadernillo, 'interior' => array( 'papel_generico' => $papel_generico, @@ -983,6 +993,12 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController 'precio_unidad' => $servicio->precio_unidad, 'margen' => $servicio->margen, ]; + + // Se comprueba que $servicio tiene paginasCuadernillo + if (isset($servicio->paginas_por_cuadernillo)) { + $data['paginas_por_cuadernillo'] = $servicio->paginas_por_cuadernillo; + } + $model->insert($data); } else if ($tipo == 'extra') { $model = new PresupuestoServiciosExtraModel(); @@ -1086,6 +1102,7 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController $cliente_id = $datos_entrada['clienteId'] ?? -1; $isColor = $datos_entrada['isColor']; $isHq = $datos_entrada['isHq']; + $paginasCuadernillo = $datos_entrada['paginasCuadernillo'] ?? null; // Interior $papel_generico = $datos_entrada['interior']['papel_generico']; @@ -1429,6 +1446,7 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController 'alto' => $datosPedido->alto, 'POD' => $POD, 'solapas' => intval($solapasCubierta) > 0 ? 1 : 0, + 'paginasCuadernillo' => $paginasCuadernillo, ]); $costeServiciosDefecto = 0.0; foreach ($servDefecto as $servicio) { @@ -1996,4 +2014,17 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController $tipo = "" . ($isColor ? "Color" : "Negro") . " " . ($isHq ? "premium" : "estándar"); return $tipo; } + + protected function obtenerPaginasCuadernillo($presupuestoEntity){ + + $model = model('App\Models\Presupuestos\PresupuestoEncuadernacionesModel'); + $lineas = $model->getResource($presupuestoEntity->id)->get()->getResultObject(); + + foreach ($lineas as $linea){ + // check if exist + if($linea->paginas_por_cuadernillo != null) + return $linea->paginas_por_cuadernillo; + } + return 32; // valor por defecto + } } diff --git a/ci4/app/Controllers/Presupuestos/Presupuestoencuadernaciones.php b/ci4/app/Controllers/Presupuestos/Presupuestoencuadernaciones.php index 323fd818..2a617768 100755 --- a/ci4/app/Controllers/Presupuestos/Presupuestoencuadernaciones.php +++ b/ci4/app/Controllers/Presupuestos/Presupuestoencuadernaciones.php @@ -118,6 +118,7 @@ class Presupuestoencuadernaciones extends \App\Controllers\BaseResourceControlle $alto = $reqData['alto'] ?? 0; $POD = $reqData['POD'] ?? 0; + $paginas_cuadernillo = $reqData['paginas_por_cuadernillo'] ?? null; $newTokenHash = csrf_hash(); $csrfTokenName = csrf_token(); @@ -125,7 +126,7 @@ class Presupuestoencuadernaciones extends \App\Controllers\BaseResourceControlle $tarifaModel = model('App\Models\Tarifas\TarifaEncuadernacionModel'); if(is_null($tipo)){ if($tarifaModel->isTarifaPorHoras($tarifa_encuadernacion_id)){ - $values = $this->model->getPrecioTarifaHoras($tarifa_encuadernacion_id, $paginas, $tirada, $proveedor_id, $POD); + $values = $this->model->getPrecioTarifaHoras($tarifa_encuadernacion_id, $paginas, $tirada, $proveedor_id, $POD, $paginas_cuadernillo); }else{ $values = $this->model->getPrecioTarifa($tarifa_encuadernacion_id, $paginas, $tirada, $ancho, $alto, $proveedor_id, $POD); } diff --git a/ci4/app/Entities/Presupuestos/PresupuestoEncuadernacionesEntity.php b/ci4/app/Entities/Presupuestos/PresupuestoEncuadernacionesEntity.php index cb8e4ce4..560fa668 100755 --- a/ci4/app/Entities/Presupuestos/PresupuestoEncuadernacionesEntity.php +++ b/ci4/app/Entities/Presupuestos/PresupuestoEncuadernacionesEntity.php @@ -11,6 +11,7 @@ class PresupuestoEncuadernacionesEntity extends \CodeIgniter\Entity\Entity "tarifa_encuadernado_id" => null, "proveedor_id" => null, "precio_unidad" => null, + "paginas_por_cuadernillo" => null, "tiempo" => null, "precio_total" => null, "margen" => null, @@ -22,6 +23,7 @@ class PresupuestoEncuadernacionesEntity extends \CodeIgniter\Entity\Entity "tarifa_encuadernado_id" => "int", "proveedor_id" => "int", "precio_unidad" => "float", + "paginas_por_cuadernillo" => "int", "tiempo" => "float", "precio_total" => "float", "margen" => "float", diff --git a/ci4/app/Language/es/Presupuestos.php b/ci4/app/Language/es/Presupuestos.php index e61122b3..4904fd8d 100755 --- a/ci4/app/Language/es/Presupuestos.php +++ b/ci4/app/Language/es/Presupuestos.php @@ -247,6 +247,7 @@ return [ 'precio' => 'Precio', 'precioUnidad' => 'Precio unidad', 'tiempo' => 'Tiempo', + "paginasCuadernillo" => "Páginas/cuadernillo", 'precioTotal' => 'Precio total', 'serviciosDefault' => 'Servicios por defecto', 'tarifa' => 'Tarifa', diff --git a/ci4/app/Models/Presupuestos/PresupuestoEncuadernacionesModel.php b/ci4/app/Models/Presupuestos/PresupuestoEncuadernacionesModel.php index 50b45fea..3958b2ec 100755 --- a/ci4/app/Models/Presupuestos/PresupuestoEncuadernacionesModel.php +++ b/ci4/app/Models/Presupuestos/PresupuestoEncuadernacionesModel.php @@ -21,7 +21,7 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel 4 => "t1.precio_total" ]; - protected $allowedFields = ["presupuesto_id", "tarifa_encuadernado_id", "proveedor_id", "nombre", "precio_total", "precio_unidad", "tiempo", "margen"]; + protected $allowedFields = ["presupuesto_id", "tarifa_encuadernado_id", "proveedor_id", "nombre", "precio_total", "precio_unidad", "paginas_por_cuadernillo", "tiempo", "margen"]; protected $returnType = "App\Entities\Presupuestos\PresupuestoEncuadernacionesEntity"; protected $useTimestamps = true; @@ -48,7 +48,7 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel - public function initPresupuesto($tipo_presupuesto, $solapas, $tirada, $paginas, $ancho, $alto, $POD){ + public function initPresupuesto($tipo_presupuesto, $solapas, $tirada, $paginas, $ancho, $alto, $POD, $paginasCuadernillo = 32){ $model = model('App\Models\Presupuestos\TipoPresupuestoServiciosDefectoModel'); $tarifas_procesar = $model->get_tarifas($tipo_presupuesto, $solapas, "encuadernacion"); @@ -60,7 +60,12 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel if($modelTarifa->isTarifaPorHoras($tarifa['tarifa_id'])){ - $tiempo = $this->calcularTiempo(16, $paginas, $tirada); // ID fija. Cambiar cuando se metan maquinas de corte. Velocidad en minutos + if($tarifa['tarifa_id'] == 2 || $tarifa['tarifa_id'] == 14){ // Rústica cosido hilo vegetal y Rústica cosido hilo vegetal solapas + $tiempo = $this->calcularTiempoCosido(16, $paginas, $tirada, $paginasCuadernillo); // ID fija. Cambiar cuando se metan maquinas de corte. Velocidad en minutos + } + else{ + $tiempo = $this->calcularTiempo(16, $paginas, $tirada); // ID fija. Cambiar cuando se metan maquinas de corte. Velocidad en minutos + } $tarifa_value = $modelTarifa->getTarifaPresupuestoEncuadernacionHoras($tarifa['tarifa_id'], $tiempo, $tirada); if (count($tarifa_value)>0) { @@ -76,8 +81,7 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel $result_data[1] = $precio_total; $result_data[2] = $tarifa_proveedor->margen ; // margen - array_push($result_array, - (object)[ + $datos = [ 'tarifa_id'=> $tarifa['tarifa_id'], 'tarifa_nombre'=> $tarifa_proveedor->tarifa_enc_nombre, 'precio_unidad'=> $result_data[0], @@ -86,7 +90,14 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel 'margen' => $result_data[2], 'proveedor' => $tarifa_proveedor->proveedor_nombre, 'proveedor_id' => $tarifa_proveedor->proveedor_id, - ]); + ]; + + if($tarifa['tarifa_id'] == 2 || $tarifa['tarifa_id'] == 14){ + $datos['paginas_por_cuadernillo'] = $paginasCuadernillo; + } + + array_push($result_array, + (object)$datos); } usort($result_array, function($a, $b) { @@ -237,11 +248,16 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel return []; } - public function getPrecioTarifaHoras($tarifa_encuadernacion_id, $paginas, $tirada, $proveedor_id, $POD){ + public function getPrecioTarifaHoras($tarifa_encuadernacion_id, $paginas, $tirada, $proveedor_id, $POD, $paginas_cuadernillo = null){ $modelTarifa = model('App\Models\Tarifas\TarifaEncuadernacionModel'); - $tiempo = $this->calcularTiempo(16, $paginas, $tirada); // ID fija. Cambiar cuando se metan maquinas de corte. Velocidad en minutos + if($tarifa_encuadernacion_id == 2 || $tarifa_encuadernacion_id == 14){ // Rústica cosido hilo vegetal y Rústica cosido hilo vegetal solapas + $tiempo = $this->calcularTiempoCosido(16, $paginas, $tirada, $paginas_cuadernillo); // ID fija. Cambiar cuando se metan maquinas de corte. Velocidad en minutos + } + else{ + $tiempo = $this->calcularTiempo(16, $paginas, $tirada); // ID fija. Cambiar cuando se metan maquinas de corte. Velocidad en minutos + } $tarifa_value = $modelTarifa->getTarifaPresupuestoEncuadernacionHoras($tarifa_encuadernacion_id, $tiempo, $tirada, $proveedor_id); if (count($tarifa_value)>0) { @@ -256,6 +272,7 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel $result_data[0] = floatval($precio_total / $tirada); // Precio/unidad $result_data[1] = $precio_total; $result_data[2] = $tarifa_proveedor->margen ; // margen + array_push($ret_array, (object)[ @@ -263,6 +280,7 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel 'tarifa_nombre'=> $tarifa_proveedor->tarifa_enc_nombre, 'precio_unidad'=> $result_data[0], 'tiempo' => $tiempo, + 'paginas_por_cuadernillo' => $paginas_cuadernillo, 'total'=> $result_data[1], 'margen' => $result_data[2], 'proveedor' => $tarifa_proveedor->proveedor_nombre, @@ -287,6 +305,7 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel 'proveedor' => lang('Presupuestos.no_disponible'), 'precio_unidad'=> 0, 'tiempo' => null, + 'paginas_por_cuadernillo' => null, 'total'=> 0, 'margen' => 0, ]; @@ -355,6 +374,7 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel $builder->where('presupuesto_id', $presupuesto_id); $builder->where('tarifa_encuadernado_id', $tarifa->tarifa_id); $result = $builder->get()->getResultObject(); + $paginas_cuadernillo = $tarifa->paginas_por_cuadernillo??null; if(count($result)>0){ $this->db ->table($this->table . " t1") @@ -365,6 +385,7 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel ->set('tiempo', $tarifa->tiempo) ->set('precio_total', $tarifa->precio_total) ->set('margen', $tarifa->margen) + ->set('paginas_por_cuadernillo', $paginas_cuadernillo) ->update(); @@ -397,7 +418,8 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel ->table($this->table . " t1") ->select( "t1.id AS id, t1.tarifa_encuadernado_id AS tarifa_encuadernado_id, t1.precio_unidad AS precio_unidad, t1.tiempo AS tiempo, - t1.precio_total AS precio_total, t1.margen AS margen, t2.nombre AS nombre, t1.proveedor_id AS proveedor_id, t3.nombre AS proveedor" + t1.precio_total AS precio_total, t1.margen AS margen, t2.nombre AS nombre, t1.proveedor_id AS proveedor_id, t3.nombre AS proveedor, + t1.paginas_por_cuadernillo AS paginas_por_cuadernillo" ); $builder->where('t1.presupuesto_id', $presupuesto_id); @@ -415,4 +437,13 @@ class PresupuestoEncuadernacionesModel extends \App\Models\BaseModel $velocidad = $maquinaModel->getVelocidad($maquina_id); return round($cuadernillos_pedido/($velocidad*60.0), 2); } + + private function calcularTiempoCosido($maquina_id, $paginas, $tirada, $cuadernillos_por_pagina = 32){ + + $maquinaModel = model("App\Models\Configuracion\MaquinaModel"); + $velocidad = $maquinaModel->getVelocidad($maquina_id); // cuadernillos por minuto + $cuadernillos_libro = ceil($paginas/intval($cuadernillos_por_pagina)); + $cuadernillos_pedido = $cuadernillos_libro*$tirada; + return round($cuadernillos_pedido/($velocidad*60.0), 2); // tiempo en segundos + } } diff --git a/ci4/app/Services/PresupuestoClienteService.php b/ci4/app/Services/PresupuestoClienteService.php index d4e91877..ecb1f1ad 100644 --- a/ci4/app/Services/PresupuestoClienteService.php +++ b/ci4/app/Services/PresupuestoClienteService.php @@ -341,9 +341,10 @@ class PresupuestoClienteService extends BaseService $alto = $data['alto'] ?? -1; $POD = $data['POD'] ?? -1; $solapas = $data['solapas'] ?? -1; + $paginasCuadernillo = $data['paginasCuadernillo'] ?? null; $model = model('App\Models\Presupuestos\PresupuestoEncuadernacionesModel'); - $values = $model->initPresupuesto($tipo_impresion_id, $solapas, $tirada, $paginas, $ancho, $alto, $POD); + $values = $model->initPresupuesto($tipo_impresion_id, $solapas, $tirada, $paginas, $ancho, $alto, $POD, $paginasCuadernillo); return $values; } diff --git a/ci4/app/Services/PresupuestoService.php b/ci4/app/Services/PresupuestoService.php index e7d4899e..0fe6e6f3 100755 --- a/ci4/app/Services/PresupuestoService.php +++ b/ci4/app/Services/PresupuestoService.php @@ -1421,12 +1421,14 @@ class PresupuestoService extends BaseService // Si es un presupuesto duplicado hay que buscar el proveedor más barato if($input_data['is_duplicado']){ if($tarifaModel->isTarifaPorHoras($servicio->tarifa_encuadernado_id)){ + $paginas_cuadernillo = $servicio->paginas_por_cuadernillo??null; $nueva_tarifa = $model->getPrecioTarifaHoras( $servicio->tarifa_encuadernado_id, $input_data['paginas'], $input_data['tirada'], -1, - $input_data['POD']); + $input_data['POD'], + $paginas_cuadernillo); }else{ $nueva_tarifa = $model->getPrecioTarifa( $servicio->tarifa_encuadernado_id, @@ -1443,12 +1445,14 @@ class PresupuestoService extends BaseService // con el mismo proveedor else{ if($tarifaModel->isTarifaPorHoras($servicio->tarifa_encuadernado_id)){ + $paginas_cuadernillo = $servicio->paginas_por_cuadernillo??null; $nueva_tarifa = $model->getPrecioTarifaHoras( $servicio->tarifa_encuadernado_id, $input_data['paginas'], $input_data['tirada'], $servicio->proveedor_id, - $input_data['POD']); + $input_data['POD'], + $paginas_cuadernillo); }else{ $nueva_tarifa = $model->getPrecioTarifa( $servicio->tarifa_encuadernado_id, diff --git a/ci4/app/Views/themes/vuexy/form/presupuestos/buscador/viewBuscadorList.php b/ci4/app/Views/themes/vuexy/form/presupuestos/buscador/viewBuscadorList.php index 3615d2e6..f98cf37b 100644 --- a/ci4/app/Views/themes/vuexy/form/presupuestos/buscador/viewBuscadorList.php +++ b/ci4/app/Views/themes/vuexy/form/presupuestos/buscador/viewBuscadorList.php @@ -173,7 +173,7 @@ theTable = $('#tableOfPresupuestos').DataTable({ } ], stateSave: false, - order: [[1, 'asc']], + order: [[1, 'desc']], language: { url: "/themes/vuexy/vendor/libs/datatables-sk/plugins/i18n/es-ES.json" }, diff --git a/ci4/app/Views/themes/vuexy/form/presupuestos/cliente/_disenioLibroItems.php b/ci4/app/Views/themes/vuexy/form/presupuestos/cliente/_disenioLibroItems.php index 442b8694..a646b22d 100644 --- a/ci4/app/Views/themes/vuexy/form/presupuestos/cliente/_disenioLibroItems.php +++ b/ci4/app/Views/themes/vuexy/form/presupuestos/cliente/_disenioLibroItems.php @@ -128,6 +128,21 @@ +