public function PedidosLineas() { $nItems = 0; $nErrores = 0; $dbLink = mysql_connect("localhost", "root", "albatronic"); $query = "TRUNCATE {$this->dbDestino}.ErpPedidosLineas"; mysql_query($query); $query = "select Codigo,IDArticulo from {$this->dbDestino}.ErpArticulos"; $result = mysql_query($query, $dbLink); while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) { $correspondencia[$row['Codigo']] = $row['IDArticulo']; } $query = "select c.Fecha, l.* from {$this->dbOrigen}.pedidos_cab as c LEFT JOIN {$this->dbOrigen}.pedidos_lineas as l ON c.IDPedido=l.IDPedido where l.IDPedido>0"; $result = mysql_query($query, $dbLink); while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) { $c = new PedidosLineas(); $c->setIDPedido($row['IDPedido']); $c->setIDLinea($row['IDLinea']); $c->setIDArticulo($correspondencia[$row['IDArticulo']]); $c->setDescripcion($row['Descripcion']); $c->setUnidades($row['Unidades']); $c->setUnidadMedida("UMC"); $c->setPrecio($row['Precio']); $c->setDescuento($row['Descuento']); $c->setImporte($row['Importe']); if ($row['Fecha'] >= '2012-09-01') { $c->setIva($this->correspondenciaIva[$row['Iva']]); } else { $c->setIva($row['Iva']); } $c->setUnidadesRecibidas($row['Unidades'] - $row['PteFacturar']); $c->setUnidadesPtesFacturar($row['PteFacturar']); $c->setPrimaryKeyMD5(md5($row['IDLinea'])); if (!$c->create()) { $errores[] = $c->getErrores(); $nErrores++; } else { $nItems++; } } //mysql_close($dbLink); echo "Líneas de Pedido creadas {$nItems}<br/>"; if (count($errores)) { echo "<pre>"; print_r($errores); echo "</pre>"; } }
/** * Crea pedido web en base a lo que hay * en el carrito de la sesion en curso. * * Si ya hubiera un pedido asociado a esa sesion, * lo borra y lo crea de nuevo * * @param integer $idCliente EL id del cliente * @param boolean $avisoRecepcionParcial * @return integer $idPedido */ static function creaPedido($idCliente, $avisoRecepcionParcial = 0) { if ($avisoRecepcionParcial == '') { $avisoRecepcionParcial = 0; } $carrito = new Carrito(); $filtro = "Sesion='{$_SESSION['IdSesion']}'"; $rows = $carrito->cargaCondicion("*", $filtro, "Id ASC"); unset($carrito); $totales = self::getTotales(); $pedido = new PedidosCab(); $pedido->setIdSucursal($_SESSION['usuarioPortal']['SucursalActiva']['Id']); $pedido->setIdUsuario($_SESSION['usuarioPortal']['Id']); $pedido->setIdCliente($idCliente); $pedido->setFecha(date('Y-m-d H:i:s')); $pedido->setNItems($totales['Unidades']); $pedido->setImporte($totales['total']); $pedido->setAvisoRecepcionParcial($avisoRecepcionParcial); $idPedido = $pedido->create(); if ($idPedido > 0) { // Crear las líneas foreach ($rows as $row) { $linea = new PedidosLineas(); $linea->setIdPedido($idPedido); $linea->setIdSucursal($row['IdSucursal']); $linea->setIdDistribuidora($row['IdDistribuidora']); $linea->setIdUsuario($row['IdUsuario']); $linea->setIdCliente($idCliente); $linea->setSku($row['Sku']); $linea->setEan($row['Ean']); $linea->setDescripcion($row['Descripcion']); $linea->setAutor($row['Autor']); $linea->setEditorial($row['Editorial']); $linea->setUrlImagen($row['UrlImagen']); $linea->setUnidades($row['Unidades']); $linea->setPrecio($row['Precio']); $linea->setDescuento($row['Descuento']); $linea->setPvd($row['Pvd']); $linea->setImporte($row['Importe']); $linea->setIva($row['Iva']); $linea->setRecargo($row['Recargo']); $linea->setIdEstado(0); $linea->setIvaIncluido($row['IvaIncluido']); $linea->create(); //print_r($linea->getErrores()); } } return $idPedido; }