db ->table($this->table . " t1") ->select( "t1.id AS id, t1.factura_id AS factura_id, t1.pedido_linea_impresion_id AS pedido_linea_impresion_id, t1.pedido_maquetacion_id AS pedido_maquetacion_id, t1.descripcion AS descripcion, t1.cantidad as cantidad, t1.precio_unidad AS precio_unidad, t1.iva AS iva, t1.base AS base, t1.total_iva AS total_iva, t1.total AS total, t1.data AS data, t2.pedido_id AS pedido_id, t3.total_aceptado AS total_aceptado, t4.tirada_flexible AS tirada_flexible, t4.descuento_tirada_flexible AS descuento_tirada_flexible, t6.cantidad AS cantidad_albaran" ) ->join("pedidos_linea t2", "t2.id = t1.pedido_linea_impresion_id", "left") ->join("presupuestos t3", "t3.id = t2.presupuesto_id", "left") ->join("clientes t4", "t4.id = t3.cliente_id", "left") ->join("albaranes t5", "t5.pedido_id = t2.pedido_id", "left") ->join("albaranes_lineas t6", "t6.albaran_id = t5.id", "left") ->where("t1.factura_id", $factura_id) ->where("t1.deleted_at", null); return $builder; } public function addFacturaPedidoLinea($factura_id, $pedido_linea_id, $cantidad) { $data = [ "factura_id" => $factura_id, "pedido_linea_id" => $pedido_linea_id, "cantidad" => $cantidad ]; return $this->db->table("facturas_pedidos_lineas")->insert($data); } public function deleteFacturasLineasPedido($factura_id, $pedido_linea_id, $cantidad){ $this->db->table("facturas_pedidos_lineas") ->where("factura_id", $factura_id) ->where("pedido_linea_id", $pedido_linea_id) ->where("cantidad", $cantidad) ->delete(); } public function updateFacturaPedidoLinea($factura_id, $pedido_linea_id, $cantidad, $cantidad_new) { // Obtener la ID del registro que queremos actualizar $record = $this->db->table("facturas_pedidos_lineas") ->select('id') ->where("factura_id", $factura_id) ->where("pedido_linea_id", $pedido_linea_id) ->where("cantidad", $cantidad) ->limit(1) ->get() ->getRow(); // Si existe el registro if ($record) { $data = [ "cantidad" => $cantidad_new ]; // Actualizar el registro especificado por su ID $this->db->table("facturas_pedidos_lineas") ->where("id", $record->id) ->update($data); } } }