diff --git a/ci4/app/Controllers/Presupuestos/Cosidotapablanda.php b/ci4/app/Controllers/Presupuestos/Cosidotapablanda.php index 38ddd816..41f5c28d 100755 --- a/ci4/app/Controllers/Presupuestos/Cosidotapablanda.php +++ b/ci4/app/Controllers/Presupuestos/Cosidotapablanda.php @@ -383,6 +383,69 @@ class Cosidotapablanda extends \App\Controllers\GoBaseResourceController } // end function edit(...) + /** + * Delete the designated resource object from the model. + * + * @param int $id + * + * @return array an array + */ + public function delete($id = null) + { + if (!empty(static::$pluralObjectNameCc) && !empty(static::$singularObjectNameCc)) { + $objName = mb_strtolower(lang(ucfirst(static::$pluralObjectNameCc).'.'.static::$singularObjectNameCc)); + } else { + $objName = lang('Basic.global.record'); + } + + if (!$this->soft_delete){ + + if (!$this->model->delete($id)) { + return $this->failNotFound(lang('Basic.global.deleteError', [$objName])); + } + } + else{ + $datetime = (new \CodeIgniter\I18n\Time("now")); + $rawResult = $this->model->where('id',$id) + ->set(['deleted_at' => $datetime->format('Y-m-d H:i:s'), + 'is_deleted' => $this->delete_flag]) + ->update(); + if (!$rawResult) { + return $this->failNotFound(lang('Basic.global.deleteError', [$objName])); + } + + } + + // Se borran las lineas de presupuesto + $model = new PresupuestoLineaModel(); + $model->where("presupuesto_id", $id)->delete(); + + // Se borran las direcciones de presupuesto + $model = new PresupuestoDireccionesModel(); + $model->where("presupuesto_id", $id)->delete(); + + // Se borran los servicios de acabado + $model = new PresupuestoAcabadosModel(); + $model->where("presupuesto_id", $id)->delete(); + + // Se borran los servicios de preimpresion + $model = new PresupuestoPreimpresionesModel(); + $model->where("presupuesto_id", $id)->delete(); + + // Se borran los servicios de encuadernacion + $model = new PresupuestoEncuadernacionesModel(); + $model->where("presupuesto_id", $id)->delete(); + + // Se borran los servicios de manipulado + $model = new PresupuestoManipuladosModel(); + $model->where("presupuesto_id", $id)->delete(); + + // $message = lang('Basic.global.deleteSuccess', [$objName]); IMN commented + $message = lang('Basic.global.deleteSuccess', [lang('Basic.global.record')]); + $response = $this->respondDeleted(['id' => $id, 'msg' => $message]); + return $response; + } + public function datatable() { @@ -620,6 +683,27 @@ class Cosidotapablanda extends \App\Controllers\GoBaseResourceController return $this->respond($data); } + else if ($tipo == 'duplicar'){ + $presupuesto_id = $reqData['presupuesto_id'] ?? -1; + $result = $this->duplicarPresupuesto($presupuesto_id); + $newTokenHash = csrf_hash(); + $csrfTokenName = csrf_token(); + if($result['success']){ + $data = [ + 'id' => $result['id'], + $csrfTokenName => $newTokenHash + ]; + return $this->respond($data); + } + else{ + $data = [ + 'error' => $result['message'], + $csrfTokenName => $newTokenHash + ]; + return $this->respond($data); + } + } + $newTokenHash = csrf_hash(); $csrfTokenName = csrf_token(); $data = [ @@ -685,7 +769,7 @@ class Cosidotapablanda extends \App\Controllers\GoBaseResourceController } - public function getCompIntData($uso, $datosPedido, $papel_generico, $gramaje, $isColor, $isHq, $cliente_id, $datosTipolog = null, $a_favor_fibra = false) + private function getCompIntData($uso, $datosPedido, $papel_generico, $gramaje, $isColor, $isHq, $cliente_id, $datosTipolog = null, $a_favor_fibra = false) { $tipo = $isColor ? ($isHq ? 'colorhq' : 'color') : ($isHq ? 'negrohq' : 'negro'); @@ -740,9 +824,63 @@ class Cosidotapablanda extends \App\Controllers\GoBaseResourceController return $lineas; } + private function duplicarPresupuesto($id){ + + try{ + + $presupuesto = $this->model->find($id); + $presupuesto->titulo = $presupuesto->titulo .' - ' . lang('Presupuestos.duplicado'); + $new_id = $this->model->insert($presupuesto); + + $presupuestoAcabadosModel = model('App\Models\Presupuestos\PresupuestoAcabadosModel'); + foreach ($presupuestoAcabadosModel->where('presupuesto_id', $presupuesto->id)->findAll() as $acabado) { + $acabado->presupuesto_id = $new_id; + $presupuestoAcabadosModel->insert($acabado); + } + + $presupuestoEncuadernacionesModel = model('App\Models\Presupuestos\PresupuestoEncuadernacionesModel'); + foreach ($presupuestoEncuadernacionesModel->where('presupuesto_id', $presupuesto->id)->findAll() as $encuadernacion) { + $encuadernacion->presupuesto_id = $new_id; + $presupuestoEncuadernacionesModel->insert($encuadernacion); + } + + $presupuestoManipuladosModel = model('App\Models\Presupuestos\PresupuestoManipuladosModel'); + foreach ($presupuestoManipuladosModel->where('presupuesto_id', $presupuesto->id)->findAll() as $manipulado) { + $manipulado->presupuesto_id = $new_id; + $presupuestoManipuladosModel->insert($manipulado); + } + + $presupuestoPreimpresionesModel = model('App\Models\Presupuestos\PresupuestoPreimpresionesModel'); + foreach ($presupuestoPreimpresionesModel->where('presupuesto_id', $presupuesto->id)->findAll() as $preimpresion) { + $preimpresion->presupuesto_id = $new_id; + $presupuestoPreimpresionesModel->insert($preimpresion); + } + + $presupuestoDireccionesModel = model('App\Models\Presupuestos\PresupuestoDireccionesModel'); + foreach ($presupuestoDireccionesModel->where('presupuesto_id', $presupuesto->id)->findAll() as $direccion) { + $direccion->presupuesto_id = $new_id; + $presupuestoDireccionesModel->insert($direccion); + } + + $presupuestoLineaModel = model('App\Models\Presupuestos\PresupuestoLineaModel'); + $presupuestoLineaModel->duplicateLineasPresupuesto($presupuesto->id, $new_id); + + return [ + 'success' => true, + 'id' => $new_id + ]; + + }catch(\Exception $e){ + return [ + 'success' => false, + 'message' => $e->getMessage() + ]; + } + } - public function getCompIntRotData($datosPedido, $papel_generico, $gramaje, $paginas, $cliente_id, $datosTipolog = null) + + private function getCompIntRotData($datosPedido, $papel_generico, $gramaje, $paginas, $cliente_id, $datosTipolog = null) { $uso = 'interior'; diff --git a/ci4/app/Controllers/Test.php b/ci4/app/Controllers/Test.php index 0938429f..9b7e760b 100755 --- a/ci4/app/Controllers/Test.php +++ b/ci4/app/Controllers/Test.php @@ -6,6 +6,7 @@ use App\Controllers\BaseController; use App\Models\Configuracion\MaquinasTarifasImpresionModel; use App\Models\Configuracion\PapelGenericoModel; use App\Models\Configuracion\MaquinaModel; +use App\Models\Presupuestos\PresupuestoModel; use App\Services\PresupuestoService; class Test extends BaseController @@ -16,23 +17,18 @@ class Test extends BaseController public function index() { - $json_text = '[{"paginas":"150","paginas_impresion":0,"papel":"3","papel_impresion_id":"45","gramaje":"90.00","maquina_id":"33","row_id":"lp_bnhq"},{"paginas":"150","paginas_impresion":0,"papel":"3","papel_impresion_id":"45","gramaje":"90.00","maquina_id":"97","row_id":"lp_colorhq"},{"paginas":"2","paginas_impresion":0,"papel":"5","papel_impresion_id":"49","gramaje":"270.00","maquina_id":"55","row_id":"lp_cubierta"},{"paginas":"4","paginas_impresion":0,"papel":"1","papel_impresion_id":"91","gramaje":"200.00","maquina_id":"55","row_id":"lp_sobrecubierta"}]'; + $presupuestoModel = model('App\Models\Presupuestos\PresupuestoModel'); + $presupuesto = $presupuestoModel->find(44); + + $presupuestoAcabadosModel = model('App\Models\Presupuestos\PresupuestoAcabadosModel'); + echo '
';
- var_dump($this->test_get_tirada_alt(
- tirada: 200,
- merma: 20,
- tipo_impresion_id: 4,
- json_data: $json_text,
- cliente_id: 685,
- ancho: 150,
- alto: 210,
- solapas_cubierta: 0,
- solapas_ancho_cubierta: 0,
- solapas_sobrecubierta: 0,
- solapas_ancho_sobrecubierta: 0,
- lomo: 16.53
- ));
+ $presupuestoLineaModel = model('App\Models\Presupuestos\PresupuestoLineaModel');
+ $presupuestoLineaModel->duplicateLineasPresupuesto(48, 75);
echo '';
+
+
+
}
diff --git a/ci4/app/Entities/Presupuestos/PresupuestoManipuladosEntity copy.php b/ci4/app/Entities/Presupuestos/PresupuestoManipuladosEntity.php
old mode 100755
new mode 100644
similarity index 100%
rename from ci4/app/Entities/Presupuestos/PresupuestoManipuladosEntity copy.php
rename to ci4/app/Entities/Presupuestos/PresupuestoManipuladosEntity.php
diff --git a/ci4/app/Language/en/Presupuestos.php b/ci4/app/Language/en/Presupuestos.php
index 6c0b3f2a..eba24c4a 100755
--- a/ci4/app/Language/en/Presupuestos.php
+++ b/ci4/app/Language/en/Presupuestos.php
@@ -154,7 +154,9 @@ return [
'envios' => 'Shipments',
'cantidad' => 'Quantity',
-
+ 'duplicado' => 'DUPLICATED',
+
+ 'duplicarConTipologias' => 'The budget contains budget lines with typology data. The budget will be duplicated with the same typologies',
'validation' => [
'decimal' => 'The {field} field must contain a decimal number.',
diff --git a/ci4/app/Language/es/Presupuestos.php b/ci4/app/Language/es/Presupuestos.php
index b208a914..2231446b 100755
--- a/ci4/app/Language/es/Presupuestos.php
+++ b/ci4/app/Language/es/Presupuestos.php
@@ -246,6 +246,9 @@ return [
'tiradaMargen' => 'Margen',
'tiradaEnvio' => 'Coste Envío',
'tiradaImpresion' => 'Coste Impresión',
+ 'duplicado' => 'DUPLICADO',
+
+ 'duplicarConTipologias' => 'El presupuesto contiene lineas de presupuesto con datos de tipologías. Se va a duplicar el presupuesto con las mismas tipologías',
'validation' => [
diff --git a/ci4/app/Models/Presupuestos/PresupuestoDireccionesModel.php b/ci4/app/Models/Presupuestos/PresupuestoDireccionesModel.php
index b70c2a3a..398dc0fa 100755
--- a/ci4/app/Models/Presupuestos/PresupuestoDireccionesModel.php
+++ b/ci4/app/Models/Presupuestos/PresupuestoDireccionesModel.php
@@ -47,7 +47,7 @@ class PresupuestoDireccionesModel extends \App\Models\GoBaseModel
"entregaPieCalle",
];
- protected $returnType = "App\Entities\Clientes\ClienteDireccionesEntity";
+ protected $returnType = "App\Entities\Presupuestos\PresupuestoDireccionesEntity";
public static $labelField = "id";
diff --git a/ci4/app/Models/Presupuestos/PresupuestoLineaModel.php b/ci4/app/Models/Presupuestos/PresupuestoLineaModel.php
index 6a93f8f8..a27d5d2a 100755
--- a/ci4/app/Models/Presupuestos/PresupuestoLineaModel.php
+++ b/ci4/app/Models/Presupuestos/PresupuestoLineaModel.php
@@ -411,6 +411,21 @@ class PresupuestoLineaModel extends \App\Models\GoBaseModel
return $builder;
}
+ public function duplicateLineasPresupuesto($presupuesto_id, $new_presupuesto_id)
+ {
+ $lineas = $this->getLineasPresupuesto($presupuesto_id);
+ $lineas = json_decode(json_encode($lineas), true);
+ foreach ($lineas as $linea) {
+ $linea['presupuesto_id'] = $new_presupuesto_id;
+ unset($linea['id']);
+ $this->db
+ ->table($this->table . " t1")
+ ->insert($linea);
+ }
+ }
+
+
+
}
diff --git a/ci4/app/Services/PresupuestoService.php b/ci4/app/Services/PresupuestoService.php
index c85fc822..e2b865e4 100755
--- a/ci4/app/Services/PresupuestoService.php
+++ b/ci4/app/Services/PresupuestoService.php
@@ -196,12 +196,14 @@ class PresupuestoService extends BaseService
$resultado_tarifa = $tarifamodel->getTarifa($maquina->maquina_id, $uso, is_array($tipo) ? 'color' : $tipo);
if($resultado_tarifa == null){
+ /*
$info = [
'maquina_id' => $maquina->maquina_id,
'uso' => $uso,
'tipo' => is_array($tipo) ? 'color' : $tipo
];
log_message("error","No se ha encontrado tarifa para la maquina {maquina_id} y el uso {uso} y el tipo {tipo}", $info);
+ */
return [];
}
else{
diff --git a/ci4/app/Views/themes/_commonPartialsBs/_modalMessageDialog.php b/ci4/app/Views/themes/_commonPartialsBs/_modalMessageDialog.php
new file mode 100644
index 00000000..1594aa27
--- /dev/null
+++ b/ci4/app/Views/themes/_commonPartialsBs/_modalMessageDialog.php
@@ -0,0 +1,36 @@
+= lang("App.login_subtitle") ?>