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) { ''+ ''+ ''+ - '
' + + '
' + '
' + "" + - ''+ + ''+ '
'+ '
' + "" + - ''+ + ''+ '
'+ '
' + "" + - ''+ + ''+ '
'+ '
' + "" + - ''+ + ''+ '
'+ '
' + "" + - ''+ + ''+ '
'+ '' + '
' + @@ -117,23 +117,23 @@ function format(d) { '
'+ '
' + "" + - ''+ + ''+ '
'+ '
' + "" + - ''+ + ''+ '
'+ '
' + "" + - ''+ + ''+ '
'+ '
' + "" + - ''+ + ''+ '
'+ '
' + "" + - ''+ + ''+ '
'+ '
' + '' + @@ -153,7 +153,7 @@ function format(d) { ''+ ''+ ''+ - '
' + + '
' + '
' + '' + '
'+ @@ -163,7 +163,7 @@ function format(d) { '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + @@ -204,54 +204,54 @@ function format(d) { ''+ ''+ ''+ - '
' + + '
' + (d.row_id.includes('rot')?'
': '' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + @@ -260,54 +260,54 @@ function format(d) { ''+ ''+ ''+ - '
' + + '
' + (d.row_id.includes('rot')?'
': '' + (d.row_id.includes('rot')?'
': '' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + '
' + '' + - '' + + '' + '
' + (d.row_id.includes('rot')?'
': '' + '
' + '' + - '' + + '' + '
' + '
' + '' + @@ -316,34 +316,34 @@ function format(d) { ''+ ''+ ''+ - '
' + + '
' + (d.row_id.includes('rot')?'
': '' + (d.row_id.includes('rot')?'
': '' + (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){ : 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);