Compare commits

...

1 Commits
master ... dt2

Author SHA1 Message Date
sio
a1d5485025 CorrectionV1 2024-09-26 11:55:44 +02:00
7 changed files with 226 additions and 144 deletions

View File

@ -75,7 +75,7 @@ jlink.additionalmodules=
jlink.additionalparam=
jlink.launcher=true
jlink.launcher.name=MusicAndCo
main.class=Test
main.class=MusicAndCo.Test
manifest.file=manifest.mf
meta.inf.dir=${src.dir}/META-INF
mkdist.disabled=false

90
src/MusicAndCo/Test.java Normal file
View File

@ -0,0 +1,90 @@
package MusicAndCo;
import static java.lang.String.format;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import métiers.Commande;
import métiers.Entreprise;
import métiers.Instrument;
import java.util.Scanner;
/**
*
* @author sio
*/
public class Test {
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
Scanner lectureClavier=new Scanner(System.in);
DateFormat format = new SimpleDateFormat("dd/MM/yyyy");
Date date = new Date();
Entreprise lEntreprise=new Entreprise("MusicAndCo");
Commande laCommande1 = new Commande(1,1,format.format(date));
Commande laCommande2 = new Commande(2,1,format.format(date));
System.out.println("Bienvenue dans ma boutique :" + lEntreprise.getRaisonSociale());
//Première commande
System.out.println("Préparons votre commande :"+laCommande1.toString());
System.out.println("Voici les instruments en stock :");
//ajouter des instruments de l'entreprise à la commande
boolean rep=false;
do {
int ref=menu(lEntreprise); //le menu affiche les instruments
System.out.print("En quelle quantité ?");
int qte=lectureClavier.nextInt();
laCommande1.ajouter(lEntreprise.getLesInstruments().get(ref), qte);
System.out.print("Voulez-vous ajouter un autre instrument à votre commande (oui/non) ?");
String reponse=lectureClavier.next();
rep = "oui".equals(reponse);
}while(rep);
//affecter la commande à l'entreprise si la commande est possible
lEntreprise.ajouterCommande(laCommande1);
System.out.println("Voici votre commande"+lEntreprise.getLesCommandes().get(0));
//--------------------------------------
//créer une autre commande
System.out.println("Voilà l'autre commande :"+laCommande2.toString());
System.out.println("Voici les instruments en stock :");
//ajouter des instruments de l'entreprise à la commande
rep=false;
do {
int ref=menu(lEntreprise);
System.out.print("En quelle quantité ?");
int qte=lectureClavier.nextInt();
laCommande2.ajouter(lEntreprise.getLesInstruments().get(ref), qte);
System.out.print("Voulez-vous ajouter un autre instrument à votre commande (oui/non) ?");
String reponse=lectureClavier.next();
rep = "oui".equals(reponse);
}while(rep);
//affecter la commande à l'entreprise si la commande est possible
lEntreprise.ajouterCommande(laCommande2);
System.out.println("Voici votre commande"+lEntreprise.getLesCommandes().get(1));
//rechercher et afficher une commande
//supprimer une des 2 commandes
//vériffier les stocks après suppression de la commande
}
static int menu(Entreprise uneEnt){
Scanner lectureClavier=new Scanner(System.in);
System.out.println("Choisir un instrument :");
int i=0;
for(Instrument lInst : uneEnt.getLesInstruments()){
i=i+1;
System.out.print(i + "- ");
System.out.println(lInst.toString());
}
System.out.print("Quel instrument voulez-vous ? ");
return lectureClavier.nextInt()-1;
}
}

View File

@ -1,38 +0,0 @@
import métiers.Commande;
import métiers.Entreprise;
import métiers.Instrument;
/*
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Main.java to edit this template
*/
/**
*
* @author sio
*/
public class Test {
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
Entreprise lEntreprise=new Entreprise("MusicAndCo");
Commande laCommande1 = new Commande(1,1,"12/09/2024");
//ajouter des instruments de l'entreprise à la commande
//affecter la commande à l'entreprise si la comamnde est possible
lEntreprise.ajouterCommande(laCommande1);
//créer une autre commande
//rechercher et afficher une commande
//supprimer une des 2 commande
}
}

