Example #1
0
 /**
  * Met à jour le stock de l'article passé en paramètre
  * lorsqu'un client finalise sa commande
  *
  * @param Article $article
  * @param int $qteCommande
  * @throws ErrorSQLException
  */
 public static function updateQteStock(Article $article, $qteCommande)
 {
     $conn = MConnexion::getBdd();
     try {
         $conn->beginTransaction();
         $req = $conn->prepare('UPDATE article SET qteStock = ? WHERE numArt = ?');
         $qte = $article->getQteStock() - $qteCommande < 0 ? 0 : $article->getQteStock() - $qteCommande;
         $req->execute([$qte, $article->getNumArt()]);
         $conn->commit();
         $conn = null;
     } catch (PDOException $e) {
         $conn->rollBack();
         throw new ErrorSQLException($e->getMessage());
     }
 }
Example #2
0
 /**
  * Ajoute un article au panier ou augmente de 1 sa quantité s'il est déjà dans le panier
  *
  * @param Article $unProduit
  * @param int     $qte
  *
  * @throws InvalidArgumentException
  */
 public function ajouterUnProduit(Article $unProduit, $qte)
 {
     if ($this->collProduit->cleExiste($unProduit->getNumArt())) {
         $produitPanier = $this->collProduit->getElement($unProduit->getNumArt());
         if ($unProduit->getQte() + $produitPanier->getQte() > $unProduit->getQteStock()) {
             throw new InvalidArgumentException('Quantité en stock insuffisante');
         }
         $this->augmenterQuantiteProduit($unProduit->getNumArt(), $qte);
     } else {
         $this->collProduit->ajouter($unProduit, $unProduit->getNumArt());
     }
 }