Files
safekat/ci4/app/Models/Pedidos/PedidoLineaModel.php
jaimejimenezortega 2f1f6f9631 terminado
2024-06-16 02:10:01 +02:00

79 lines
2.4 KiB
PHP

<?php
namespace App\Models\Pedidos;
class PedidoLineaModel extends \App\Models\BaseModel
{
protected $table = "pedidos_linea";
/**
* Whether primary key uses auto increment.
*
* @var bool
*/
protected $useAutoIncrement = true;
const SORTABLE = [
0 => "t1.id",
1 => "t1.estado",
2 => "t1.total_precio",
3 => "t1.total_tirada",
];
protected $allowedFields = [
"pedido_id",
"presupuesto_id",
"ubicacion_id",
"user_created_id",
"user_updated_id",
"created_at",
"updated_at",
];
protected $returnType = "App\Entities\Pedidos\PedidoLineaEntity";
protected $useTimestamps = true;
protected $useSoftDeletes = false;
protected $createdField = "created_at";
protected $updatedField = "updated_at";
public static $labelField = "id";
public function getResource(string $search = "", $estado="")
{
$builder = $this->db
->table($this->table . " t1")
->select(
"t2.id AS id, t2.updated_at AS fecha, t2.fecha_entrega_real AS fecha_entrega,
t4.nombre AS cliente, CONCAT(t5.first_name, ' ', t5.last_name) AS comercial,
t3.titulo AS titulo, t6.nombre AS ubicacion, t3.inc_rei AS inc_rei,
t3.paginas AS paginas, t3.tirada AS tirada, t3.total_aceptado AS total_presupuesto,
t2.estado AS estado"
);
$builder->join("pedidos t2", "t2.id = t1.pedido_id", "left");
$builder->join("presupuestos t3", "t1.presupuesto_id = t3.id", "left");
$builder->join("clientes t4", "t4.id = t3.cliente_id", "left");
$builder->join("users t5", "t5.id = t4.comercial_id", "left");
$builder->join("ubicaciones t6", "t6.id = t1.ubicacion_id", "left");
if($estado != "") {
if($estado == "activo") {
$sql = "t2.estado = 'validacion' OR t2.estado = 'produccion'";
$builder->where($sql);
} else {
$builder->where("t2.estado", $estado);
}
}
// Falta implementar la busqueda por grupos
return empty($search)
? $builder
: $builder
->groupStart()
->like("t1.id", $search)
->orLike("t1.id", $search)
->groupEnd();
}
}