View File

@ -40,7 +40,8 @@ private final HashMap<Instrument, Integer> lesLignes = new HashMap<>();
//il faut empêcher l'ajout d'une ligne avec une quantité à 0
//bien s'assurer que le stock est suffisant
boolean ajoutOK=false;
if(qte!=0){
if(qte==0) System.out.println("Vous ne pouvez pas commander une quantité 0");
else{
//ajout d'un instrument existant dans la commande, ce sera une mise à jour de la ligne
if (lesLignes.containsKey(unInstrument))//l'instrument existe
{
@ -53,7 +54,7 @@ private final HashMap<Instrument, Integer> lesLignes = new HashMap<>();
lesLignes.remove(unInstrument);
//nouvel ajout
this.ajouter(unInstrument,qte);
System.out.println("Ligne de commande préexistante mise à jour");
}
else //nouvel instrument
{
@ -62,14 +63,17 @@ private final HashMap<Instrument, Integer> lesLignes = new HashMap<>();
int qteDisponible = unInstrument.getQteStock();
if (qteDisponible<qte){
ajoutOK = false;
System.out.println("Ajout impossible, quantité en stock insuffisante");
}else {
ajoutOK = true;
lesLignes.put(unInstrument,qte);
//màj qté stock pour déduire la qté commandée
unInstrument.setQteStock(qteDisponible-qte);
System.out.println("Instrument ajouté à la commande");
}
}
}
return ajoutOK;
}
/**
@ -82,6 +86,12 @@ private final HashMap<Instrument, Integer> lesLignes = new HashMap<>();
boolean suppOK;
if (lesLignes.containsKey(unInstrument) == true){
suppOK = true;
//récupération de la quantité en stock
int oldQte=unInstrument.getQteStock();
//réaffectation dans le stock de la quantité commandée
int qteStock=oldQte+ this.getLesLignes().get(unInstrument);
unInstrument.setQteStock(qteStock);
//suppression ligne commande
lesLignes.remove(unInstrument);
} else {
suppOK = false;
@ -141,5 +151,10 @@ private final HashMap<Instrument, Integer> lesLignes = new HashMap<>();
return Objects.equals(this.dateCom, other.dateCom);
}
@Override
public String toString() {
return " "+noCom+" du vendeur " + noVendeur + ", du " + dateCom + ", contient " + lesLignes + '}';
}
}

View File

@ -23,9 +23,25 @@ public class Entreprise {
Instrument instr1=new Instrument(23,"Piano droit",3, 8300f);
Instrument instr2=new Instrument(54,"Violon Alto",5, 105f);
Instrument instr3=new Instrument(67,"Guitare Classique",8, 575f);
lesInstruments.add(instr3);
lesInstruments.add(instr2);
lesInstruments.add(instr1);
lesInstruments.add(instr2);
lesInstruments.add(instr3);
}
public ArrayList<Commande> getLesCommandes() {
return lesCommandes;
}
public void setLesCommandes(ArrayList<Commande> lesCommandes) {
this.lesCommandes = lesCommandes;
}
public ArrayList<Instrument> getLesInstruments() {
return lesInstruments;
}
public void setLesInstruments(ArrayList<Instrument> lesInstruments) {
this.lesInstruments = lesInstruments;
}
public String getRaisonSociale() {

View File

@ -25,7 +25,7 @@ public class Instrument {
@Override
public String toString() {
return "Instrument{" + "ref=" + ref + ", designation=" + designation + ", qteStock=" + qteStock + ", prix=" + prix + '}';
return designation + ", Stock=" + qteStock + ", prix=" + prix ;
}
public void setRef(int ref) {

View File

@ -86,7 +86,6 @@ public class CommandeTest {
qteAttendu=0;
assertEquals("Test4 quantite", qteAttendu,qteRes);
/*MORGANN*/
System.out.println("Cas5 : mise à 0 quantité commandée d'une ligne existante");
laCommande.ajouter(instr2, 0);