Exemplo n.º 1
0
 /**
  * @name update($pMarche)
  * @param MarcheVO
  * @return integer
  * @desc Insère une nouvelle ligne dans la table, à partir des informations de la CommandeVO en paramètre (l'id sera automatiquement calculé par la BDD)
  */
 public function update($pMarche)
 {
     $lIdMarche = $pMarche->getId();
     $lMarche = new CommandeVO();
     $lMarche->setId($lIdMarche);
     $lMarche->setNumero($pMarche->getNumero());
     $lMarche->setNom($pMarche->getNom());
     $lMarche->setDescription($pMarche->getDescription());
     $lMarche->setDateMarcheDebut($pMarche->getDateMarcheDebut());
     $lMarche->setDateMarcheFin($pMarche->getDateMarcheFin());
     $lMarche->setDateDebutReservation($pMarche->getDateDebutReservation());
     $lMarche->setDateFinReservation($pMarche->getDateFinReservation());
     $lMarche->setArchive($pMarche->getArchive());
     CommandeManager::update($lMarche);
     // Maj des infos de la commande
     $lMarcheActuel = $this->get($lIdMarche);
     if ($lIdMarche != null && $lMarcheActuel->getId() != null) {
         $lStockService = new StockService();
         foreach ($lMarcheActuel->getProduits() as $lProduitActuel) {
             $lMaj = true;
             // Produits Modifiés
             foreach ($pMarche->getProduits() as $lProduitNv) {
                 if ($lProduitActuel->getId() == $lProduitNv->getId()) {
                     $lMaj = false;
                     //Les lots
                     foreach ($lProduitActuel->getLots() as $lLotActuel) {
                         $lMajLot = true;
                         foreach ($lProduitNv->getLots() as $lLotNv) {
                             // Maj Lot
                             if ($lLotActuel->getId() == $lLotNv->getId()) {
                                 $lDcomId = $lLotActuel->getId();
                                 $lMajLot = false;
                                 $lDetailCommande = new DetailCommandeVO();
                                 $lDetailCommande->setId($lLotActuel->getId());
                                 $lDetailCommande->setIdProduit($lProduitActuel->getId());
                                 $lDetailCommande->setTaille($lLotNv->getTaille());
                                 $lDetailCommande->setPrix($lLotNv->getPrix());
                                 DetailCommandeManager::update($lDetailCommande);
                                 // Maj des réservations associées
                                 DetailOperationManager::majTotalReservation($lLotActuel->getId());
                             }
                         }
                         // Supprimer Lot
                         if ($lMajLot) {
                             $lDeleteLot = DetailCommandeManager::select($lLotActuel->getId());
                             $lDeleteLot->setEtat(1);
                             DetailCommandeManager::update($lDeleteLot);
                         }
                     }
                     // Nouveau Lot
                     foreach ($lProduitNv->getLots() as $lLotNv) {
                         $lAjout = true;
                         foreach ($lProduitActuel->getLots() as $lLotActuel) {
                             if ($lLotActuel->getId() == $lLotNv->getId()) {
                                 $lAjout = false;
                             }
                         }
                         if ($lAjout) {
                             $lDetailCommande = new DetailCommandeVO();
                             $lDetailCommande->setIdProduit($lProduitActuel->getId());
                             $lDetailCommande->setTaille($lLotNv->getTaille());
                             $lDetailCommande->setPrix($lLotNv->getPrix());
                             $lDcomId = DetailCommandeManager::insert($lDetailCommande);
                         }
                     }
                     $lResaActuel = GestionCommandeReservationProducteurViewManager::getStockReservationProducteur($lProduitActuel->getIdCompteProducteur(), $lProduitActuel->getId());
                     $lStockActuel = $lStockService->get($lResaActuel[0]->getStoId());
                     // Maj du stock
                     $lStockActuel->setQuantite($lProduitNv->getQteRestante());
                     $lStockActuel->setIdCompte($lProduitNv->getIdProducteur());
                     $lStockActuel->setIdDetailCommande($lDcomId);
                     $lStockService->set($lStockActuel);
                     $lProduit = ProduitManager::select($lProduitActuel->getId());
                     $lProduit->setIdCommande($lIdMarche);
                     $lProduit->setIdNomProduit($lProduitNv->getIdNom());
                     $lProduit->setUniteMesure($lProduitNv->getUnite());
                     $lProduit->setMaxProduitCommande($lProduitNv->getQteMaxCommande());
                     $lProduit->setIdCompteProducteur($lProduitNv->getIdProducteur());
                     // C'est bien le compte il faut changer le nom du champ
                     $lProduit->setType($lProduitNv->getType());
                     ProduitManager::update($lProduit);
                 }
             }
             // Produits supprimés
             if ($lMaj) {
                 // Suppression des lots
                 $lLots = DetailCommandeManager::selectByIdProduit($lProduitActuel->getId());
                 foreach ($lLots as $lLot) {
                     $lLot->setEtat(1);
                     DetailCommandeManager::update($lLot);
                 }
                 $lProduit = new ProduitVO();
                 $lProduit->setId($lProduitActuel->getId());
                 $lProduit->setIdCommande($lIdMarche);
                 $lProduit->setIdNomProduit($lProduitActuel->getIdNom());
                 $lProduit->setUniteMesure($lProduitActuel->getUnite());
                 $lProduit->setMaxProduitCommande($lProduitActuel->getQteMaxCommande());
                 $lProduit->setIdCompteProducteur($lProduitActuel->getIdCompteProducteur());
                 $lProduit->setType($lProduitActuel->getType());
                 $lProduit->setEtat(1);
                 ProduitManager::update($lProduit);
             }
         }
         // Les nouveaux produits
         foreach ($pMarche->getProduits() as $lProduitNv) {
             $lAjout = true;
             foreach ($lMarcheActuel->getProduits() as $lProduitActuel) {
                 if ($lProduitActuel->getId() == $lProduitNv->getId()) {
                     $lAjout = false;
                 }
             }
             if ($lAjout) {
                 // Insertion du produit
                 $lProduit = new ProduitVO();
                 $lProduit->setIdCommande($lIdMarche);
                 $lProduit->setIdNomProduit($lProduitNv->getIdNom());
                 $lProduit->setUniteMesure($lProduitNv->getUnite());
                 $lProduit->setMaxProduitCommande($lProduitNv->getQteMaxCommande());
                 $lProduit->setIdCompteProducteur($lProduitNv->getIdProducteur());
                 // C'est bien le compte il faut changer le nom du champ
                 $lProduit->setStockReservation($lProduitNv->getQteRestante());
                 $lProduit->setStockInitial($lProduitNv->getQteRestante());
                 $lProduit->setType($lProduitNv->getType());
                 $lIdProduit = ProduitManager::insert($lProduit);
                 //Insertion des lots
                 foreach ($lProduitNv->getLots() as $lNouveauLot) {
                     $lDetailCommande = new DetailCommandeVO();
                     $lDetailCommande->setIdProduit($lIdProduit);
                     $lDetailCommande->setTaille($lNouveauLot->getTaille());
                     $lDetailCommande->setPrix($lNouveauLot->getPrix());
                     $lDcomId = DetailCommandeManager::insert($lDetailCommande);
                 }
                 //Insertion du stock -> Met à jour le stock reservation dans le produit
                 $lStock = new StockVO();
                 $lStock->setQuantite($lProduitNv->getQteRestante());
                 $lStock->setType(0);
                 $lStock->setIdCompte($lProduitNv->getIdProducteur());
                 // C'est bien le compte il faut changer le nom du champ
                 $lStock->setIdDetailCommande($lDcomId);
                 $lStockService = new StockService();
                 $lStockService->set($lStock);
             }
         }
     }
     return $lIdMarche;
 }
 /**
  * @name remplirCommande($pId, $pNumero, $pNom, $pDescription, $pDateMarcheDebut, $pDateMarcheFin, $pDateDebutReservation, $pDateFinReservation, $pArchive)
  * @param int(11)
  * @param int(11)
  * @param varchar(100)
  * @param text
  * @param datetime
  * @param datetime
  * @param datetime
  * @param datetime
  * @param tinyint(1)
  * @return CommandeVO
  * @desc Retourne une CommandeVO remplie
  */
 private static function remplirCommande($pId, $pNumero, $pNom, $pDescription, $pDateMarcheDebut, $pDateMarcheFin, $pDateDebutReservation, $pDateFinReservation, $pArchive)
 {
     $lCommande = new CommandeVO();
     $lCommande->setId($pId);
     $lCommande->setNumero($pNumero);
     $lCommande->setNom($pNom);
     $lCommande->setDescription($pDescription);
     $lCommande->setDateMarcheDebut($pDateMarcheDebut);
     $lCommande->setDateMarcheFin($pDateMarcheFin);
     $lCommande->setDateDebutReservation($pDateDebutReservation);
     $lCommande->setDateFinReservation($pDateFinReservation);
     $lCommande->setArchive($pArchive);
     return $lCommande;
 }