"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(); } }