terminada modificacion

This commit is contained in:
2025-04-04 17:03:08 +02:00
parent a0cb703991
commit cddf64b025
9 changed files with 129 additions and 58 deletions

View File

@ -239,7 +239,13 @@ class Presupuestoadmin extends \App\Controllers\BaseResourceController
if(isset($sanitizedData['total_aceptado_revisado']) && $sanitizedData['total_aceptado_revisado'] != 0
&& $sanitizedData['total_aceptado_revisado'] != null && $sanitizedData['total_aceptado_revisado'] != ""){
$sanitizedData['aprobado_at'] = $sanitizedData['updated_at'];
$sanitizedData['aprobado_by'] = $sanitizedData['user_updated_id'];
$sanitizedData['aprobado_user_id'] = $sanitizedData['user_updated_id'];
}
if ($presupuestoEntity->estado_id == 1 && isset($postData['confirmar']) && $postData['confirmar'] == 1) {
$sanitizedData['aprobado_at'] = $sanitizedData['updated_at'];
$sanitizedData['aprobado_user_id'] = $sanitizedData['user_updated_id'];
$sanitizedData['total_aceptado_revisado'] = $sanitizedData['total_presupuesto'];
}
if ($this->request->getPost('is_duplicado') == null) {
@ -638,8 +644,9 @@ class Presupuestoadmin extends \App\Controllers\BaseResourceController
$data['resumen']['total_factor_ponderado'] = is_numeric($presupuesto->total_factor_ponderado) ? $presupuesto->total_factor_ponderado : 0;
$data['total_aceptado_revisado'] = $presupuesto->total_aceptado_revisado;
$data['aprobado_by_at'] = ($presupuesto->aprobado_user_id != null)?model('App\Models\UserModel')->getFullName($presupuesto->aprobado_user_id) . ', '
. date('d/m/Y', strtotime($presupuesto->aprobado_at)):'';
$data['aprobado_by_at'] = ($presupuesto->aprobado_user_id != null)?
model('App\Models\UserModel')->getFullName($presupuesto->aprobado_user_id) . ', '
. date('d/m/Y H:i:s', strtotime($presupuesto->aprobado_at)):'';
$data['resumen']['iva_reducido'] = $presupuesto->iva_reducido;

View File

@ -100,6 +100,7 @@ class PresupuestoEntity extends \CodeIgniter\Entity\Entity
"total_factor" => null,
"total_factor_ponderado" => null,
'total_aceptado' => null,
'total_aceptado_revisado' => null,
'iva_reducido' => null,
'excluir_rotativa' => null,
"acabado_cubierta_id" => null,
@ -173,6 +174,7 @@ class PresupuestoEntity extends \CodeIgniter\Entity\Entity
"total_factor" => "?float",
"total_factor_ponderado" => "?float",
'total_aceptado' => "?float",
'total_aceptado_revisado' => "?float",
'iva_reducido' => "?boolean",
'excluir_rotativa' => "?boolean",
"acabado_cubierta_id" => "int",

View File

@ -74,6 +74,7 @@ class PresupuestoDireccionesModel extends \App\Models\BaseModel
$builder->where('t1.presupuesto_id', $presupuesto_id);
$builder->join("lg_paises t2", "t1.pais_id = t2.id", "left");
$builder->orderBy('t1.id', 'DESC');
return empty($search)
? $builder

View File

@ -119,6 +119,7 @@ class PresupuestoModel extends \App\Models\BaseModel
"total_descuento",
"total_descuentoPercent",
"total_presupuesto",
"total_aceptado_revisado",
"total_precio_unidad",
"total_factor",
"total_factor_ponderado",

View File

@ -44,13 +44,13 @@
<dt class="col-5 fw-normal text-end">Coste de envío</dt>
<dd class="col-6 text-end py-1 "><span id="costeEnvios"
class="autonumeric-resumen-currency"></span></sp>
<dt class="col-5 fw-normal text-end">Precio de envío</dt>
<dd class="col-6 text-end py-1 "><span id="precioEnvios"
class="autonumeric-resumen-currency"></span></sp>
class="autonumeric-resumen-currency"></span></dd>
<dt class="col-5 fw-normal text-end">Margen envío</dt>
<dd class="col-6 text-end py-1 "><span id="margenEnvios"
class="autonumeric-resumen-currency"></span></sp>
class="autonumeric-resumen-currency"></span></dd>
<dt class="col-5 fw-normal text-end">Total envío base</dt>
<dd class="col-6 text-end py-1 "><span id="precioEnvios"
class="autonumeric-resumen-currency"></span></dd>
</dl>
<hr class="mx-n4">
@ -69,7 +69,7 @@
<hr class="mx-n4">
<dl class="row mb-0">
<dt class="col-5 fw-normal text-end">Total</dt>
<dt class="col-5 fw-normal text-end">Total antes de descuento</dt>
<dd class="col-6 text-end"><span id="totalAntesDescuento"
class="autonumeric-resumen-currency"></span></span>
<dt class="col-5 py-1 fw-normal text-end">Descuento (%)</dt>
@ -118,28 +118,41 @@
<div class="col-xl-12 mt-3">
<div class="card border border-secondary-subtle rounded-3">
<div class="card-body">
<div id="div_ajustar_error" class="alert alert-danger d-flex align-items-baseline d-none" role="alert">
<span class="alert-icon alert-icon-lg text-primary me-2">
<i class="ti ti-ban ti-sm"></i>
</span>
<div class="d-flex flex-column ps-1">
<h5 id="error_recalcular_margen" class="alert-heading mb-2"></h5>
</div>
</div>
<div class="row">
<p>El total aceptado y revisado tiene que ser mayor que total costes + precio de envío
</p>
</div>
<div class="row">
<div class="col-sm-6 mb-md-0 mb-2">
<label for="total_aceptado_revisado" class="form-label">Total aceptado y
revisado</label>
<input <?= ($presupuestoEntity->estado_id == 2)? "disabled":"" ?> type="text" class="autonumeric-currency form-control text-center fs-5"
id="total_aceptado_revisado">
<input <?= ($presupuestoEntity->estado_id == 2) ? "disabled" : "" ?> type="text"
class="autonumeric-currency form-control text-center fs-5"
id="total_aceptado_revisado"></input>
</div>
<div class="col-sm-6 d-flex align-items-end mb-md-0 mb-2">
<button type="button" id="btn_aceptar_revisado"
<button type="button" id="btn_ajustar_revisado"
class="btn btn-primary w-100">Ajustar</button>
</div>
</div>
<?php if ($presupuestoEntity->estado_id == 2): ?>
<?php /*if ($presupuestoEntity->estado_id == 2): ?>
<div class="row">
<div class="mb-1">
<div class="col-sm-6 mb-1">
<label for="totalAceptado"
class="form-label"><?= lang('Presupuestos.totalAceptado') ?></label>
<input disabled type="text" id="totalAceptado" name="totalAceptado"
class="form-control autonumeric-resumen-currency" value="" <?php echo ($tipo_impresion_id == 21) ? ' max=80' : '' ?>>
class="form-control text-center fs-5 autonumeric-resumen-currency" value="" <?php echo ($tipo_impresion_id == 21) ? ' max=80' : '' ?>>
</div>
</div>
<?php endif; ?>
<?php endif; */?>
<div class="row">
<p>
<span id="aprobado_by_at"></span>
@ -149,10 +162,6 @@
</div> <!-- //.card-body -->
</div> <!-- //.card -->
</div> <!-- //.col-xl-12 -->
</div> <!-- //.accordion-body -->
</div> <!-- //.accordion-collapse -->
</div> <!-- //.accordion-item -->
</div> <!-- //.accordion -->

View File

@ -68,7 +68,7 @@ class Chat {
}
if (this.chatHistoryBody[0]) {
console.log("History body");
//console.log("History body");
this.scrollbarChatHistory = new PerfectScrollbar(this.chatHistoryBody[0], {
wheelPropagation: false,
suppressScrollX: true,

View File

@ -120,9 +120,28 @@ class PresupuestoAdminEdit {
this.tiradasAlternativas.init();
this.resumen.init();
$('#btn_aceptar_revisado').on('click', function () {
$('#btn_ajustar_revisado').on('click', function () {
this.resumen.updateTotales({ updateLP: true, updateServicios: true, updateEnvio: true });
this.resumen.updateTotales({ updateLP: true, updateServicios: true, updateEnvio: true }, true);
}.bind(this));
$('#total_aceptado_revisado').on('change', function () {
let totalCostes = AutoNumeric.getAutoNumericElement($('#totalCostes')[0]);
let envio_base = AutoNumeric.getAutoNumericElement($('#precioEnvios')[0]);
let autoTotalAceptado = AutoNumeric.getAutoNumericElement($('#total_aceptado_revisado')[0]);
let total_aceptado_revisado = autoTotalAceptado.getNumber();
if (total_aceptado_revisado && total_aceptado_revisado != 0) {
const nuevoTotal = totalCostes.getNumber() + envio_base.getNumber();
if (total_aceptado_revisado < nuevoTotal) {
// Solo usá .set(), no .val() ni .html()
autoTotalAceptado.set(nuevoTotal);
total_aceptado_revisado = nuevoTotal;
}
totalMargenes = total_aceptado_revisado - nuevoTotal;
}
}.bind(this));
if (window.location.href.includes("edit")) {
@ -380,7 +399,8 @@ class PresupuestoAdminEdit {
self.tipo_impresion.val(response.data.tipo_impresion);
self.POD.val(response.data.POD);
$('#total_aceptado_revisado').val(response.data.total_aceptado_revisado);
AutoNumeric.getAutoNumericElement($('#total_aceptado_revisado')[0]).set(response.data.total_aceptado_revisado);
$('#aprobado_by_at').html(response.data.aprobado_by_at);
$('#created_by').html(response.data.created_by);

View File

@ -41,14 +41,13 @@ class Envios {
processing: true,
autoWidth: true,
responsive: true,
order: [[0, "asc"]],
pageLength: 20,
lengthChange: false,
searching: false,
paging: false,
info: false,
scrollX: true,
ordering: false,
columns: [
{ 'data': 'tarifa_id' },
{ 'data': 'cantidad' },
@ -87,10 +86,10 @@ class Envios {
{
orderable: false,
searchable: false,
targets: [$('#tableOfDireccionesEnvio').find("tr:first th").length - 1]
// all columns
targets: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
//targets: [$('#tableOfDireccionesEnvio').find("tr:first th").length - 1]
},
{ "orderData": [0], "targets": 0 },
],
language: {
url: "/themes/vuexy/vendor/libs/datatables-sk/plugins/i18n/es-ES.json"

View File

@ -94,7 +94,7 @@ class Resumen {
async updateTotales(data = {}) {
async updateTotales(data = {}, ajustar = false) {
const self = this;
@ -302,13 +302,40 @@ class Resumen {
let totalMargenes = parseFloat(margenPapel.toFixed(2)) + parseFloat(margenImpresion.toFixed(2)) + parseFloat(margenServicios.toFixed(2)) + parseFloat(margenEnvios.toFixed(2))
let total_aceptado_revisado = AutoNumeric.getAutoNumericElement($('#total_aceptado_revisado')[0]).getNumber()
if(total_aceptado_revisado != '' && total_aceptado_revisado != undefined &&
total_aceptado_revisado != null && total_aceptado_revisado != 0){
if(total_aceptado_revisado < totalCostes){
total_aceptado_revisado = totalCoste ;
let autoTotalAceptado = AutoNumeric.getAutoNumericElement($('#total_aceptado_revisado')[0]);
let total_aceptado_revisado = autoTotalAceptado.getNumber();
if (ajustar) {
if (total_aceptado_revisado && total_aceptado_revisado != 0) {
const nuevoTotal = totalCostes + totalEnvios_base;
if (total_aceptado_revisado < nuevoTotal) {
if($('#total_aceptado')){
$('#div_ajustar_error').removeClass('d-none');
$('#error_recalcular_margen').hide().empty().
html('El presupuesto está confirmado y el total coste + precio de envio es menor que el total aceptado y revisado').
fadeIn("slow", function(){
setTimeout(function(){
$('#div_ajustar_error').addClass('d-none');
}, 5000);
});
}
else{
autoTotalAceptado.set(nuevoTotal);
total_aceptado_revisado = nuevoTotal;
}
}
if(!($('#total_aceptado') && total_aceptado_revisado < nuevoTotal)){
totalMargenes = total_aceptado_revisado - nuevoTotal;
}
}
totalMargenes = parseFloat(total_aceptado_revisado)- totalCostes;
}
let porcentajeMargen = totalCostes + totalMargenes > 0 ? (100 * totalMargenes / (totalCostes + totalMargenes)).toFixed(0) : 0
@ -319,11 +346,10 @@ class Resumen {
if ($('#total_descuentoPercent').val() < 0) {
$('#total_descuentoPercent').val(0)
}
let totalAntesDescuento = totalCostes + totalMargenes + parseFloat(totalEnvios.toFixed(2)) + totalEnvios_base;
let totalAntesDescuento = totalCostes + totalMargenes + totalEnvios_base;
let totalDescuento = totalAntesDescuento * parseInt($('#total_descuentoPercent').val() || 0) / 100
let totalPresupuesto = totalAntesDescuento - totalDescuento; // para el calculo del precio_u solo se tiene en cuenta el base
let precioUnidad = totalPresupuesto / parseInt($('#tirada').val())
totalPresupuesto += totalEnvios;
$('#totalAntesDescuento').html(totalAntesDescuento).val(totalAntesDescuento.toFixed(2))
$('#descuentoTotal').html(totalDescuento).val(totalDescuento.toFixed(2))
@ -381,6 +407,12 @@ class Resumen {
data.total_aceptado = $('#totalDespuesDecuento').val();
}
let autoTotalAceptado = AutoNumeric.getAutoNumericElement($('#total_aceptado_revisado')[0]);
let total_aceptado_revisado = autoTotalAceptado.getNumber();
if (total_aceptado_revisado && total_aceptado_revisado != 0) {
data.total_aceptado_revisado = total_aceptado_revisado;
}
return data;
}