mirror of
https://git.imnavajas.es/jjimenez/safekat.git
synced 2025-07-25 22:52:08 +00:00
Merge branch 'main' into feat/tipo_papel_presup_cliente
This commit is contained in:
@ -3686,21 +3686,30 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController
|
||||
public function download_zip()
|
||||
{
|
||||
$presupuesto_id = $this->request->getPost('presupuesto_id');
|
||||
$ot_id = $this->request->getPost('ot_id');
|
||||
|
||||
if (!$presupuesto_id) {
|
||||
return $this->response->setStatusCode(400)->setBody('Presupuesto ID requerido');
|
||||
}
|
||||
|
||||
// Definir prefijo si se recibió un ot_id válido
|
||||
$prefijo = (!empty($ot_id) && is_numeric($ot_id)) ? "OT_{$ot_id}" : null;
|
||||
|
||||
$ftpClient = new \App\Libraries\SafekatFtpClient();
|
||||
try {
|
||||
$zipPath = $ftpClient->downloadZipPresupuesto((int) $presupuesto_id);
|
||||
$zipPath = $ftpClient->downloadZipPresupuesto((int) $presupuesto_id, $prefijo);
|
||||
|
||||
if ($zipPath === null || !file_exists($zipPath)) {
|
||||
return $this->response->setStatusCode(404)->setBody('No se encontraron archivos');
|
||||
}
|
||||
|
||||
$nombreArchivo = $prefijo
|
||||
? "{$prefijo}_PRESUPUESTO_{$presupuesto_id}.zip"
|
||||
: "archivos_presupuesto_{$presupuesto_id}.zip";
|
||||
|
||||
return $this->response
|
||||
->download($zipPath, null) // null = usar nombre original del archivo
|
||||
->setFileName('archivos_presupuesto_' . $presupuesto_id . '.zip');
|
||||
->download($zipPath, null)
|
||||
->setFileName($nombreArchivo);
|
||||
} catch (\Throwable $e) {
|
||||
log_message('error', $e->getMessage());
|
||||
return $this->response->setStatusCode(500)->setBody('Error interno');
|
||||
@ -3708,4 +3717,5 @@ class Presupuestocliente extends \App\Controllers\BaseResourceController
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
@ -1,35 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace App\Controllers\Produccion;
|
||||
use App\Controllers\BaseController;
|
||||
|
||||
|
||||
class Ordenmaquina extends BaseController
|
||||
{
|
||||
function __construct()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public function index()
|
||||
{
|
||||
echo 'Orden maquina';
|
||||
}
|
||||
|
||||
public function delete()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public function add()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public function edit()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@ -1,35 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace App\Controllers\Produccion;
|
||||
use App\Controllers\BaseController;
|
||||
|
||||
|
||||
class Ordentrabajomaquetacion extends BaseController
|
||||
{
|
||||
function __construct()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public function index()
|
||||
{
|
||||
echo 'Orden maquetación';
|
||||
}
|
||||
|
||||
public function delete()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public function add()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public function edit()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@ -1,35 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace App\Controllers\Produccion;
|
||||
use App\Controllers\BaseController;
|
||||
|
||||
|
||||
class Pedidoproduccion extends BaseController
|
||||
{
|
||||
function __construct()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public function index()
|
||||
{
|
||||
echo 'Pedido produccion';
|
||||
}
|
||||
|
||||
public function delete()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public function add()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public function edit()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@ -115,7 +115,7 @@ class SafekatFtpClient
|
||||
return implode('/', [$this->base_dir, 'pedidos_files', $rootIdExtern]);
|
||||
}
|
||||
|
||||
public function downloadZipPresupuesto(int $presupuesto_id): ?string
|
||||
public function downloadZipPresupuesto(int $presupuesto_id, ?string $prefijo = null): ?string
|
||||
{
|
||||
$modelPedidoLinea = model(PedidoLineaModel::class);
|
||||
$model = model(PresupuestoFicheroModel::class);
|
||||
@ -143,8 +143,11 @@ class SafekatFtpClient
|
||||
|
||||
foreach ($files as $file) {
|
||||
$originalName = $file->nombre ?? basename($file->file_path);
|
||||
$localFile = $localTempDir . '/' . $originalName;
|
||||
$prefixedName = $prefijo ? $prefijo . '_' . $originalName : $originalName;
|
||||
|
||||
$localFile = $localTempDir . '/' . $prefixedName;
|
||||
$remoteFile = $remotePath . '/' . basename($file->file_path);
|
||||
|
||||
$this->ftp->get($remoteFile, $localFile);
|
||||
}
|
||||
|
||||
@ -167,4 +170,5 @@ class SafekatFtpClient
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
@ -12,7 +12,7 @@
|
||||
data-bs-parent="#accordionPresupuestoFiles">
|
||||
<div class="accordion-body">
|
||||
<div class="col-12">
|
||||
<div class="dropzone needsclick" id="<?= $id ?>" data-id="<?= $modelId ?>">
|
||||
<div class="dropzone needsclick" id="<?= $id ?>" data-id="<?= $modelId ?>" data-ot-id="<?= $otId ?? '' ?>">
|
||||
|
||||
<div class="dz-message needsclick">
|
||||
Arrastre aquí los ficheros o haga click
|
||||
|
||||
@ -13,92 +13,110 @@
|
||||
<div class="col-xl-12">
|
||||
<div class="border rounded p-4 mb-3 pb-3">
|
||||
|
||||
<!-- Price Details -->
|
||||
<dl class="row mb-0">
|
||||
<dt class="col-5 py-1 fw-normal text-end">Coste papel</dt>
|
||||
<dd class="py-1 col-6 text-end"><span id="totalCostePapel"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
<dt class="col-5 py-1 fw-normal text-end">Margen papel</dt>
|
||||
<dd class="col-3 text-end py-1"><span id="porcentajeMargenPapel"
|
||||
class="autonumeric-resumen-percent"></span></dd>
|
||||
<dd class="col-3 text-end py-1"><span id="margenPapel"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
<div class="d-flex justify-content-between align-items-center mb-4">
|
||||
<h5 class="mb-0">Costes detallados</h5>
|
||||
<button class="btn btn-sm btn-link p-0" type="button" data-bs-toggle="collapse"
|
||||
data-bs-target="#detallesCostes" aria-expanded="true"
|
||||
aria-controls="detallesCostes" title="Mostrar/ocultar detalle de precios">
|
||||
<i class="ti ti-chevron-down"></i>
|
||||
</button>
|
||||
</div>
|
||||
|
||||
<dt class="col-5 fw-normal text-end">
|
||||
<a href="javascript:void(0);" data-bs-toggle="collapse" data-bs-target=".costes-impresion" aria-expanded="false" aria-controls="costes-impresion">
|
||||
<i class="ti ti-list ti-sm mx-2"></i>
|
||||
</a>
|
||||
Coste impresión
|
||||
</dt>
|
||||
<dd class="col-6 text-end py-1"><span id="totalCosteImpresion"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
<!-- Bloque colapsable, sin <div>, solo usando clases -->
|
||||
<dt class="col-5 fw-normal text-end collapse costes-impresion">Coste clicks</dt>
|
||||
<dd class="col-6 text-end py-1 collapse costes-impresion">
|
||||
<span id="totalCosteClicks" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
<div id="detallesCostes" class="collapse">
|
||||
<!-- Price Details -->
|
||||
<dl class="row mb-0">
|
||||
<dt class="col-5 py-1 fw-normal text-end">Coste papel</dt>
|
||||
<dd class="py-1 col-6 text-end"><span id="totalCostePapel"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
<dt class="col-5 py-1 fw-normal text-end">Margen papel</dt>
|
||||
<dd class="col-3 text-end py-1"><span id="porcentajeMargenPapel"
|
||||
class="autonumeric-resumen-percent"></span></dd>
|
||||
<dd class="col-3 text-end py-1"><span id="margenPapel"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
|
||||
<dt class="col-5 fw-normal text-end collapse costes-impresion">Coste horas</dt>
|
||||
<dd class="col-6 text-end py-1 collapse costes-impresion">
|
||||
<span id="totalCosteHoras" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
<dt class="col-5 fw-normal text-end">
|
||||
<a href="javascript:void(0);" data-bs-toggle="collapse"
|
||||
data-bs-target=".costes-impresion" aria-expanded="false"
|
||||
aria-controls="costes-impresion">
|
||||
<i class="ti ti-list ti-sm mx-2"></i>
|
||||
</a>
|
||||
Coste impresión
|
||||
</dt>
|
||||
<dd class="col-6 text-end py-1"><span id="totalCosteImpresion"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
<!-- Bloque colapsable, sin <div>, solo usando clases -->
|
||||
<dt class="col-5 fw-normal text-end collapse costes-impresion">Coste clicks</dt>
|
||||
<dd class="col-6 text-end py-1 collapse costes-impresion">
|
||||
<span id="totalCosteClicks" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
|
||||
<dt class="col-5 fw-normal text-end collapse costes-impresion">Coste tinta</dt>
|
||||
<dd class="col-6 text-end py-1 collapse costes-impresion">
|
||||
<span id="totalCosteTinta" class="autonumeric-resumen-currency" ></span>
|
||||
</dd>
|
||||
<dt class="col-5 fw-normal text-end collapse costes-impresion">Coste horas</dt>
|
||||
<dd class="col-6 text-end py-1 collapse costes-impresion">
|
||||
<span id="totalCosteHoras" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
|
||||
<dt class="col-5 fw-normal text-end collapse costes-impresion">Coste corte</dt>
|
||||
<dd class="col-6 text-end py-1 collapse costes-impresion">
|
||||
<span id="totalCosteCorte" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
<dt class="col-5 py-1 fw-normal text-end">
|
||||
<a href="javascript:void(0);" data-bs-toggle="collapse" data-bs-target=".margen-impresion" aria-expanded="false" aria-controls="margen-impresion">
|
||||
<i class="ti ti-list ti-sm mx-2"></i>
|
||||
</a>
|
||||
Margen impresión
|
||||
</dt>
|
||||
<dd class="col-3 text-end py-1"><span id="porcentajeMargenImpresion"
|
||||
class="autonumeric-resumen-percent"></span></dd>
|
||||
<dd class="col-3 text-end py-1"><span id="margenImpresion"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
<!-- Bloque colapsable, sin <div>, solo usando clases -->
|
||||
<dt class="col-5 fw-normal text-end collapse margen-impresion">Margen clicks</dt>
|
||||
<dd class="col-6 text-end py-1 collapse margen-impresion">
|
||||
<span id="totalMargenClicks" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
<dt class="col-5 fw-normal text-end collapse costes-impresion">Coste tinta</dt>
|
||||
<dd class="col-6 text-end py-1 collapse costes-impresion">
|
||||
<span id="totalCosteTinta" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
|
||||
<dt class="col-5 fw-normal text-end collapse margen-impresion">Margen horas</dt>
|
||||
<dd class="col-6 text-end py-1 collapse margen-impresion">
|
||||
<span id="totalMargenHoras" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
<dt class="col-5 fw-normal text-end collapse costes-impresion">Coste corte</dt>
|
||||
<dd class="col-6 text-end py-1 collapse costes-impresion">
|
||||
<span id="totalCosteCorte" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
<dt class="col-5 py-1 fw-normal text-end">
|
||||
<a href="javascript:void(0);" data-bs-toggle="collapse"
|
||||
data-bs-target=".margen-impresion" aria-expanded="false"
|
||||
aria-controls="margen-impresion">
|
||||
<i class="ti ti-list ti-sm mx-2"></i>
|
||||
</a>
|
||||
Margen impresión
|
||||
</dt>
|
||||
<dd class="col-3 text-end py-1"><span id="porcentajeMargenImpresion"
|
||||
class="autonumeric-resumen-percent"></span></dd>
|
||||
<dd class="col-3 text-end py-1"><span id="margenImpresion"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
<!-- Bloque colapsable, sin <div>, solo usando clases -->
|
||||
<dt class="col-5 fw-normal text-end collapse margen-impresion">Margen clicks</dt>
|
||||
<dd class="col-6 text-end py-1 collapse margen-impresion">
|
||||
<span id="totalMargenClicks" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
|
||||
<dt class="col-5 fw-normal text-end collapse margen-impresion">Margen tinta</dt>
|
||||
<dd class="col-6 text-end py-1 collapse margen-impresion">
|
||||
<span id="totalMargenTinta" class="autonumeric-resumen-currency" ></span>
|
||||
</dd>
|
||||
<dt class="col-5 fw-normal text-end collapse margen-impresion">Margen horas</dt>
|
||||
<dd class="col-6 text-end py-1 collapse margen-impresion">
|
||||
<span id="totalMargenHoras" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
|
||||
<dt class="col-5 fw-normal text-end collapse margen-impresion">Margen corte</dt>
|
||||
<dd class="col-6 text-end py-1 collapse margen-impresion">
|
||||
<span id="totalMargenCorte" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
<dt class="col-5 fw-normal text-end collapse margen-impresion">Margen tinta</dt>
|
||||
<dd class="col-6 text-end py-1 collapse margen-impresion">
|
||||
<span id="totalMargenTinta" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
|
||||
<dt class="col-5 fw-normal text-end collapse margen-impresion">Margen corte</dt>
|
||||
<dd class="col-6 text-end py-1 collapse margen-impresion">
|
||||
<span id="totalMargenCorte" class="autonumeric-resumen-currency"></span>
|
||||
</dd>
|
||||
|
||||
<dt class="col-5 fw-normal text-end">Coste servicios</dt>
|
||||
<dd class="col-6 text-end py-1 "><span id="totalServicios"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
<dt class="col-5 fw-normal text-end">Margen servicios</dt>
|
||||
<dd class="col-3 text-end py-1 "><span id="porcentajeMargenServicios"
|
||||
class="autonumeric-resumen-percent"></span></dd>
|
||||
<dd class="col-3 text-end py-1 "><span id="margenServicios"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
|
||||
<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></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></dd>
|
||||
</dl>
|
||||
|
||||
</div>
|
||||
|
||||
<dt class="col-5 fw-normal text-end">Coste servicios</dt>
|
||||
<dd class="col-6 text-end py-1 "><span id="totalServicios"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
<dt class="col-5 fw-normal text-end">Margen servicios</dt>
|
||||
<dd class="col-3 text-end py-1 "><span id="porcentajeMargenServicios"
|
||||
class="autonumeric-resumen-percent"></span></dd>
|
||||
<dd class="col-3 text-end py-1 "><span id="margenServicios"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
|
||||
<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></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></dd>
|
||||
</dl>
|
||||
|
||||
<hr class="mx-n4">
|
||||
|
||||
@ -111,7 +129,7 @@
|
||||
class="autonumeric-resumen-percent"></span></dd>
|
||||
<dd class="col-3 text-end py-1"><span id="totalMargenes"
|
||||
class="autonumeric-resumen-currency"></span></dd>
|
||||
<dt class="col-5 fw-normal text-end">Total envío base</dt>
|
||||
<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>
|
||||
@ -168,7 +186,8 @@
|
||||
<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">
|
||||
<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>
|
||||
@ -194,15 +213,15 @@
|
||||
</div>
|
||||
</div>
|
||||
<?php /*if ($presupuestoEntity->estado_id == 2): ?>
|
||||
<div class="row">
|
||||
<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 text-center fs-5 autonumeric-resumen-currency" value="" <?php echo ($tipo_impresion_id == 21) ? ' max=80' : '' ?>>
|
||||
</div>
|
||||
</div>
|
||||
<?php endif; */ ?>
|
||||
<div class="row">
|
||||
<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 text-center fs-5 autonumeric-resumen-currency" value="" <?php echo ($tipo_impresion_id == 21) ? ' max=80' : '' ?>>
|
||||
</div>
|
||||
</div>
|
||||
<?php endif; */ ?>
|
||||
<div class="row">
|
||||
<p>
|
||||
<span id="aprobado_by_at"></span>
|
||||
|
||||
@ -1,5 +1,9 @@
|
||||
<div class="row">
|
||||
<div class="col-md-12">
|
||||
<?= view("themes/vuexy/components/dropzone",data: ['id' => 'dropzone-ot-files','modelId' => $presupuesto->id]) ?>
|
||||
<?= view("themes/vuexy/components/dropzone", data: [
|
||||
'id' => 'dropzone-ot-files',
|
||||
'modelId' => $presupuesto->id,
|
||||
'otId' => $ot->id
|
||||
]) ?>
|
||||
</div><!--//.col -->
|
||||
</div><!--//.row -->
|
||||
Reference in New Issue
Block a user