/// <summary> /// Cette methode permet d'ajout ou de modifier une sous famille après avoir cliqué sur le bouton ajouter / modifier /// </summary> /// <param name="sender">object qui envoie l'action </param> /// <param name="e">Evenement envoyé </param> /// <remarks> /// Cette methode vérifie que tous les champs sont saisie par l'utilisateur /// et choisie en fonction de l'attribut <see cref="RefSousFamile"/> si on ajoute ou modifie la sous famille /// puis on ferme la fenetre /// </remarks> private void Button_Ajouter_Modifier_Click(object sender, EventArgs e) { if (String.IsNullOrEmpty(TextBox_NomSousFamille.Text) || String.IsNullOrEmpty(ComboBox_TypeFamille.Text)) { MessageBox.Show(this, "Veillez remplir tous les champs !!!", "Erreur Insertion ", MessageBoxButtons.OK, MessageBoxIcon.Error, MessageBoxDefaultButton.Button1); } else { InterfaceDB_Sous_Famille inter = new InterfaceDB_Sous_Famille(); InterfaceDB_Famille interfam = new InterfaceDB_Famille(); Famille famille = interfam.GetFamille(ComboBox_TypeFamille.Text); string resultat; if (RefSousFamile == -1)//on ajoute { resultat = inter.InsererSousFamille(famille.NomFamille, TextBox_NomSousFamille.Text); } else // on modifie { resultat = inter.ModifierSousFamille(RefSousFamile, famille.RefFamille, TextBox_NomSousFamille.Text); } MessageBox.Show(this, resultat, "Information", MessageBoxButtons.OK, MessageBoxIcon.Information, MessageBoxDefaultButton.Button1); Reussi_ = true; this.Close(); } }
/// <summary> /// Cette methode permet d'ajout ou de modifier un article après avoir cliqué sur le bouton ajouter / modifier /// </summary> /// <param name="sender">object qui envoie l'action </param> /// <param name="e">Evenement envoyé </param> /// <remarks> /// Cette methode vérifie que tous les champs sont saisie par l'utilisateur /// et choisie en fonction de l'attribut <see cref="RefArticle"/> si on ajoute ou modifie l'article /// puis on ferme la fenetre /// </remarks> private void Button_Ajouter_Modifier_Click(object sender, EventArgs e) { if (String.IsNullOrEmpty(TextBox_RefArticle.Text) || String.IsNullOrEmpty(ComboBox_SousFamille.Text) || String.IsNullOrEmpty(ComboBox_Marque.Text) || String.IsNullOrEmpty(TextBox_Description.Text)) { MessageBox.Show(this, "Veillez remplir tous les champs !!!", "Erreur Insertion ", MessageBoxButtons.OK, MessageBoxIcon.Error, MessageBoxDefaultButton.Button1); } else { InterfaceDB_Articles inter = new InterfaceDB_Articles(); InterfaceDB_Sous_Famille intersousfam = new InterfaceDB_Sous_Famille(); InterfaceDB_Marque intermarque = new InterfaceDB_Marque(); string resultat; SousFamille sousfamille = intersousfam.GetSousFamille(ComboBox_SousFamille.Text); Marque marque = intermarque.GetMarque(ComboBox_Marque.Text); if (RefArticle == null) //on ajoute { Article article = new Article(TextBox_RefArticle.Text, TextBox_Description.Text, sousfamille, marque, double.Parse(NumericUpDown_PrixHT.Value.ToString()), Int32.Parse(NumericUpDown_Quantite.Value.ToString())); resultat = inter.InsererArticle(article); } else // on modifie { resultat = inter.ModifierArticle(RefArticle, TextBox_Description.Text, sousfamille.RefSousFamille, marque.RefMarque, double.Parse(NumericUpDown_PrixHT.Value.ToString()), Int32.Parse(NumericUpDown_Quantite.Value.ToString())); } MessageBox.Show(this, resultat, "Information", MessageBoxButtons.OK, MessageBoxIcon.Information, MessageBoxDefaultButton.Button1); Reussi_ = true; this.Close(); } }
/// <summary> /// Cette méthode permet d'initialiser l'interface graphique /// </summary> public void Init() { if (RefSousFamile == -1) { RemplirComboFamille(); } else { // Initialise les champs correspondant à la reférence de la sous famille ( cas d'une modification) InterfaceDB_Sous_Famille inter = new InterfaceDB_Sous_Famille(); SousFamille sousfammille = inter.GetSousFamille(RefSousFamile); TextBox_NomSousFamille.Text = sousfammille.NomSousFamille; Button_Ajouter_Modifier.Text = "Modifier"; RemplirComboFamille(); this.ComboBox_TypeFamille.SelectedIndex = this.ComboBox_TypeFamille.FindString(sousfammille.MaFamille.NomFamille); } }
/// <summary> /// Cette methode permet d'aller chercher dans la base de données Toutes les sous familles et remplir la liste Combobox pour les sous familles /// </summary> public void RemplirComboSousfamille() { InterfaceDB_Sous_Famille inter = new InterfaceDB_Sous_Famille(); int indice = 0; List <SousFamille> liste = inter.getToutesSousFamille(); string[] chaine = new string[liste.Count]; foreach (SousFamille sousfamille in liste) { chaine[indice] = sousfamille.NomSousFamille; indice++; } this.ComboBox_SousFamille.Items.AddRange(chaine); }
/// <summary> /// Cette méthode permet de supprimer une sous famille dans la base de données /// </summary> /// <remarks> /// la suppression est faite que si une ligne est sélectionnée , et un message box est affiché pour demander à l'utilisateur de confirmer la suppression /// on met à jour la liste view des sous familles <see cref="ListView_SousFamille"/> , on change le status de l'application si la suppression à reussi /// </remarks> private void SupprimerSousFamille() { int count = this.ListView_SousFamille.Items.Count; DialogResult reponse = MessageBox.Show("Voulez-vous supprimer cette famille ? ", "Information", MessageBoxButtons.OKCancel, MessageBoxIcon.Information); string resultat; if (reponse == DialogResult.OK) { ListViewItem item = ListView_SousFamille.SelectedItems[0]; int refsousfamille = Int32.Parse(item.SubItems[0].Text); InterfaceDB_Sous_Famille inter = new InterfaceDB_Sous_Famille(); resultat = inter.SupprimerSousFamille(refsousfamille); MessageBox.Show(resultat, "Information", MessageBoxButtons.OK, MessageBoxIcon.Information); MettreJourSousFamilles(); if (count < ListView_SousFamille.Items.Count) { ChangementStatus("Une sous famille supprimée "); } } }
/// <summary> /// Cette methode permet d'aller chercher dans la base de données Toutes les sous familles et remplir la liste View de ces sous familles /// , en indiquant les noms de colonne /// </summary> public void RemplirListeSousFamille() { InterfaceDB_Sous_Famille interSousfamille = new InterfaceDB_Sous_Famille(); int indice = 0; ColumnHeader Crefsousfamille = new ColumnHeader(); Crefsousfamille.Text = "Ref Sous Famille"; Crefsousfamille.Width = 100; ColumnHeader CrefFamille = new ColumnHeader(); CrefFamille.Text = "Famille "; CrefFamille.Width = 150; ColumnHeader Cnomsousfamille = new ColumnHeader(); Cnomsousfamille.Text = "Nom "; Cnomsousfamille.Width = -2; this.ListView_SousFamille.Columns.AddRange(new ColumnHeader[] { Crefsousfamille, CrefFamille, Cnomsousfamille }); List <SousFamille> listeSousfamille = interSousfamille.getToutesSousFamille(); ListViewItem[] listeItem = new ListViewItem[listeSousfamille.Count]; foreach (SousFamille sousfamille in listeSousfamille) { string[] chaine = new string[] { sousfamille.RefSousFamille.ToString(), sousfamille.MaFamille.NomFamille, sousfamille.NomSousFamille }; ListViewItem item = new ListViewItem(chaine); listeItem[indice] = item; indice++; } this.ListView_SousFamille.Items.AddRange(listeItem); }
/// <summary> /// Cette methode permet de lire le contenu du fichier xml et mettre à jour les informations des articles dans la base de données /// </summary> /// <remarks> /// Elle permet de : /// - Ouvre et lit le fichier XML avec <see cref="XmlDocument"/> /// - Pour chaque noeud lu , elle met à jour un article avec les nouveaux éléments d'un fichier /// - si la marque , la famille et la sous famille existent alors l'action est faite directement /// - sinon on cree l'objet puis on met à jour l'article /// - Si l'article n'existe pas avant dans la base de données alors il est crée /// </remarks> private void FileMisejour() { Article articleMisejour; Marque marqueMisejour; Famille familleMisejour; SousFamille sousfamilleMisejour; InterfaceDB_Articles interArticle = new InterfaceDB_Articles(); InterfaceDB_Marque interMarque = new InterfaceDB_Marque(); InterfaceDB_Famille interfamille = new InterfaceDB_Famille(); InterfaceDB_Sous_Famille interSousfamille = new InterfaceDB_Sous_Famille(); int increment = 0; XmlDocument documentXml = new XmlDocument(); this.NomFicherXML = this.Ouvrir_XML_Fichier.FileName; documentXml.Load(this.NomFicherXML); foreach (XmlNode enregistrement in documentXml.DocumentElement) { string descriptionActicle = enregistrement.SelectSingleNode("description").InnerText; string refArticle = enregistrement.SelectSingleNode("refArticle").InnerText; double prixArticle = Double.Parse(enregistrement.SelectSingleNode("prixHT").InnerText); int quantiteArticle = 1; string nomSousfamille = enregistrement.SelectSingleNode("sousFamille").InnerText; string nomfamille = enregistrement.SelectSingleNode("famille").InnerText; string nomMarque = enregistrement.SelectSingleNode("marque").InnerText; /** * La marque * */ marqueMisejour = interMarque.GetMarque(nomMarque); if (marqueMisejour == null) { ResultatErreur = interMarque.InsererMarque(nomMarque); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); marqueMisejour = interMarque.GetMarque(nomMarque); } /** * La famille */ familleMisejour = interfamille.GetFamille(nomfamille); if (familleMisejour == null) { ResultatErreur = interfamille.InsererFamille(nomfamille); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); familleMisejour = interfamille.GetFamille(nomfamille); } /** * La sous famille * */ sousfamilleMisejour = interSousfamille.GetSousFamille(nomSousfamille); if (sousfamilleMisejour == null) { ResultatErreur = interSousfamille.InsererSousFamille(nomfamille, nomSousfamille); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); sousfamilleMisejour = interSousfamille.GetSousFamille(nomSousfamille); } else { if (sousfamilleMisejour.MaFamille.RefFamille != familleMisejour.RefFamille) { ResultatErreur = interSousfamille.ModifierSousFamille(sousfamilleMisejour.RefSousFamille, familleMisejour.RefFamille, sousfamilleMisejour.NomSousFamille); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); } } /** * L'article * */ articleMisejour = interArticle.GetArticle(refArticle); if (articleMisejour == null) { ResultatErreur = interArticle.InsererArticle(refArticle, descriptionActicle, sousfamilleMisejour.RefSousFamille, marqueMisejour.RefMarque, prixArticle, quantiteArticle); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); } else { ResultatErreur = interArticle.ModifierArticle(refArticle, descriptionActicle, sousfamilleMisejour.RefSousFamille, marqueMisejour.RefMarque, prixArticle, quantiteArticle); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); } increment++; Travail_En_Arriere_Plan.ReportProgress(increment); } Reussi_ = 2; // Mise à jour reussie }
/// <summary> /// Cette methode permet de lire le contenu du fichier xml et inserer dans la base de données /// </summary> /// <remarks> /// - Elle supprime en premier lieu , toutes les tuples qui se trouvent dans les différents tables de la base de données /// - Puis ouvre et lit le fichier XML avec <see cref="XmlDocument"/> /// - Pour chaque noeud lu , elle cree une marque , une famille , une sous famille puis un article si ils existent pas déjà /// </remarks> private void FileIntegration() { int increment = 0; XmlDocument documentXml = new XmlDocument(); /** * Suppression des tables de la base de données * */ ResultatErreur = InterfaceDB.SupprimerToutTable("Articles"); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); ResultatErreur = InterfaceDB.SupprimerToutTable("Familles"); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); ResultatErreur = InterfaceDB.SupprimerToutTable("SousFamilles"); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); ResultatErreur = InterfaceDB.SupprimerToutTable("Marques"); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); /** * Lecture des Elements dans le fichier xml choisie * */ this.NomFicherXML = this.Ouvrir_XML_Fichier.FileName; documentXml.Load(this.NomFicherXML); foreach (XmlNode enregistrement in documentXml.DocumentElement) { /** * Pour chaque noeud je recupère les élements d'un article * En creer la marque , la famille , la sous famille puis l'article */ string descriptionActicle = enregistrement.SelectSingleNode("description").InnerText; string refArticle = enregistrement.SelectSingleNode("refArticle").InnerText; double prixArticle = Double.Parse(enregistrement.SelectSingleNode("prixHT").InnerText); int quantiteArticle = 1; string nomSousfamille = enregistrement.SelectSingleNode("sousFamille").InnerText; string nomfamille = enregistrement.SelectSingleNode("famille").InnerText; string nomMarque = enregistrement.SelectSingleNode("marque").InnerText; /** * L'ordre d'insertion est importante */ InterfaceDB_Marque marque = new InterfaceDB_Marque(); ResultatErreur = marque.InsererMarque(nomMarque); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); InterfaceDB_Famille famille = new InterfaceDB_Famille(); ResultatErreur = famille.InsererFamille(nomfamille); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); InterfaceDB_Sous_Famille sousfamille = new InterfaceDB_Sous_Famille(); ResultatErreur = sousfamille.InsererSousFamille(nomfamille, nomSousfamille); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); Marque marqueArticle = marque.GetMarque(nomMarque); SousFamille sousFamilleArticle = sousfamille.GetSousFamille(nomSousfamille); if (marqueArticle != null && sousFamilleArticle != null) { InterfaceDB_Articles article = new InterfaceDB_Articles(); ResultatErreur = article.InsererArticle(refArticle, descriptionActicle, sousFamilleArticle.RefSousFamille, marqueArticle.RefMarque, prixArticle, quantiteArticle); TextBox_Affichage_ResultatEtErreurs.Invoke(new AjouterFinLigneResultatErreurs(ChangerResultat), ResultatErreur); } increment++; Travail_En_Arriere_Plan.ReportProgress(increment); } Reussi_ = 1; // Integration reussie }