From 0813abfb10bc9f9fdaa597cbf409de62075f273e Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Jaime=20Jim=C3=A9nez?= <“jaimejimenezortega@gmail.com”>
Date: Sat, 3 Feb 2024 20:19:48 +0100
Subject: [PATCH] arreglado bug rotativa. Trabajando en bug inkjet
---
.../Presupuestos/Cosidotapablanda.php | 8 +-
ci4/app/Services/PresupuestoService.php | 50 +++---
.../_lineasPresupuestoItems.php | 154 ++++++++++++------
.../presupuestos/cosidotapablanda/previews.js | 9 +-
4 files changed, 141 insertions(+), 80 deletions(-)
diff --git a/ci4/app/Controllers/Presupuestos/Cosidotapablanda.php b/ci4/app/Controllers/Presupuestos/Cosidotapablanda.php
index dc34f8b3..fa7fda96 100755
--- a/ci4/app/Controllers/Presupuestos/Cosidotapablanda.php
+++ b/ci4/app/Controllers/Presupuestos/Cosidotapablanda.php
@@ -483,7 +483,9 @@ class Cosidotapablanda extends \App\Controllers\GoBaseResourceController
array_push($datosTipolog, $data);
}
- $resourceData = $this->getCompIntData($type, $datosPedido, $papel_generico, $gramaje, $isColor, $isHq, $cliente_id, $datosTipolog);
+ $a_favor_fibra = $reqData['a_favor_fibra'] ?? null;
+
+ $resourceData = $this->getCompIntData($type, $datosPedido, $papel_generico, $gramaje, $isColor, $isHq, $cliente_id, $datosTipolog, $a_favor_fibra);
$newTokenHash = csrf_hash();
$csrfTokenName = csrf_token();
@@ -640,7 +642,7 @@ class Cosidotapablanda extends \App\Controllers\GoBaseResourceController
}
- public function getCompIntData($uso, $datosPedido, $papel_generico, $gramaje, $isColor, $isHq, $cliente_id, $datosTipolog = null)
+ public function getCompIntData($uso, $datosPedido, $papel_generico, $gramaje, $isColor, $isHq, $cliente_id, $datosTipolog = null, $a_favor_fibra = null)
{
$tipo = $isColor? ($isHq?'colorhq':'color'): ($isHq?'negrohq':'negro');
@@ -697,7 +699,7 @@ class Cosidotapablanda extends \App\Controllers\GoBaseResourceController
if($maquina->is_inkjet){
$parametrosInkjet = (object)array(
- 'a_favor_fibra' => 1, // este parametro se cambia para comprobar
+ 'a_favor_fibra' => $a_favor_fibra, // este parametro se cambia para comprobar
// en las dos direcciones (menos en rustica fresada que es siempre 1)
'bnPages' => $isColor?0:$datosPedido->paginas,
'colorPages' => $isColor?$datosPedido->paginas:0,
diff --git a/ci4/app/Services/PresupuestoService.php b/ci4/app/Services/PresupuestoService.php
index db6645e3..f77b4d50 100755
--- a/ci4/app/Services/PresupuestoService.php
+++ b/ci4/app/Services/PresupuestoService.php
@@ -45,7 +45,7 @@ class PresupuestoService extends BaseService
if ($uso!='rotativa') {
$ancho_calculo = ($uso=='cubierta' || $uso=='sobrecubierta') ? $datosPedido->anchoExteriores : $datosPedido->ancho;
- $formas = PresupuestoService::getNumFormasPlana($uso, $maquina, $ancho_calculo, $datosPedido->alto, $datosPedido->isCosido);
+ $formas = PresupuestoService::getNumFormasPlana($uso, $maquina, $ancho_calculo, $datosPedido->alto, $datosPedido->isCosido,);
$response['fields'] = $formas;
}
@@ -387,13 +387,18 @@ class PresupuestoService extends BaseService
$data['alto_click'] = $maquina->alto_click;
- $formas = PresupuestoService::getNumFormasRot($maquina, $datosPedido->ancho, $datosPedido->alto, $datosPedido->isCosido);
+ $formas = PresupuestoService::getNumFormasRot(
+ $maquina,
+ $datosPedido->ancho,
+ $datosPedido->alto,
+ $datosPedido->isCosido,
+ $parametrosRotativa->a_favor_fibra);
$data['num_formas'] = $formas;
return $data;
}
- public static function getNumFormasRot($maquina, $ancho, $alto, $isCosido)
+ public static function getNumFormasRot($maquina, $ancho, $alto, $isCosido, $a_favor_fibra = true)
{
// El ancho si es cosido es el doble
$anchoForCalculo = $isCosido ? $ancho * 2 : $ancho;
@@ -403,35 +408,38 @@ class PresupuestoService extends BaseService
$h2_temp = floor($maquina->ancho_impresion / $alto);
// horizontales
- $calles = (new \App\Models\Configuracion\MaquinasCallesModel())->getCallesForMaquina($maquina->maquina_id, $h1_temp);
- // Si son mas de 2 formas
- if(count($calles)>0)
- $h1 = ($h1_temp * $anchoForCalculo + 2 * $calles[0]->externas + ($h1_temp - 1) * $calles[0]->internas < ($maquina->ancho)) ? $h1_temp : $h1_temp - 1;
- else
- $h1 = $h1_temp;
-
- $v1 = floor($maquina->alto_click / $alto);
- $formas_h = $h1 * $v1; //p1
+ if($a_favor_fibra){
+ $calles = (new \App\Models\Configuracion\MaquinasCallesModel())->getCallesForMaquina($maquina->maquina_id, $h1_temp);
+ // Si son mas de 2 formas
+ if(count($calles)>0)
+ $h1 = ($h1_temp * $anchoForCalculo + 2 * $calles[0]->externas + ($h1_temp - 1) * $calles[0]->internas < ($maquina->ancho)) ? $h1_temp : $h1_temp - 1;
+ else
+ $h1 = $h1_temp;
+ $v1 = floor($maquina->alto_click / $alto);
+ $formas_h = $h1 * $v1; //p1
+ }
// verticales
- $calles = (new \App\Models\Configuracion\MaquinasCallesModel())->getCallesForMaquina($maquina->maquina_id, $h2_temp);
- if(count($calles)>0)
- $h2 = ($h2_temp * $anchoForCalculo + 2 * $calles[0]->externas + ($h2_temp - 1) * $calles[0]->internas < ($maquina->ancho)) ? $h2_temp : $h2_temp - 1;
- else
- $h2 = $h2_temp;
- $v2 = floor($maquina->alto_click / $anchoForCalculo);
- $formas_v = $h2 * $v2; //p2
+ else{
+ $calles = (new \App\Models\Configuracion\MaquinasCallesModel())->getCallesForMaquina($maquina->maquina_id, $h2_temp);
+ if(count($calles)>0)
+ $h2 = ($h2_temp * $alto + 2 * $calles[0]->externas + ($h2_temp - 1) * $calles[0]->internas < ($maquina->ancho)) ? $h2_temp : $h2_temp - 1;
+ else
+ $h2 = $h2_temp;
+ $v2 = floor($maquina->alto_click / $anchoForCalculo);
+ $formas_v = $h2 * $v2; //p2
+ }
- $num_formas = ($formas_h > $formas_v) ? $formas_h : $formas_v;
+ $num_formas = $a_favor_fibra ? $formas_h : $formas_v;
$num_formas = $isCosido ? $num_formas * 2 : $num_formas;
// si no hay formas se devuelve n/a
if ($num_formas == 0) {
$response['posicion_formas'] = 'n/a'; // not available
- } else if ($formas_h > $formas_v) {
+ } else if ($a_favor_fibra) {
$response['posicion_formas'] = 'h';
$response['num_formas_horizontales'] = $h1;
$response['num_formas_verticales'] = $v1;
diff --git a/ci4/app/Views/themes/backend/vuexy/form/presupuestos/cosidotapablanda/_lineasPresupuestoItems.php b/ci4/app/Views/themes/backend/vuexy/form/presupuestos/cosidotapablanda/_lineasPresupuestoItems.php
index 41160640..d2991f86 100755
--- a/ci4/app/Views/themes/backend/vuexy/form/presupuestos/cosidotapablanda/_lineasPresupuestoItems.php
+++ b/ci4/app/Views/themes/backend/vuexy/form/presupuestos/cosidotapablanda/_lineasPresupuestoItems.php
@@ -90,26 +90,26 @@ function format(d) {
'
| '+
' | '+
''+
- '' +
+ ' ' +
' ' +
"= lang("Presupuestos.numeroPliegos") ?>" +
- ''+
+ ''+
' '+
' ' +
"= lang("Presupuestos.pliegosPedido") ?>" +
- ''+
+ ''+
' '+
' ' +
"= lang("Presupuestos.precioPliego") ?>" +
- ''+
+ ''+
' '+
' ' +
"= lang("Presupuestos.libro") ?>" +
- ''+
+ ''+
' '+
' ' +
"= lang("Presupuestos.totalPapelPedido") ?>" +
- ''+
+ ''+
' '+
' ' +
' ' +
@@ -117,23 +117,23 @@ function format(d) {
' '+
' ' +
"= lang("Presupuestos.click") ?>" +
- ''+
+ ''+
' '+
' ' +
"= lang("Presupuestos.totalClicks") ?>" +
- ''+
+ ''+
' '+
' ' +
"= lang("Presupuestos.horas") ?>" +
- ''+
+ ''+
' '+
' ' +
"= lang("Presupuestos.precioHora") ?>" +
- ''+
+ ''+
' '+
' ' +
"= lang("Presupuestos.precioImpresion") ?>" +
- ''+
+ ''+
' '+
' ' +
' ' +
@@ -153,7 +153,7 @@ function format(d) {
' | '+
' | '+
' '+
- '' +
+ ' ' +
' ' +
'' +
' '+
@@ -163,7 +163,7 @@ function format(d) {
' ' +
' ' +
'= lang('Presupuestos.saturacion') ?>' +
- '' +
+ '' +
' ' +
' ' +
'= lang('Presupuestos.cobNegro') ?>' +
@@ -204,54 +204,54 @@ function format(d) {
' | '+
' | '+
' '+
- '' +
+ ' ' +
(d.row_id.includes('rot')?' ' +
' | ' +
@@ -260,54 +260,54 @@ function format(d) {
' | '+
' | '+
' '+
- '' +
+ ' ' +
(d.row_id.includes('rot')?' | ' +
@@ -316,34 +316,34 @@ function format(d) {
' | '+
' | '+
' '+
- '' +
+ ' ' +
(d.row_id.includes('rot')?' | ' +
@@ -1173,7 +1173,6 @@ function change_lp_bn_maquina(){
}
-
function change_lp_bn_paginas(){
if( parseInt($('#lp_bn_paginas').val())>0 &&
@@ -1186,6 +1185,23 @@ function change_lp_bn_paginas(){
}
}
+
+function change_lp_bn_aFavorFibra(){
+
+ if( parseInt($('#lp_bn_paginas').val())>0 &&
+ parseInt($('#lp_bn_papel option:selected').val())>0 &&
+ $('#lp_bn_gramaje option:selected').text().length>0 &&
+ parseInt($('#lp_bn_papelImpresion option:selected').val())>0
+ ){
+ var rowData = tableLineasPresupuesto.row('#lp_bn').data()
+ rowData.aFavorFibra = $('#lp_bn_aFavorFibra').prop('checked')
+ tableLineasPresupuesto.row('#lp_bn').data(rowData).draw(false)
+
+ calcularPresupuesto_rot_bn(false, true);
+ }
+}
+
+
function calcularPresupuesto_bn(input_data={}, updatedTipologias = false){
const dimension = getDimensionLibro();
@@ -1219,6 +1235,11 @@ function calcularPresupuesto_bn(input_data={}, updatedTipologias = false){
= csrf_token() ?? "token" ?> : = csrf_token() ?>v
};
+ // Si es inkjet, existe este check
+ if ($('#lp_bn_aFavorFibra').length){
+ datos.a_favor_fibra = $('#lp_bn_aFavorFibra').prop('checked')
+ }
+
if(updatedTipologias){
datos.gota_negro= $('#lp_bn_gotaNegro').val()
datos.gota_color= $('#lp_bn_gotaColor').val()
@@ -1243,9 +1264,13 @@ function calcularPresupuesto_bn(input_data={}, updatedTipologias = false){
value.fields.papel_generico_id === input_data.papel_generico_id &&
value.fields.papel_impresion_id === input_data.papel_impresion_id) {
+ // Si viene del comparador
if(Object.keys(input_data).length == 0){
value.fields.check_papel_total = $('#lp_bn' + '_checkPapel').is(":checked")?1:0
value.fields.check_impresion_total = $('#lp_bn' + '_checkClicks').is(":checked")?1:0
+ // Por defecto en plana: en contra de fibra
+ value.fields.a_favor_fibra = false
+
}
else{
value.fields.check_papel_total = 1
@@ -1353,6 +1378,7 @@ function eventos_lp_bn(isInkjet = false){
if(isInkjet){
$('.lp-bn-tipologia').bind("change", change_lp_bn_tipologia);
$('#lp_bn_defecto').bind("click", por_defecto_lp_bn);
+ $('#lp_bn_aFavorFibra').bind("change", change_lp_bn_aFavorFibra);
}
$('#lp_bn_checkPapel').bind("change", {id_linea: 'lp_bn'}, update_total_linea);
@@ -1806,6 +1832,21 @@ function por_defecto_lp_bnhq(){
}
}
+function change_lp_bnhq_aFavorFibra(){
+
+if( parseInt($('#lp_bnhq_paginas').val())>0 &&
+ parseInt($('#lp_bnhq_papel option:selected').val())>0 &&
+ $('#lp_bnhq_gramaje option:selected').text().length>0 &&
+ parseInt($('#lp_bnhq_papelImpresion option:selected').val())>0
+ ){
+ var rowData = tableLineasPresupuesto.row('#lp_bnhq').data()
+ rowData.aFavorFibra = $('#lp_bnhq_aFavorFibra').prop('checked')
+ tableLineasPresupuesto.row('#lp_bnhq').data(rowData).draw(false)
+
+ calcularPresupuesto_bnhq(false, true);
+}
+}
+
function calcularPresupuesto_bnhq(input_data={}, updatedTipologias = false){
@@ -1849,6 +1890,11 @@ function calcularPresupuesto_bnhq(input_data={}, updatedTipologias = false){
datos.amarillo= $('#lp_bnhq_cobAmarillo').val()
}
+ // Si es inkjet, existe este check
+ if ($('#lp_bnhq_aFavorFibra').length){
+ datos.a_favor_fibra = $('#lp_bnhq_aFavorFibra').prop('checked')
+ }
+
$.ajax({
type: "POST",
url: "/cosidotapablanda/datatable",
@@ -1865,6 +1911,8 @@ function calcularPresupuesto_bnhq(input_data={}, updatedTipologias = false){
if(Object.keys(input_data).length == 0){
value.fields.check_papel_total = $('#lp_bnhq' + '_checkPapel').is(":checked")?1:0
value.fields.check_impresion_total = $('#lp_bnhq' + '_checkClicks').is(":checked")?1:0
+ // Por defecto en plana: en contra de fibra
+ value.fields.a_favor_fibra = false
}
else{
value.fields.check_papel_total = 1
@@ -1946,6 +1994,7 @@ function eventos_lp_bnhq(isInkjet = false){
if(isInkjet){
$('.lp-bnhq-tipologia').bind("change", change_lp_bnhq_tipologia);
$('#lp_bnhq_defecto').bind("click", por_defecto_lp_bnhq);
+ $('#lp_bnhq_aFavorFibra').bind("change", change_lp_bnhq_aFavorFibra);
}
$('#lp_bnhq_checkPapel').bind("change", {id_linea: 'lp_bnhq'}, update_total_linea);
@@ -2792,6 +2841,7 @@ function calcularPresupuesto_rot_color(fromComparador=false, updatedTipologias=f
if(data.lineas.length >0){
// Se cogen los valores de la linea con los datos correspondientes
$.each(data.lineas, function(key, value) {
+ console.log(value.fields.num_formas)
fibra = $('#lp_rot_color_aFavorFibra').prop('checked')
if(fromComparador){
if(value.fields.maquina_id === input_data.maquina_id &&
@@ -3324,16 +3374,16 @@ function fill_lp_from_bbdd(){
switch(lp.tipo){
case 'lp_bn':
- eventos_lp_bn()
+ eventos_lp_bn(lp.maquina_tipo=='inkjet'?true:false)
break
case 'lp_bnhq':
- eventos_lp_bnhq()
+ eventos_lp_bnhq(lp.maquina_tipo=='inkjet'?true:false)
break
case 'lp_color':
- eventos_lp_color()
+ eventos_lp_color(lp.maquina_tipo=='inkjet'?true:false)
break
case 'lp_colorhq':
- eventos_lp_colorhq()
+ eventos_lp_colorhq(lp.maquina_tipo=='inkjet'?true:false)
break
case 'lp_rot_bn':
eventos_lp_rot_bn()
diff --git a/ci4/app/Views/themes/backend/vuexy/form/presupuestos/cosidotapablanda/previews.js b/ci4/app/Views/themes/backend/vuexy/form/presupuestos/cosidotapablanda/previews.js
index 7f80ed00..5d0e36d1 100755
--- a/ci4/app/Views/themes/backend/vuexy/form/presupuestos/cosidotapablanda/previews.js
+++ b/ci4/app/Views/themes/backend/vuexy/form/presupuestos/cosidotapablanda/previews.js
@@ -455,10 +455,11 @@ function getObjetoLP(lpName, _isCosido) {
case 'rot_bn':
case 'rot_color':
- if ((pvObj.anchoImpresion / pvObj.altoForma) > (pvObj.anchoImpresion / pvObj.anchoForma)) {
- let auxReg = pvObj.anchoForma;
- pvObj.anchoForma = pvObj.altoForma;
- pvObj.altoForma = auxReg;
+ // Conditional assignements depending on rotation of the printing shape
+ if (pvObj.orientacionFormas == 'v') {
+ let auxReg = pvObj.altoForma;
+ pvObj.altoForma = pvObj.anchoForma;
+ pvObj.anchoForma = auxReg;
}
$(pvName + '_forma').text(pvObj.anchoForma + "x" + pvObj.altoForma);
pvObj.altoClick = isNaN(parseFloat(rowData.alto_click))?305:parseFloat(rowData.alto_click);
| |